blob: 4eb47c65dbe180607f057e1ebe6e7dcb0b3c1e9c [file] [log] [blame]
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2005 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17//
18#ifndef _RUNTIME_EVENT_HUB_H
19#define _RUNTIME_EVENT_HUB_H
20
Mathias Agopianb93a03f82012-02-17 15:34:57 -080021#include <androidfw/Input.h>
22#include <androidfw/Keyboard.h>
23#include <androidfw/KeyLayoutMap.h>
24#include <androidfw/KeyCharacterMap.h>
25#include <androidfw/VirtualKeyMap.h>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080026#include <utils/String8.h>
27#include <utils/threads.h>
Mathias Agopian3b4062e2009-05-31 19:13:00 -070028#include <utils/Log.h>
29#include <utils/threads.h>
30#include <utils/List.h>
31#include <utils/Errors.h>
Jeff Brown47e6b1b2010-11-29 17:37:49 -080032#include <utils/PropertyMap.h>
Jeff Brown90655042010-12-02 13:50:46 -080033#include <utils/Vector.h>
Jeff Brown93fa9b32011-06-14 17:09:25 -070034#include <utils/KeyedVector.h>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080035
36#include <linux/input.h>
Jeff Brown93fa9b32011-06-14 17:09:25 -070037#include <sys/epoll.h>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080038
Jeff Brown46b9ac02010-04-22 18:58:52 -070039/* Convenience constants. */
40
41#define BTN_FIRST 0x100 // first button scancode
42#define BTN_LAST 0x15f // last button scancode
43
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080044namespace android {
45
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080046/*
Jeff Brown6d0fec22010-07-23 21:28:06 -070047 * A raw event as retrieved from the EventHub.
48 */
49struct RawEvent {
50 nsecs_t when;
51 int32_t deviceId;
52 int32_t type;
53 int32_t scanCode;
54 int32_t keyCode;
55 int32_t value;
56 uint32_t flags;
57};
58
59/* Describes an absolute axis. */
60struct RawAbsoluteAxisInfo {
61 bool valid; // true if the information is valid, false otherwise
62
63 int32_t minValue; // minimum value
64 int32_t maxValue; // maximum value
65 int32_t flat; // center flat position, eg. flat == 8 means center is between -8 and 8
66 int32_t fuzz; // error tolerance, eg. fuzz == 4 means value is +/- 4 due to noise
Jeff Brownb3a2d132011-06-12 18:14:50 -070067 int32_t resolution; // resolution in units per mm or radians per mm
Jeff Brown6d0fec22010-07-23 21:28:06 -070068
Jeff Brown8d608662010-08-30 03:02:23 -070069 inline void clear() {
70 valid = false;
71 minValue = 0;
72 maxValue = 0;
73 flat = 0;
74 fuzz = 0;
Jeff Brownb3a2d132011-06-12 18:14:50 -070075 resolution = 0;
Jeff Brown8d608662010-08-30 03:02:23 -070076 }
Jeff Brown6d0fec22010-07-23 21:28:06 -070077};
78
79/*
Jeff Brownc5ed5912010-07-14 18:48:53 -070080 * Input device classes.
81 */
82enum {
Jeff Browncb1404e2011-01-15 18:14:15 -080083 /* The input device is a keyboard or has buttons. */
Jeff Brownc5ed5912010-07-14 18:48:53 -070084 INPUT_DEVICE_CLASS_KEYBOARD = 0x00000001,
85
86 /* The input device is an alpha-numeric keyboard (not just a dial pad). */
87 INPUT_DEVICE_CLASS_ALPHAKEY = 0x00000002,
88
Jeff Brown58a2da82011-01-25 16:02:22 -080089 /* The input device is a touchscreen or a touchpad (either single-touch or multi-touch). */
90 INPUT_DEVICE_CLASS_TOUCH = 0x00000004,
Jeff Brownc5ed5912010-07-14 18:48:53 -070091
Jeff Brown83c09682010-12-23 17:50:18 -080092 /* The input device is a cursor device such as a trackball or mouse. */
93 INPUT_DEVICE_CLASS_CURSOR = 0x00000008,
Jeff Brownc5ed5912010-07-14 18:48:53 -070094
95 /* The input device is a multi-touch touchscreen. */
Jeff Brown58a2da82011-01-25 16:02:22 -080096 INPUT_DEVICE_CLASS_TOUCH_MT = 0x00000010,
Jeff Brownc5ed5912010-07-14 18:48:53 -070097
Jeff Browndc1ab4b2010-09-14 18:03:38 -070098 /* The input device is a directional pad (implies keyboard, has DPAD keys). */
Jeff Brownc5ed5912010-07-14 18:48:53 -070099 INPUT_DEVICE_CLASS_DPAD = 0x00000020,
100
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700101 /* The input device is a gamepad (implies keyboard, has BUTTON keys). */
Jeff Brown6d0fec22010-07-23 21:28:06 -0700102 INPUT_DEVICE_CLASS_GAMEPAD = 0x00000040,
103
104 /* The input device has switches. */
105 INPUT_DEVICE_CLASS_SWITCH = 0x00000080,
Jeff Browncb1404e2011-01-15 18:14:15 -0800106
107 /* The input device is a joystick (implies gamepad, has joystick absolute axes). */
108 INPUT_DEVICE_CLASS_JOYSTICK = 0x00000100,
Jeff Brown56194eb2011-03-02 19:23:13 -0800109
110 /* The input device is external (not built-in). */
111 INPUT_DEVICE_CLASS_EXTERNAL = 0x80000000,
Jeff Brownc5ed5912010-07-14 18:48:53 -0700112};
113
114/*
Jeff Brown9ee285a2011-08-31 12:56:34 -0700115 * Gets the class that owns an axis, in cases where multiple classes might claim
116 * the same axis for different purposes.
117 */
118extern uint32_t getAbsAxisUsage(int32_t axis, uint32_t deviceClasses);
119
120/*
Jeff Brown46b9ac02010-04-22 18:58:52 -0700121 * Grand Central Station for events.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800122 *
Jeff Brown46b9ac02010-04-22 18:58:52 -0700123 * The event hub aggregates input events received across all known input
124 * devices on the system, including devices that may be emulated by the simulator
125 * environment. In addition, the event hub generates fake input events to indicate
126 * when devices are added or removed.
127 *
Jeff Brownb4ff35d2011-01-02 16:37:43 -0800128 * The event hub provides a stream of input events (via the getEvent function).
Jeff Brown46b9ac02010-04-22 18:58:52 -0700129 * It also supports querying the current actual state of input devices such as identifying
130 * which keys are currently down. Finally, the event hub keeps track of the capabilities of
131 * individual input devices, such as their class and the set of key codes that they support.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800132 */
Jeff Brown46b9ac02010-04-22 18:58:52 -0700133class EventHubInterface : public virtual RefBase {
134protected:
135 EventHubInterface() { }
136 virtual ~EventHubInterface() { }
137
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800138public:
Jeff Brown46b9ac02010-04-22 18:58:52 -0700139 // Synthetic raw event type codes produced when devices are added or removed.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800140 enum {
Jeff Brown7342bb92010-10-01 18:55:43 -0700141 // Sent when a device is added.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800142 DEVICE_ADDED = 0x10000000,
Jeff Brown7342bb92010-10-01 18:55:43 -0700143 // Sent when a device is removed.
144 DEVICE_REMOVED = 0x20000000,
145 // Sent when all added/removed devices from the most recent scan have been reported.
146 // This event is always sent at least once.
147 FINISHED_DEVICE_SCAN = 0x30000000,
Jeff Brownb7198742011-03-18 18:14:26 -0700148
149 FIRST_SYNTHETIC_EVENT = DEVICE_ADDED,
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800150 };
Jeff Brown46b9ac02010-04-22 18:58:52 -0700151
152 virtual uint32_t getDeviceClasses(int32_t deviceId) const = 0;
153
154 virtual String8 getDeviceName(int32_t deviceId) const = 0;
155
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800156 virtual void getConfiguration(int32_t deviceId, PropertyMap* outConfiguration) const = 0;
157
Jeff Brown6d0fec22010-07-23 21:28:06 -0700158 virtual status_t getAbsoluteAxisInfo(int32_t deviceId, int axis,
159 RawAbsoluteAxisInfo* outAxisInfo) const = 0;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700160
Jeff Browncc0c1592011-02-19 05:07:28 -0800161 virtual bool hasRelativeAxis(int32_t deviceId, int axis) const = 0;
162
Jeff Brown80fd47c2011-05-24 01:07:44 -0700163 virtual bool hasInputProperty(int32_t deviceId, int property) const = 0;
164
Jeff Brown6f2fba42011-02-19 01:08:02 -0800165 virtual status_t mapKey(int32_t deviceId, int scancode,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700166 int32_t* outKeycode, uint32_t* outFlags) const = 0;
167
Jeff Brown6f2fba42011-02-19 01:08:02 -0800168 virtual status_t mapAxis(int32_t deviceId, int scancode,
Jeff Brown3a22fa02011-03-04 13:07:49 -0800169 AxisInfo* outAxisInfo) const = 0;
Jeff Brown6f2fba42011-02-19 01:08:02 -0800170
Jeff Brown1a84fd12011-06-02 01:26:32 -0700171 // Sets devices that are excluded from opening.
172 // This can be used to ignore input devices for sensors.
173 virtual void setExcludedDevices(const Vector<String8>& devices) = 0;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700174
175 /*
Jeff Brownb7198742011-03-18 18:14:26 -0700176 * Wait for events to become available and returns them.
Jeff Brown46b9ac02010-04-22 18:58:52 -0700177 * After returning, the EventHub holds onto a wake lock until the next call to getEvent.
178 * This ensures that the device will not go to sleep while the event is being processed.
179 * If the device needs to remain awake longer than that, then the caller is responsible
180 * for taking care of it (say, by poking the power manager user activity timer).
Jeff Brownaa3855d2011-03-17 01:34:19 -0700181 *
182 * The timeout is advisory only. If the device is asleep, it will not wake just to
183 * service the timeout.
184 *
Jeff Brownb7198742011-03-18 18:14:26 -0700185 * Returns the number of events obtained, or 0 if the timeout expired.
Jeff Brown46b9ac02010-04-22 18:58:52 -0700186 */
Jeff Brownb7198742011-03-18 18:14:26 -0700187 virtual size_t getEvents(int timeoutMillis, RawEvent* buffer, size_t bufferSize) = 0;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700188
189 /*
190 * Query current input state.
Jeff Brown46b9ac02010-04-22 18:58:52 -0700191 */
Jeff Brown6d0fec22010-07-23 21:28:06 -0700192 virtual int32_t getScanCodeState(int32_t deviceId, int32_t scanCode) const = 0;
193 virtual int32_t getKeyCodeState(int32_t deviceId, int32_t keyCode) const = 0;
194 virtual int32_t getSwitchState(int32_t deviceId, int32_t sw) const = 0;
Jeff Brown2717eff2011-06-30 23:53:07 -0700195 virtual status_t getAbsoluteAxisValue(int32_t deviceId, int32_t axis,
196 int32_t* outValue) const = 0;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700197
198 /*
199 * Examine key input devices for specific framework keycode support
200 */
Jeff Brown6d0fec22010-07-23 21:28:06 -0700201 virtual bool markSupportedKeyCodes(int32_t deviceId, size_t numCodes, const int32_t* keyCodes,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700202 uint8_t* outFlags) const = 0;
Jeff Brownf2f48712010-10-01 17:46:21 -0700203
Jeff Brown49754db2011-07-01 17:37:58 -0700204 virtual bool hasScanCode(int32_t deviceId, int32_t scanCode) const = 0;
Jeff Brown497a92c2010-09-12 17:55:08 -0700205 virtual bool hasLed(int32_t deviceId, int32_t led) const = 0;
206 virtual void setLedState(int32_t deviceId, int32_t led, bool on) = 0;
207
Jeff Brown90655042010-12-02 13:50:46 -0800208 virtual void getVirtualKeyDefinitions(int32_t deviceId,
209 Vector<VirtualKeyDefinition>& outVirtualKeys) const = 0;
210
Jeff Brown1e08fe92011-11-15 17:48:10 -0800211 virtual String8 getKeyCharacterMapFile(int32_t deviceId) const = 0;
212
Jeff Brown93fa9b32011-06-14 17:09:25 -0700213 /* Requests the EventHub to reopen all input devices on the next call to getEvents(). */
214 virtual void requestReopenDevices() = 0;
215
216 /* Wakes up getEvents() if it is blocked on a read. */
217 virtual void wake() = 0;
Jeff Brown1a84fd12011-06-02 01:26:32 -0700218
Jeff Brown89ef0722011-08-10 16:25:21 -0700219 /* Dump EventHub state to a string. */
Jeff Brownf2f48712010-10-01 17:46:21 -0700220 virtual void dump(String8& dump) = 0;
Jeff Brown89ef0722011-08-10 16:25:21 -0700221
222 /* Called by the heatbeat to ensures that the reader has not deadlocked. */
223 virtual void monitor() = 0;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700224};
225
226class EventHub : public EventHubInterface
227{
228public:
229 EventHub();
230
Jeff Brown46b9ac02010-04-22 18:58:52 -0700231 virtual uint32_t getDeviceClasses(int32_t deviceId) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700232
Jeff Brown46b9ac02010-04-22 18:58:52 -0700233 virtual String8 getDeviceName(int32_t deviceId) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700234
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800235 virtual void getConfiguration(int32_t deviceId, PropertyMap* outConfiguration) const;
236
Jeff Brown6d0fec22010-07-23 21:28:06 -0700237 virtual status_t getAbsoluteAxisInfo(int32_t deviceId, int axis,
238 RawAbsoluteAxisInfo* outAxisInfo) const;
239
Jeff Browncc0c1592011-02-19 05:07:28 -0800240 virtual bool hasRelativeAxis(int32_t deviceId, int axis) const;
241
Jeff Brown80fd47c2011-05-24 01:07:44 -0700242 virtual bool hasInputProperty(int32_t deviceId, int property) const;
243
Jeff Brown6f2fba42011-02-19 01:08:02 -0800244 virtual status_t mapKey(int32_t deviceId, int scancode,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700245 int32_t* outKeycode, uint32_t* outFlags) const;
246
Jeff Brown6f2fba42011-02-19 01:08:02 -0800247 virtual status_t mapAxis(int32_t deviceId, int scancode,
Jeff Brown3a22fa02011-03-04 13:07:49 -0800248 AxisInfo* outAxisInfo) const;
Jeff Brown6f2fba42011-02-19 01:08:02 -0800249
Jeff Brown1a84fd12011-06-02 01:26:32 -0700250 virtual void setExcludedDevices(const Vector<String8>& devices);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700251
Jeff Brown6d0fec22010-07-23 21:28:06 -0700252 virtual int32_t getScanCodeState(int32_t deviceId, int32_t scanCode) const;
253 virtual int32_t getKeyCodeState(int32_t deviceId, int32_t keyCode) const;
254 virtual int32_t getSwitchState(int32_t deviceId, int32_t sw) const;
Jeff Brown2717eff2011-06-30 23:53:07 -0700255 virtual status_t getAbsoluteAxisValue(int32_t deviceId, int32_t axis, int32_t* outValue) const;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700256
Jeff Brown6d0fec22010-07-23 21:28:06 -0700257 virtual bool markSupportedKeyCodes(int32_t deviceId, size_t numCodes,
258 const int32_t* keyCodes, uint8_t* outFlags) const;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800259
Jeff Brownb7198742011-03-18 18:14:26 -0700260 virtual size_t getEvents(int timeoutMillis, RawEvent* buffer, size_t bufferSize);
Mike Lockwood1d9dfc52009-07-16 11:11:18 -0400261
Jeff Brown49754db2011-07-01 17:37:58 -0700262 virtual bool hasScanCode(int32_t deviceId, int32_t scanCode) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700263 virtual bool hasLed(int32_t deviceId, int32_t led) const;
264 virtual void setLedState(int32_t deviceId, int32_t led, bool on);
265
Jeff Brown90655042010-12-02 13:50:46 -0800266 virtual void getVirtualKeyDefinitions(int32_t deviceId,
267 Vector<VirtualKeyDefinition>& outVirtualKeys) const;
268
Jeff Brown1e08fe92011-11-15 17:48:10 -0800269 virtual String8 getKeyCharacterMapFile(int32_t deviceId) const;
270
Jeff Brown93fa9b32011-06-14 17:09:25 -0700271 virtual void requestReopenDevices();
272
273 virtual void wake();
Jeff Brown1a84fd12011-06-02 01:26:32 -0700274
Jeff Brownf2f48712010-10-01 17:46:21 -0700275 virtual void dump(String8& dump);
Jeff Brown89ef0722011-08-10 16:25:21 -0700276 virtual void monitor();
Jeff Brownf2f48712010-10-01 17:46:21 -0700277
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800278protected:
279 virtual ~EventHub();
Jeff Brown93fa9b32011-06-14 17:09:25 -0700280
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800281private:
Jeff Brown90655042010-12-02 13:50:46 -0800282 struct Device {
283 Device* next;
284
285 int fd;
286 const int32_t id;
287 const String8 path;
288 const InputDeviceIdentifier identifier;
289
290 uint32_t classes;
Jeff Brown93fa9b32011-06-14 17:09:25 -0700291
292 uint8_t keyBitmask[(KEY_MAX + 1) / 8];
293 uint8_t absBitmask[(ABS_MAX + 1) / 8];
294 uint8_t relBitmask[(REL_MAX + 1) / 8];
295 uint8_t swBitmask[(SW_MAX + 1) / 8];
296 uint8_t ledBitmask[(LED_MAX + 1) / 8];
297 uint8_t propBitmask[(INPUT_PROP_MAX + 1) / 8];
298
Jeff Brown90655042010-12-02 13:50:46 -0800299 String8 configurationFile;
300 PropertyMap* configuration;
301 VirtualKeyMap* virtualKeyMap;
302 KeyMap keyMap;
303
304 Device(int fd, int32_t id, const String8& path, const InputDeviceIdentifier& identifier);
305 ~Device();
306
307 void close();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800308 };
309
Jeff Brown93fa9b32011-06-14 17:09:25 -0700310 status_t openDeviceLocked(const char *devicePath);
311 status_t closeDeviceByPathLocked(const char *devicePath);
312
313 void closeDeviceLocked(Device* device);
314 void closeAllDevicesLocked();
315
316 status_t scanDirLocked(const char *dirname);
317 void scanDevicesLocked();
318 status_t readNotifyLocked();
319
Jeff Brown90655042010-12-02 13:50:46 -0800320 Device* getDeviceLocked(int32_t deviceId) const;
Jeff Brown93fa9b32011-06-14 17:09:25 -0700321 Device* getDeviceByPathLocked(const char* devicePath) const;
322
Jeff Brown90655042010-12-02 13:50:46 -0800323 bool hasKeycodeLocked(Device* device, int keycode) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700324
Jeff Brown93fa9b32011-06-14 17:09:25 -0700325 void loadConfigurationLocked(Device* device);
326 status_t loadVirtualKeyMapLocked(Device* device);
327 status_t loadKeyMapLocked(Device* device);
Jeff Brown497a92c2010-09-12 17:55:08 -0700328
Jeff Brown93fa9b32011-06-14 17:09:25 -0700329 bool isExternalDeviceLocked(Device* device);
Jeff Brown56194eb2011-03-02 19:23:13 -0800330
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800331 // Protect all internal state.
Jeff Brown90655042010-12-02 13:50:46 -0800332 mutable Mutex mLock;
Mike Lockwood1d9dfc52009-07-16 11:11:18 -0400333
Jeff Brown90655042010-12-02 13:50:46 -0800334 // The actual id of the built-in keyboard, or -1 if none.
335 // EventHub remaps the built-in keyboard to id 0 externally as required by the API.
336 int32_t mBuiltInKeyboardId;
337
338 int32_t mNextDeviceId;
339
Jeff Brown93fa9b32011-06-14 17:09:25 -0700340 KeyedVector<int32_t, Device*> mDevices;
Jeff Brown90655042010-12-02 13:50:46 -0800341
342 Device *mOpeningDevices;
343 Device *mClosingDevices;
344
Jeff Brown90655042010-12-02 13:50:46 -0800345 bool mNeedToSendFinishedDeviceScan;
Jeff Brown93fa9b32011-06-14 17:09:25 -0700346 bool mNeedToReopenDevices;
Jeff Brown1a84fd12011-06-02 01:26:32 -0700347 bool mNeedToScanDevices;
348 Vector<String8> mExcludedDevices;
Mike Lockwood1d9dfc52009-07-16 11:11:18 -0400349
Jeff Brown93fa9b32011-06-14 17:09:25 -0700350 int mEpollFd;
351 int mINotifyFd;
352 int mWakeReadPipeFd;
353 int mWakeWritePipeFd;
Jeff Browncc2e7172010-08-17 16:48:25 -0700354
Jeff Brown93fa9b32011-06-14 17:09:25 -0700355 // Ids used for epoll notifications not associated with devices.
356 static const uint32_t EPOLL_ID_INOTIFY = 0x80000001;
357 static const uint32_t EPOLL_ID_WAKE = 0x80000002;
358
359 // Epoll FD list size hint.
360 static const int EPOLL_SIZE_HINT = 8;
361
362 // Maximum number of signalled FDs to handle at a time.
363 static const int EPOLL_MAX_EVENTS = 16;
364
365 // The array of pending epoll events and the index of the next event to be handled.
366 struct epoll_event mPendingEventItems[EPOLL_MAX_EVENTS];
367 size_t mPendingEventCount;
368 size_t mPendingEventIndex;
369 bool mPendingINotify;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800370};
371
372}; // namespace android
373
374#endif // _RUNTIME_EVENT_HUB_H