1 #include "bcm47xx_private.h"
3 #include <linux/input.h>
4 #include <linux/gpio_keys.h>
5 #include <linux/interrupt.h>
6 #include <bcm47xx_board.h>
9 /**************************************************
11 **************************************************/
13 #define BCM47XX_GPIO_KEY(_gpio, _code) \
22 static const struct gpio_keys_button
23 bcm47xx_buttons_asus_rtn12
[] __initconst
= {
24 BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON
),
25 BCM47XX_GPIO_KEY(1, KEY_RESTART
),
26 BCM47XX_GPIO_KEY(4, BTN_0
), /* Router mode */
27 BCM47XX_GPIO_KEY(5, BTN_1
), /* Repeater mode */
28 BCM47XX_GPIO_KEY(6, BTN_2
), /* AP mode */
31 static const struct gpio_keys_button
32 bcm47xx_buttons_asus_rtn16
[] __initconst
= {
33 BCM47XX_GPIO_KEY(6, KEY_WPS_BUTTON
),
34 BCM47XX_GPIO_KEY(8, KEY_RESTART
),
37 static const struct gpio_keys_button
38 bcm47xx_buttons_asus_rtn66u
[] __initconst
= {
39 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
40 BCM47XX_GPIO_KEY(9, KEY_RESTART
),
43 static const struct gpio_keys_button
44 bcm47xx_buttons_asus_wl300g
[] __initconst
= {
45 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
48 static const struct gpio_keys_button
49 bcm47xx_buttons_asus_wl320ge
[] __initconst
= {
50 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
53 static const struct gpio_keys_button
54 bcm47xx_buttons_asus_wl330ge
[] __initconst
= {
55 BCM47XX_GPIO_KEY(2, KEY_RESTART
),
58 static const struct gpio_keys_button
59 bcm47xx_buttons_asus_wl500gd
[] __initconst
= {
60 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
63 static const struct gpio_keys_button
64 bcm47xx_buttons_asus_wl500gpv1
[] __initconst
= {
65 BCM47XX_GPIO_KEY(0, KEY_RESTART
),
66 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
69 static const struct gpio_keys_button
70 bcm47xx_buttons_asus_wl500gpv2
[] __initconst
= {
71 BCM47XX_GPIO_KEY(2, KEY_RESTART
),
72 BCM47XX_GPIO_KEY(3, KEY_WPS_BUTTON
),
75 static const struct gpio_keys_button
76 bcm47xx_buttons_asus_wl500w
[] __initconst
= {
77 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
78 BCM47XX_GPIO_KEY(7, KEY_WPS_BUTTON
),
81 static const struct gpio_keys_button
82 bcm47xx_buttons_asus_wl520gc
[] __initconst
= {
83 BCM47XX_GPIO_KEY(2, KEY_RESTART
),
84 BCM47XX_GPIO_KEY(3, KEY_WPS_BUTTON
),
87 static const struct gpio_keys_button
88 bcm47xx_buttons_asus_wl520gu
[] __initconst
= {
89 BCM47XX_GPIO_KEY(2, KEY_RESTART
),
90 BCM47XX_GPIO_KEY(3, KEY_WPS_BUTTON
),
93 static const struct gpio_keys_button
94 bcm47xx_buttons_asus_wl700ge
[] __initconst
= {
95 BCM47XX_GPIO_KEY(0, KEY_POWER
), /* Hard disk power switch */
96 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
), /* EZSetup */
97 BCM47XX_GPIO_KEY(6, KEY_COPY
), /* Copy data from USB to internal disk */
98 BCM47XX_GPIO_KEY(7, KEY_RESTART
), /* Hard reset */
101 static const struct gpio_keys_button
102 bcm47xx_buttons_asus_wlhdd
[] __initconst
= {
103 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
108 static const struct gpio_keys_button
109 bcm47xx_buttons_huawei_e970
[] __initconst
= {
110 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
115 static const struct gpio_keys_button
116 bcm47xx_buttons_belkin_f7d4301
[] __initconst
= {
117 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
118 BCM47XX_GPIO_KEY(8, KEY_WPS_BUTTON
),
123 static const struct gpio_keys_button
124 bcm47xx_buttons_buffalo_whr2_a54g54
[] __initconst
= {
125 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
128 static const struct gpio_keys_button
129 bcm47xx_buttons_buffalo_whr_g125
[] __initconst
= {
130 BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON
),
131 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
132 BCM47XX_GPIO_KEY(5, BTN_0
), /* Router / AP mode swtich */
135 static const struct gpio_keys_button
136 bcm47xx_buttons_buffalo_whr_g54s
[] __initconst
= {
137 BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON
),
138 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
139 BCM47XX_GPIO_KEY(5, BTN_0
), /* Router / AP mode swtich */
142 static const struct gpio_keys_button
143 bcm47xx_buttons_buffalo_whr_hp_g54
[] __initconst
= {
144 BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON
),
145 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
146 BCM47XX_GPIO_KEY(5, BTN_0
), /* Router / AP mode swtich */
149 static const struct gpio_keys_button
150 bcm47xx_buttons_buffalo_wzr_g300n
[] __initconst
= {
151 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
154 static const struct gpio_keys_button
155 bcm47xx_buttons_buffalo_wzr_rs_g54
[] __initconst
= {
156 BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON
),
157 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
160 static const struct gpio_keys_button
161 bcm47xx_buttons_buffalo_wzr_rs_g54hp
[] __initconst
= {
162 BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON
),
163 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
168 static const struct gpio_keys_button
169 bcm47xx_buttons_dell_tm2300
[] __initconst
= {
170 BCM47XX_GPIO_KEY(0, KEY_RESTART
),
175 static const struct gpio_keys_button
176 bcm47xx_buttons_dlink_dir130
[] __initconst
= {
177 BCM47XX_GPIO_KEY(3, KEY_RESTART
),
178 BCM47XX_GPIO_KEY(7, KEY_UNKNOWN
),
181 static const struct gpio_keys_button
182 bcm47xx_buttons_dlink_dir330
[] __initconst
= {
183 BCM47XX_GPIO_KEY(3, KEY_RESTART
),
184 BCM47XX_GPIO_KEY(7, KEY_UNKNOWN
),
189 static const struct gpio_keys_button
190 bcm47xx_buttons_linksys_e1000v1
[] __initconst
= {
191 BCM47XX_GPIO_KEY(5, KEY_WPS_BUTTON
),
192 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
195 static const struct gpio_keys_button
196 bcm47xx_buttons_linksys_e1000v21
[] __initconst
= {
197 BCM47XX_GPIO_KEY(9, KEY_WPS_BUTTON
),
198 BCM47XX_GPIO_KEY(10, KEY_RESTART
),
201 static const struct gpio_keys_button
202 bcm47xx_buttons_linksys_e2000v1
[] __initconst
= {
203 BCM47XX_GPIO_KEY(5, KEY_WPS_BUTTON
),
204 BCM47XX_GPIO_KEY(8, KEY_RESTART
),
207 static const struct gpio_keys_button
208 bcm47xx_buttons_linksys_e3000v1
[] __initconst
= {
209 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
210 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
213 static const struct gpio_keys_button
214 bcm47xx_buttons_linksys_e3200v1
[] __initconst
= {
215 BCM47XX_GPIO_KEY(5, KEY_RESTART
),
216 BCM47XX_GPIO_KEY(8, KEY_WPS_BUTTON
),
219 static const struct gpio_keys_button
220 bcm47xx_buttons_linksys_e4200v1
[] __initconst
= {
221 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
222 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
225 static const struct gpio_keys_button
226 bcm47xx_buttons_linksys_wrt150nv1
[] __initconst
= {
227 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
228 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
231 static const struct gpio_keys_button
232 bcm47xx_buttons_linksys_wrt150nv11
[] __initconst
= {
233 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
234 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
237 static const struct gpio_keys_button
238 bcm47xx_buttons_linksys_wrt160nv1
[] __initconst
= {
239 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
240 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
243 static const struct gpio_keys_button
244 bcm47xx_buttons_linksys_wrt160nv3
[] __initconst
= {
245 BCM47XX_GPIO_KEY(5, KEY_WPS_BUTTON
),
246 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
249 static const struct gpio_keys_button
250 bcm47xx_buttons_linksys_wrt300nv11
[] __initconst
= {
251 BCM47XX_GPIO_KEY(4, KEY_UNKNOWN
),
252 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
255 static const struct gpio_keys_button
256 bcm47xx_buttons_linksys_wrt310nv1
[] __initconst
= {
257 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
258 BCM47XX_GPIO_KEY(8, KEY_UNKNOWN
),
261 static const struct gpio_keys_button
262 bcm47xx_buttons_linksys_wrt610nv1
[] __initconst
= {
263 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
264 BCM47XX_GPIO_KEY(8, KEY_WPS_BUTTON
),
267 static const struct gpio_keys_button
268 bcm47xx_buttons_linksys_wrt610nv2
[] __initconst
= {
269 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
270 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
275 static const struct gpio_keys_button
276 bcm47xx_buttons_motorola_we800g
[] __initconst
= {
277 BCM47XX_GPIO_KEY(0, KEY_RESTART
),
280 static const struct gpio_keys_button
281 bcm47xx_buttons_motorola_wr850gp
[] __initconst
= {
282 BCM47XX_GPIO_KEY(5, KEY_RESTART
),
285 static const struct gpio_keys_button
286 bcm47xx_buttons_motorola_wr850gv2v3
[] __initconst
= {
287 BCM47XX_GPIO_KEY(5, KEY_RESTART
),
292 static const struct gpio_keys_button
293 bcm47xx_buttons_netgear_wndr3400v1
[] __initconst
= {
294 BCM47XX_GPIO_KEY(4, KEY_RESTART
),
295 BCM47XX_GPIO_KEY(6, KEY_WPS_BUTTON
),
296 BCM47XX_GPIO_KEY(8, KEY_RFKILL
),
299 static const struct gpio_keys_button
300 bcm47xx_buttons_netgear_wndr3700v3
[] __initconst
= {
301 BCM47XX_GPIO_KEY(2, KEY_RFKILL
),
302 BCM47XX_GPIO_KEY(3, KEY_RESTART
),
303 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
306 static const struct gpio_keys_button
307 bcm47xx_buttons_netgear_wndr4500v1
[] __initconst
= {
308 BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON
),
309 BCM47XX_GPIO_KEY(5, KEY_RFKILL
),
310 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
313 static const struct gpio_keys_button
314 bcm47xx_buttons_netgear_wnr834bv2
[] __initconst
= {
315 BCM47XX_GPIO_KEY(6, KEY_RESTART
),
320 static const struct gpio_keys_button
321 bcm47xx_buttons_simpletech_simpleshare
[] __initconst
= {
322 BCM47XX_GPIO_KEY(0, KEY_RESTART
),
325 /**************************************************
327 **************************************************/
329 static struct gpio_keys_platform_data bcm47xx_button_pdata
;
331 static struct platform_device bcm47xx_buttons_gpio_keys
= {
334 .platform_data
= &bcm47xx_button_pdata
,
338 /* Copy data from __initconst */
339 static int __init
bcm47xx_buttons_copy(const struct gpio_keys_button
*buttons
,
342 size_t size
= nbuttons
* sizeof(*buttons
);
344 bcm47xx_button_pdata
.buttons
= kmalloc(size
, GFP_KERNEL
);
345 if (!bcm47xx_button_pdata
.buttons
)
347 memcpy(bcm47xx_button_pdata
.buttons
, buttons
, size
);
348 bcm47xx_button_pdata
.nbuttons
= nbuttons
;
353 #define bcm47xx_copy_bdata(dev_buttons) \
354 bcm47xx_buttons_copy(dev_buttons, ARRAY_SIZE(dev_buttons));
356 int __init
bcm47xx_buttons_register(void)
358 enum bcm47xx_board board
= bcm47xx_board_get();
362 case BCM47XX_BOARD_ASUS_RTN12
:
363 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_rtn12
);
365 case BCM47XX_BOARD_ASUS_RTN16
:
366 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_rtn16
);
368 case BCM47XX_BOARD_ASUS_RTN66U
:
369 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_rtn66u
);
371 case BCM47XX_BOARD_ASUS_WL300G
:
372 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl300g
);
374 case BCM47XX_BOARD_ASUS_WL320GE
:
375 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl320ge
);
377 case BCM47XX_BOARD_ASUS_WL330GE
:
378 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl330ge
);
380 case BCM47XX_BOARD_ASUS_WL500GD
:
381 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500gd
);
383 case BCM47XX_BOARD_ASUS_WL500GPV1
:
384 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500gpv1
);
386 case BCM47XX_BOARD_ASUS_WL500GPV2
:
387 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500gpv2
);
389 case BCM47XX_BOARD_ASUS_WL500W
:
390 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500w
);
392 case BCM47XX_BOARD_ASUS_WL520GC
:
393 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl520gc
);
395 case BCM47XX_BOARD_ASUS_WL520GU
:
396 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl520gu
);
398 case BCM47XX_BOARD_ASUS_WL700GE
:
399 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl700ge
);
401 case BCM47XX_BOARD_ASUS_WLHDD
:
402 err
= bcm47xx_copy_bdata(bcm47xx_buttons_asus_wlhdd
);
405 case BCM47XX_BOARD_BELKIN_F7D4301
:
406 err
= bcm47xx_copy_bdata(bcm47xx_buttons_belkin_f7d4301
);
409 case BCM47XX_BOARD_BUFFALO_WHR2_A54G54
:
410 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr2_a54g54
);
412 case BCM47XX_BOARD_BUFFALO_WHR_G125
:
413 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr_g125
);
415 case BCM47XX_BOARD_BUFFALO_WHR_G54S
:
416 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr_g54s
);
418 case BCM47XX_BOARD_BUFFALO_WHR_HP_G54
:
419 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr_hp_g54
);
421 case BCM47XX_BOARD_BUFFALO_WZR_G300N
:
422 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_wzr_g300n
);
424 case BCM47XX_BOARD_BUFFALO_WZR_RS_G54
:
425 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_wzr_rs_g54
);
427 case BCM47XX_BOARD_BUFFALO_WZR_RS_G54HP
:
428 err
= bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_wzr_rs_g54hp
);
431 case BCM47XX_BOARD_DELL_TM2300
:
432 err
= bcm47xx_copy_bdata(bcm47xx_buttons_dell_tm2300
);
435 case BCM47XX_BOARD_DLINK_DIR130
:
436 err
= bcm47xx_copy_bdata(bcm47xx_buttons_dlink_dir130
);
438 case BCM47XX_BOARD_DLINK_DIR330
:
439 err
= bcm47xx_copy_bdata(bcm47xx_buttons_dlink_dir330
);
442 case BCM47XX_BOARD_HUAWEI_E970
:
443 err
= bcm47xx_copy_bdata(bcm47xx_buttons_huawei_e970
);
446 case BCM47XX_BOARD_LINKSYS_E1000V1
:
447 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e1000v1
);
449 case BCM47XX_BOARD_LINKSYS_E1000V21
:
450 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e1000v21
);
452 case BCM47XX_BOARD_LINKSYS_E2000V1
:
453 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e2000v1
);
455 case BCM47XX_BOARD_LINKSYS_E3000V1
:
456 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e3000v1
);
458 case BCM47XX_BOARD_LINKSYS_E3200V1
:
459 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e3200v1
);
461 case BCM47XX_BOARD_LINKSYS_E4200V1
:
462 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e4200v1
);
464 case BCM47XX_BOARD_LINKSYS_WRT150NV1
:
465 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt150nv1
);
467 case BCM47XX_BOARD_LINKSYS_WRT150NV11
:
468 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt150nv11
);
470 case BCM47XX_BOARD_LINKSYS_WRT160NV1
:
471 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt160nv1
);
473 case BCM47XX_BOARD_LINKSYS_WRT160NV3
:
474 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt160nv3
);
476 case BCM47XX_BOARD_LINKSYS_WRT300NV11
:
477 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt300nv11
);
479 case BCM47XX_BOARD_LINKSYS_WRT310NV1
:
480 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt310nv1
);
482 case BCM47XX_BOARD_LINKSYS_WRT610NV1
:
483 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt610nv1
);
485 case BCM47XX_BOARD_LINKSYS_WRT610NV2
:
486 err
= bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt610nv2
);
489 case BCM47XX_BOARD_MOTOROLA_WE800G
:
490 err
= bcm47xx_copy_bdata(bcm47xx_buttons_motorola_we800g
);
492 case BCM47XX_BOARD_MOTOROLA_WR850GP
:
493 err
= bcm47xx_copy_bdata(bcm47xx_buttons_motorola_wr850gp
);
495 case BCM47XX_BOARD_MOTOROLA_WR850GV2V3
:
496 err
= bcm47xx_copy_bdata(bcm47xx_buttons_motorola_wr850gv2v3
);
499 case BCM47XX_BOARD_NETGEAR_WNDR3400V1
:
500 err
= bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wndr3400v1
);
502 case BCM47XX_BOARD_NETGEAR_WNDR3700V3
:
503 err
= bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wndr3700v3
);
505 case BCM47XX_BOARD_NETGEAR_WNDR4500V1
:
506 err
= bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wndr4500v1
);
508 case BCM47XX_BOARD_NETGEAR_WNR834BV2
:
509 err
= bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wnr834bv2
);
512 case BCM47XX_BOARD_SIMPLETECH_SIMPLESHARE
:
513 err
= bcm47xx_copy_bdata(bcm47xx_buttons_simpletech_simpleshare
);
517 pr_debug("No buttons configuration found for this device\n");
524 err
= platform_device_register(&bcm47xx_buttons_gpio_keys
);
526 pr_err("Failed to register platform device: %d\n", err
);