2 * drivers/macintosh/mac_hid.c
4 * HID support stuff for Macintosh computers.
6 * Copyright (C) 2000 Franz Sirl.
8 * This file will soon be removed in favor of an uinput userspace tool.
11 #include <linux/init.h>
12 #include <linux/proc_fs.h>
13 #include <linux/sysctl.h>
14 #include <linux/input.h>
15 #include <linux/module.h>
16 #include <linux/kbd_kern.h>
19 static struct input_dev
*emumousebtn
;
20 static int emumousebtn_input_register(void);
21 static int mouse_emulate_buttons
;
22 static int mouse_button2_keycode
= KEY_RIGHTCTRL
; /* right control key */
23 static int mouse_button3_keycode
= KEY_RIGHTALT
; /* right option key */
24 static int mouse_last_keycode
;
26 #if defined(CONFIG_SYSCTL)
27 /* file(s) in /proc/sys/dev/mac_hid */
28 static ctl_table mac_hid_files
[] = {
30 .ctl_name
= DEV_MAC_HID_MOUSE_BUTTON_EMULATION
,
31 .procname
= "mouse_button_emulation",
32 .data
= &mouse_emulate_buttons
,
33 .maxlen
= sizeof(int),
35 .proc_handler
= &proc_dointvec
,
38 .ctl_name
= DEV_MAC_HID_MOUSE_BUTTON2_KEYCODE
,
39 .procname
= "mouse_button2_keycode",
40 .data
= &mouse_button2_keycode
,
41 .maxlen
= sizeof(int),
43 .proc_handler
= &proc_dointvec
,
46 .ctl_name
= DEV_MAC_HID_MOUSE_BUTTON3_KEYCODE
,
47 .procname
= "mouse_button3_keycode",
48 .data
= &mouse_button3_keycode
,
49 .maxlen
= sizeof(int),
51 .proc_handler
= &proc_dointvec
,
56 /* dir in /proc/sys/dev */
57 static ctl_table mac_hid_dir
[] = {
59 .ctl_name
= DEV_MAC_HID
,
60 .procname
= "mac_hid",
63 .child
= mac_hid_files
,
68 /* /proc/sys/dev itself, in case that is not there yet */
69 static ctl_table mac_hid_root_dir
[] = {
80 static struct ctl_table_header
*mac_hid_sysctl_header
;
82 #endif /* endif CONFIG_SYSCTL */
84 int mac_hid_mouse_emulate_buttons(int caller
, unsigned int keycode
, int down
)
88 /* Called from keyboard.c */
89 if (mouse_emulate_buttons
90 && (keycode
== mouse_button2_keycode
91 || keycode
== mouse_button3_keycode
)) {
92 if (mouse_emulate_buttons
== 1) {
93 input_report_key(emumousebtn
,
94 keycode
== mouse_button2_keycode
? BTN_MIDDLE
: BTN_RIGHT
,
96 input_sync(emumousebtn
);
99 mouse_last_keycode
= down
? keycode
: 0;
106 static struct lock_class_key emumousebtn_event_class
;
107 static struct lock_class_key emumousebtn_mutex_class
;
109 static int emumousebtn_input_register(void)
113 emumousebtn
= input_allocate_device();
117 lockdep_set_class(&emumousebtn
->event_lock
, &emumousebtn_event_class
);
118 lockdep_set_class(&emumousebtn
->mutex
, &emumousebtn_mutex_class
);
120 emumousebtn
->name
= "Macintosh mouse button emulation";
121 emumousebtn
->id
.bustype
= BUS_ADB
;
122 emumousebtn
->id
.vendor
= 0x0001;
123 emumousebtn
->id
.product
= 0x0001;
124 emumousebtn
->id
.version
= 0x0100;
126 emumousebtn
->evbit
[0] = BIT_MASK(EV_KEY
) | BIT_MASK(EV_REL
);
127 emumousebtn
->keybit
[BIT_WORD(BTN_MOUSE
)] = BIT_MASK(BTN_LEFT
) |
128 BIT_MASK(BTN_MIDDLE
) | BIT_MASK(BTN_RIGHT
);
129 emumousebtn
->relbit
[0] = BIT_MASK(REL_X
) | BIT_MASK(REL_Y
);
131 ret
= input_register_device(emumousebtn
);
133 input_free_device(emumousebtn
);
138 static int __init
mac_hid_init(void)
142 err
= emumousebtn_input_register();
146 #if defined(CONFIG_SYSCTL)
147 mac_hid_sysctl_header
= register_sysctl_table(mac_hid_root_dir
);
148 #endif /* CONFIG_SYSCTL */
153 device_initcall(mac_hid_init
);