blob: d37549a849e7015cb67b989d084befc06c1ee833 [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
Jeff Brown90655042010-12-02 13:50:46 -080021#include <ui/Input.h>
Jeff Brown6b53e8d2010-11-10 16:03:06 -080022#include <ui/Keyboard.h>
Jeff Brown90655042010-12-02 13:50:46 -080023#include <ui/KeyLayoutMap.h>
24#include <ui/KeyCharacterMap.h>
25#include <ui/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 Brown93fa9b32011-06-14 17:09:25 -0700211 /* Requests the EventHub to reopen all input devices on the next call to getEvents(). */
212 virtual void requestReopenDevices() = 0;
213
214 /* Wakes up getEvents() if it is blocked on a read. */
215 virtual void wake() = 0;
Jeff Brown1a84fd12011-06-02 01:26:32 -0700216
Jeff Brown89ef0722011-08-10 16:25:21 -0700217 /* Dump EventHub state to a string. */
Jeff Brownf2f48712010-10-01 17:46:21 -0700218 virtual void dump(String8& dump) = 0;
Jeff Brown89ef0722011-08-10 16:25:21 -0700219
220 /* Called by the heatbeat to ensures that the reader has not deadlocked. */
221 virtual void monitor() = 0;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700222};
223
224class EventHub : public EventHubInterface
225{
226public:
227 EventHub();
228
Jeff Brown46b9ac02010-04-22 18:58:52 -0700229 virtual uint32_t getDeviceClasses(int32_t deviceId) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700230
Jeff Brown46b9ac02010-04-22 18:58:52 -0700231 virtual String8 getDeviceName(int32_t deviceId) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700232
Jeff Brown47e6b1b2010-11-29 17:37:49 -0800233 virtual void getConfiguration(int32_t deviceId, PropertyMap* outConfiguration) const;
234
Jeff Brown6d0fec22010-07-23 21:28:06 -0700235 virtual status_t getAbsoluteAxisInfo(int32_t deviceId, int axis,
236 RawAbsoluteAxisInfo* outAxisInfo) const;
237
Jeff Browncc0c1592011-02-19 05:07:28 -0800238 virtual bool hasRelativeAxis(int32_t deviceId, int axis) const;
239
Jeff Brown80fd47c2011-05-24 01:07:44 -0700240 virtual bool hasInputProperty(int32_t deviceId, int property) const;
241
Jeff Brown6f2fba42011-02-19 01:08:02 -0800242 virtual status_t mapKey(int32_t deviceId, int scancode,
Jeff Brown46b9ac02010-04-22 18:58:52 -0700243 int32_t* outKeycode, uint32_t* outFlags) const;
244
Jeff Brown6f2fba42011-02-19 01:08:02 -0800245 virtual status_t mapAxis(int32_t deviceId, int scancode,
Jeff Brown3a22fa02011-03-04 13:07:49 -0800246 AxisInfo* outAxisInfo) const;
Jeff Brown6f2fba42011-02-19 01:08:02 -0800247
Jeff Brown1a84fd12011-06-02 01:26:32 -0700248 virtual void setExcludedDevices(const Vector<String8>& devices);
Jeff Brown46b9ac02010-04-22 18:58:52 -0700249
Jeff Brown6d0fec22010-07-23 21:28:06 -0700250 virtual int32_t getScanCodeState(int32_t deviceId, int32_t scanCode) const;
251 virtual int32_t getKeyCodeState(int32_t deviceId, int32_t keyCode) const;
252 virtual int32_t getSwitchState(int32_t deviceId, int32_t sw) const;
Jeff Brown2717eff2011-06-30 23:53:07 -0700253 virtual status_t getAbsoluteAxisValue(int32_t deviceId, int32_t axis, int32_t* outValue) const;
Jeff Brown46b9ac02010-04-22 18:58:52 -0700254
Jeff Brown6d0fec22010-07-23 21:28:06 -0700255 virtual bool markSupportedKeyCodes(int32_t deviceId, size_t numCodes,
256 const int32_t* keyCodes, uint8_t* outFlags) const;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800257
Jeff Brownb7198742011-03-18 18:14:26 -0700258 virtual size_t getEvents(int timeoutMillis, RawEvent* buffer, size_t bufferSize);
Mike Lockwood1d9dfc52009-07-16 11:11:18 -0400259
Jeff Brown49754db2011-07-01 17:37:58 -0700260 virtual bool hasScanCode(int32_t deviceId, int32_t scanCode) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700261 virtual bool hasLed(int32_t deviceId, int32_t led) const;
262 virtual void setLedState(int32_t deviceId, int32_t led, bool on);
263
Jeff Brown90655042010-12-02 13:50:46 -0800264 virtual void getVirtualKeyDefinitions(int32_t deviceId,
265 Vector<VirtualKeyDefinition>& outVirtualKeys) const;
266
Jeff Brown93fa9b32011-06-14 17:09:25 -0700267 virtual void requestReopenDevices();
268
269 virtual void wake();
Jeff Brown1a84fd12011-06-02 01:26:32 -0700270
Jeff Brownf2f48712010-10-01 17:46:21 -0700271 virtual void dump(String8& dump);
Jeff Brown89ef0722011-08-10 16:25:21 -0700272 virtual void monitor();
Jeff Brownf2f48712010-10-01 17:46:21 -0700273
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800274protected:
275 virtual ~EventHub();
Jeff Brown93fa9b32011-06-14 17:09:25 -0700276
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800277private:
Jeff Brown90655042010-12-02 13:50:46 -0800278 struct Device {
279 Device* next;
280
281 int fd;
282 const int32_t id;
283 const String8 path;
284 const InputDeviceIdentifier identifier;
285
286 uint32_t classes;
Jeff Brown93fa9b32011-06-14 17:09:25 -0700287
288 uint8_t keyBitmask[(KEY_MAX + 1) / 8];
289 uint8_t absBitmask[(ABS_MAX + 1) / 8];
290 uint8_t relBitmask[(REL_MAX + 1) / 8];
291 uint8_t swBitmask[(SW_MAX + 1) / 8];
292 uint8_t ledBitmask[(LED_MAX + 1) / 8];
293 uint8_t propBitmask[(INPUT_PROP_MAX + 1) / 8];
294
Jeff Brown90655042010-12-02 13:50:46 -0800295 String8 configurationFile;
296 PropertyMap* configuration;
297 VirtualKeyMap* virtualKeyMap;
298 KeyMap keyMap;
299
300 Device(int fd, int32_t id, const String8& path, const InputDeviceIdentifier& identifier);
301 ~Device();
302
303 void close();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800304 };
305
Jeff Brown93fa9b32011-06-14 17:09:25 -0700306 status_t openDeviceLocked(const char *devicePath);
307 status_t closeDeviceByPathLocked(const char *devicePath);
308
309 void closeDeviceLocked(Device* device);
310 void closeAllDevicesLocked();
311
312 status_t scanDirLocked(const char *dirname);
313 void scanDevicesLocked();
314 status_t readNotifyLocked();
315
Jeff Brown90655042010-12-02 13:50:46 -0800316 Device* getDeviceLocked(int32_t deviceId) const;
Jeff Brown93fa9b32011-06-14 17:09:25 -0700317 Device* getDeviceByPathLocked(const char* devicePath) const;
318
Jeff Brown90655042010-12-02 13:50:46 -0800319 bool hasKeycodeLocked(Device* device, int keycode) const;
Jeff Brown497a92c2010-09-12 17:55:08 -0700320
Jeff Brown93fa9b32011-06-14 17:09:25 -0700321 void loadConfigurationLocked(Device* device);
322 status_t loadVirtualKeyMapLocked(Device* device);
323 status_t loadKeyMapLocked(Device* device);
324 void setKeyboardPropertiesLocked(Device* device, bool builtInKeyboard);
325 void clearKeyboardPropertiesLocked(Device* device, bool builtInKeyboard);
Jeff Brown497a92c2010-09-12 17:55:08 -0700326
Jeff Brown93fa9b32011-06-14 17:09:25 -0700327 bool isExternalDeviceLocked(Device* device);
Jeff Brown56194eb2011-03-02 19:23:13 -0800328
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800329 // Protect all internal state.
Jeff Brown90655042010-12-02 13:50:46 -0800330 mutable Mutex mLock;
Mike Lockwood1d9dfc52009-07-16 11:11:18 -0400331
Jeff Brown90655042010-12-02 13:50:46 -0800332 // The actual id of the built-in keyboard, or -1 if none.
333 // EventHub remaps the built-in keyboard to id 0 externally as required by the API.
334 int32_t mBuiltInKeyboardId;
335
336 int32_t mNextDeviceId;
337
Jeff Brown93fa9b32011-06-14 17:09:25 -0700338 KeyedVector<int32_t, Device*> mDevices;
Jeff Brown90655042010-12-02 13:50:46 -0800339
340 Device *mOpeningDevices;
341 Device *mClosingDevices;
342
Jeff Brown90655042010-12-02 13:50:46 -0800343 bool mNeedToSendFinishedDeviceScan;
Jeff Brown93fa9b32011-06-14 17:09:25 -0700344 bool mNeedToReopenDevices;
Jeff Brown1a84fd12011-06-02 01:26:32 -0700345 bool mNeedToScanDevices;
346 Vector<String8> mExcludedDevices;
Mike Lockwood1d9dfc52009-07-16 11:11:18 -0400347
Jeff Brown93fa9b32011-06-14 17:09:25 -0700348 int mEpollFd;
349 int mINotifyFd;
350 int mWakeReadPipeFd;
351 int mWakeWritePipeFd;
Jeff Browncc2e7172010-08-17 16:48:25 -0700352
Jeff Brown93fa9b32011-06-14 17:09:25 -0700353 // Ids used for epoll notifications not associated with devices.
354 static const uint32_t EPOLL_ID_INOTIFY = 0x80000001;
355 static const uint32_t EPOLL_ID_WAKE = 0x80000002;
356
357 // Epoll FD list size hint.
358 static const int EPOLL_SIZE_HINT = 8;
359
360 // Maximum number of signalled FDs to handle at a time.
361 static const int EPOLL_MAX_EVENTS = 16;
362
363 // The array of pending epoll events and the index of the next event to be handled.
364 struct epoll_event mPendingEventItems[EPOLL_MAX_EVENTS];
365 size_t mPendingEventCount;
366 size_t mPendingEventIndex;
367 bool mPendingINotify;
Jeff Brownb7198742011-03-18 18:14:26 -0700368
369 // Set to the number of CPUs.
370 int32_t mNumCpus;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800371};
372
373}; // namespace android
374
375#endif // _RUNTIME_EVENT_HUB_H