diff options
author | Daniel van Vugt <vanvugt@gmail.com> | 2011-10-14 01:39:34 -0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2011-10-21 04:13:55 -0400 |
commit | bca621421c53caf73f36e181d6e5fe41fe0da7a7 (patch) | |
tree | 196f178300d1b823640219ea7df7338ec52ac4af /drivers/hid/hid-magicmouse.c | |
parent | fad9fbe8651e8abd9794d4b4c4133241aa3093b5 (diff) |
HID: hid-magicmouse: Magic Trackpad has 1 button, not 2
hid-magicmouse was advertising the Apple Magic Trackpad as having 2
buttons (left and right) when it actually only has 1 button.
Advertising multiple buttons makes Xorg disable all button 2 and 3
emulation (using multi-finger clicks). So Xorg users don't get working
right/middle-click emulation out of the box.
This patch makes hid-magicmouse correctly only report one real button
for Magic Trackpad, which in turn makes Xorg enable multi-finger click
support to emulate right/middle buttons.
[http://launchpad.net/bugs/862094]
Signed-off-by: Daniel van Vugt <vanvugt@gmail.com>
Reviewed-by: Chase Douglas <chase.douglas@canonical.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid/hid-magicmouse.c')
-rw-r--r-- | drivers/hid/hid-magicmouse.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/hid/hid-magicmouse.c b/drivers/hid/hid-magicmouse.c index f0fbd7bd239e..2ab71758e2e2 100644 --- a/drivers/hid/hid-magicmouse.c +++ b/drivers/hid/hid-magicmouse.c | |||
@@ -405,6 +405,13 @@ static void magicmouse_setup_input(struct input_dev *input, struct hid_device *h | |||
405 | __set_bit(REL_HWHEEL, input->relbit); | 405 | __set_bit(REL_HWHEEL, input->relbit); |
406 | } | 406 | } |
407 | } else { /* USB_DEVICE_ID_APPLE_MAGICTRACKPAD */ | 407 | } else { /* USB_DEVICE_ID_APPLE_MAGICTRACKPAD */ |
408 | /* input->keybit is initialized with incorrect button info | ||
409 | * for Magic Trackpad. There really is only one physical | ||
410 | * button (BTN_LEFT == BTN_MOUSE). Make sure we don't | ||
411 | * advertise buttons that don't exist... | ||
412 | */ | ||
413 | __clear_bit(BTN_RIGHT, input->keybit); | ||
414 | __clear_bit(BTN_MIDDLE, input->keybit); | ||
408 | __set_bit(BTN_MOUSE, input->keybit); | 415 | __set_bit(BTN_MOUSE, input->keybit); |
409 | __set_bit(BTN_TOOL_FINGER, input->keybit); | 416 | __set_bit(BTN_TOOL_FINGER, input->keybit); |
410 | __set_bit(BTN_TOOL_DOUBLETAP, input->keybit); | 417 | __set_bit(BTN_TOOL_DOUBLETAP, input->keybit); |