xref: /openbmc/linux/arch/mips/bcm47xx/buttons.c (revision 8c0b9ee8)
1 #include "bcm47xx_private.h"
2 
3 #include <linux/input.h>
4 #include <linux/gpio_keys.h>
5 #include <linux/interrupt.h>
6 #include <bcm47xx_board.h>
7 #include <bcm47xx.h>
8 
9 /**************************************************
10  * Database
11  **************************************************/
12 
13 #define BCM47XX_GPIO_KEY(_gpio, _code)					\
14 	{								\
15 		.code		= _code,				\
16 		.gpio		= _gpio,				\
17 		.active_low	= 1,					\
18 	}
19 
20 /* Asus */
21 
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 */
29 };
30 
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),
35 };
36 
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),
41 };
42 
43 static const struct gpio_keys_button
44 bcm47xx_buttons_asus_wl300g[] __initconst = {
45 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
46 };
47 
48 static const struct gpio_keys_button
49 bcm47xx_buttons_asus_wl320ge[] __initconst = {
50 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
51 };
52 
53 static const struct gpio_keys_button
54 bcm47xx_buttons_asus_wl330ge[] __initconst = {
55 	BCM47XX_GPIO_KEY(2, KEY_RESTART),
56 };
57 
58 static const struct gpio_keys_button
59 bcm47xx_buttons_asus_wl500g[] __initconst = {
60 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
61 };
62 
63 static const struct gpio_keys_button
64 bcm47xx_buttons_asus_wl500gd[] __initconst = {
65 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
66 };
67 
68 static const struct gpio_keys_button
69 bcm47xx_buttons_asus_wl500gpv1[] __initconst = {
70 	BCM47XX_GPIO_KEY(0, KEY_RESTART),
71 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
72 };
73 
74 static const struct gpio_keys_button
75 bcm47xx_buttons_asus_wl500gpv2[] __initconst = {
76 	BCM47XX_GPIO_KEY(2, KEY_RESTART),
77 	BCM47XX_GPIO_KEY(3, KEY_WPS_BUTTON),
78 };
79 
80 static const struct gpio_keys_button
81 bcm47xx_buttons_asus_wl500w[] __initconst = {
82 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
83 	BCM47XX_GPIO_KEY(7, KEY_WPS_BUTTON),
84 };
85 
86 static const struct gpio_keys_button
87 bcm47xx_buttons_asus_wl520gc[] __initconst = {
88 	BCM47XX_GPIO_KEY(2, KEY_RESTART),
89 	BCM47XX_GPIO_KEY(3, KEY_WPS_BUTTON),
90 };
91 
92 static const struct gpio_keys_button
93 bcm47xx_buttons_asus_wl520gu[] __initconst = {
94 	BCM47XX_GPIO_KEY(2, KEY_RESTART),
95 	BCM47XX_GPIO_KEY(3, KEY_WPS_BUTTON),
96 };
97 
98 static const struct gpio_keys_button
99 bcm47xx_buttons_asus_wl700ge[] __initconst = {
100 	BCM47XX_GPIO_KEY(0, KEY_POWER), /* Hard disk power switch */
101 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON), /* EZSetup */
102 	BCM47XX_GPIO_KEY(6, KEY_COPY), /* Copy data from USB to internal disk */
103 	BCM47XX_GPIO_KEY(7, KEY_RESTART), /* Hard reset */
104 };
105 
106 static const struct gpio_keys_button
107 bcm47xx_buttons_asus_wlhdd[] __initconst = {
108 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
109 };
110 
111 /* Huawei */
112 
113 static const struct gpio_keys_button
114 bcm47xx_buttons_huawei_e970[] __initconst = {
115 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
116 };
117 
118 /* Belkin */
119 
120 static const struct gpio_keys_button
121 bcm47xx_buttons_belkin_f7d4301[] __initconst = {
122 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
123 	BCM47XX_GPIO_KEY(8, KEY_WPS_BUTTON),
124 };
125 
126 /* Buffalo */
127 
128 static const struct gpio_keys_button
129 bcm47xx_buttons_buffalo_whr2_a54g54[] __initconst = {
130 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
131 };
132 
133 static const struct gpio_keys_button
134 bcm47xx_buttons_buffalo_whr_g125[] __initconst = {
135 	BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON),
136 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
137 	BCM47XX_GPIO_KEY(5, BTN_0), /* Router / AP mode swtich */
138 };
139 
140 static const struct gpio_keys_button
141 bcm47xx_buttons_buffalo_whr_g54s[] __initconst = {
142 	BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON),
143 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
144 	BCM47XX_GPIO_KEY(5, BTN_0), /* Router / AP mode swtich */
145 };
146 
147 static const struct gpio_keys_button
148 bcm47xx_buttons_buffalo_whr_hp_g54[] __initconst = {
149 	BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON),
150 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
151 	BCM47XX_GPIO_KEY(5, BTN_0), /* Router / AP mode swtich */
152 };
153 
154 static const struct gpio_keys_button
155 bcm47xx_buttons_buffalo_wzr_g300n[] __initconst = {
156 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
157 };
158 
159 static const struct gpio_keys_button
160 bcm47xx_buttons_buffalo_wzr_rs_g54[] __initconst = {
161 	BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON),
162 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
163 };
164 
165 static const struct gpio_keys_button
166 bcm47xx_buttons_buffalo_wzr_rs_g54hp[] __initconst = {
167 	BCM47XX_GPIO_KEY(0, KEY_WPS_BUTTON),
168 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
169 };
170 
171 /* Dell */
172 
173 static const struct gpio_keys_button
174 bcm47xx_buttons_dell_tm2300[] __initconst = {
175 	BCM47XX_GPIO_KEY(0, KEY_RESTART),
176 };
177 
178 /* D-Link */
179 
180 static const struct gpio_keys_button
181 bcm47xx_buttons_dlink_dir130[] __initconst = {
182 	BCM47XX_GPIO_KEY(3, KEY_RESTART),
183 	BCM47XX_GPIO_KEY(7, KEY_UNKNOWN),
184 };
185 
186 static const struct gpio_keys_button
187 bcm47xx_buttons_dlink_dir330[] __initconst = {
188 	BCM47XX_GPIO_KEY(3, KEY_RESTART),
189 	BCM47XX_GPIO_KEY(7, KEY_UNKNOWN),
190 };
191 
192 /* Linksys */
193 
194 static const struct gpio_keys_button
195 bcm47xx_buttons_linksys_e1000v1[] __initconst = {
196 	BCM47XX_GPIO_KEY(5, KEY_WPS_BUTTON),
197 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
198 };
199 
200 static const struct gpio_keys_button
201 bcm47xx_buttons_linksys_e1000v21[] __initconst = {
202 	BCM47XX_GPIO_KEY(9, KEY_WPS_BUTTON),
203 	BCM47XX_GPIO_KEY(10, KEY_RESTART),
204 };
205 
206 static const struct gpio_keys_button
207 bcm47xx_buttons_linksys_e2000v1[] __initconst = {
208 	BCM47XX_GPIO_KEY(5, KEY_WPS_BUTTON),
209 	BCM47XX_GPIO_KEY(8, KEY_RESTART),
210 };
211 
212 static const struct gpio_keys_button
213 bcm47xx_buttons_linksys_e3000v1[] __initconst = {
214 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
215 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
216 };
217 
218 static const struct gpio_keys_button
219 bcm47xx_buttons_linksys_e3200v1[] __initconst = {
220 	BCM47XX_GPIO_KEY(5, KEY_RESTART),
221 	BCM47XX_GPIO_KEY(8, KEY_WPS_BUTTON),
222 };
223 
224 static const struct gpio_keys_button
225 bcm47xx_buttons_linksys_e4200v1[] __initconst = {
226 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
227 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
228 };
229 
230 static const struct gpio_keys_button
231 bcm47xx_buttons_linksys_wrt150nv1[] __initconst = {
232 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
233 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
234 };
235 
236 static const struct gpio_keys_button
237 bcm47xx_buttons_linksys_wrt150nv11[] __initconst = {
238 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
239 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
240 };
241 
242 static const struct gpio_keys_button
243 bcm47xx_buttons_linksys_wrt160nv1[] __initconst = {
244 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
245 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
246 };
247 
248 static const struct gpio_keys_button
249 bcm47xx_buttons_linksys_wrt160nv3[] __initconst = {
250 	BCM47XX_GPIO_KEY(5, KEY_WPS_BUTTON),
251 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
252 };
253 
254 static const struct gpio_keys_button
255 bcm47xx_buttons_linksys_wrt300nv11[] __initconst = {
256 	BCM47XX_GPIO_KEY(4, KEY_UNKNOWN),
257 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
258 };
259 
260 static const struct gpio_keys_button
261 bcm47xx_buttons_linksys_wrt310nv1[] __initconst = {
262 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
263 	BCM47XX_GPIO_KEY(8, KEY_UNKNOWN),
264 };
265 
266 static const struct gpio_keys_button
267 bcm47xx_buttons_linksys_wrt54g3gv2[] __initconst = {
268 	BCM47XX_GPIO_KEY(5, KEY_WIMAX),
269 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
270 };
271 
272 static const struct gpio_keys_button
273 bcm47xx_buttons_linksys_wrt54g_generic[] __initconst = {
274 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
275 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
276 };
277 
278 static const struct gpio_keys_button
279 bcm47xx_buttons_linksys_wrt610nv1[] __initconst = {
280 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
281 	BCM47XX_GPIO_KEY(8, KEY_WPS_BUTTON),
282 };
283 
284 static const struct gpio_keys_button
285 bcm47xx_buttons_linksys_wrt610nv2[] __initconst = {
286 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
287 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
288 };
289 
290 static const struct gpio_keys_button
291 bcm47xx_buttons_linksys_wrtsl54gs[] __initconst = {
292 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
293 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
294 };
295 
296 /* Microsoft */
297 
298 static const struct gpio_keys_button
299 bcm47xx_buttons_microsoft_nm700[] __initconst = {
300 	BCM47XX_GPIO_KEY(7, KEY_RESTART),
301 };
302 
303 /* Motorola */
304 
305 static const struct gpio_keys_button
306 bcm47xx_buttons_motorola_we800g[] __initconst = {
307 	BCM47XX_GPIO_KEY(0, KEY_RESTART),
308 };
309 
310 static const struct gpio_keys_button
311 bcm47xx_buttons_motorola_wr850gp[] __initconst = {
312 	BCM47XX_GPIO_KEY(5, KEY_RESTART),
313 };
314 
315 static const struct gpio_keys_button
316 bcm47xx_buttons_motorola_wr850gv2v3[] __initconst = {
317 	BCM47XX_GPIO_KEY(5, KEY_RESTART),
318 };
319 
320 /* Netgear */
321 
322 static const struct gpio_keys_button
323 bcm47xx_buttons_netgear_wndr3400v1[] __initconst = {
324 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
325 	BCM47XX_GPIO_KEY(6, KEY_WPS_BUTTON),
326 	BCM47XX_GPIO_KEY(8, KEY_RFKILL),
327 };
328 
329 static const struct gpio_keys_button
330 bcm47xx_buttons_netgear_wndr3700v3[] __initconst = {
331 	BCM47XX_GPIO_KEY(2, KEY_RFKILL),
332 	BCM47XX_GPIO_KEY(3, KEY_RESTART),
333 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
334 };
335 
336 static const struct gpio_keys_button
337 bcm47xx_buttons_netgear_wndr4500v1[] __initconst = {
338 	BCM47XX_GPIO_KEY(4, KEY_WPS_BUTTON),
339 	BCM47XX_GPIO_KEY(5, KEY_RFKILL),
340 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
341 };
342 
343 static const struct gpio_keys_button
344 bcm47xx_buttons_netgear_wnr3500lv1[] __initconst = {
345 	BCM47XX_GPIO_KEY(4, KEY_RESTART),
346 	BCM47XX_GPIO_KEY(6, KEY_WPS_BUTTON),
347 };
348 
349 static const struct gpio_keys_button
350 bcm47xx_buttons_netgear_wnr834bv2[] __initconst = {
351 	BCM47XX_GPIO_KEY(6, KEY_RESTART),
352 };
353 
354 /* SimpleTech */
355 
356 static const struct gpio_keys_button
357 bcm47xx_buttons_simpletech_simpleshare[] __initconst = {
358 	BCM47XX_GPIO_KEY(0, KEY_RESTART),
359 };
360 
361 /**************************************************
362  * Init
363  **************************************************/
364 
365 static struct gpio_keys_platform_data bcm47xx_button_pdata;
366 
367 static struct platform_device bcm47xx_buttons_gpio_keys = {
368 	.name = "gpio-keys",
369 	.dev = {
370 		.platform_data = &bcm47xx_button_pdata,
371 	}
372 };
373 
374 /* Copy data from __initconst */
375 static int __init bcm47xx_buttons_copy(const struct gpio_keys_button *buttons,
376 				       size_t nbuttons)
377 {
378 	size_t size = nbuttons * sizeof(*buttons);
379 
380 	bcm47xx_button_pdata.buttons = kmalloc(size, GFP_KERNEL);
381 	if (!bcm47xx_button_pdata.buttons)
382 		return -ENOMEM;
383 	memcpy(bcm47xx_button_pdata.buttons, buttons, size);
384 	bcm47xx_button_pdata.nbuttons = nbuttons;
385 
386 	return 0;
387 }
388 
389 #define bcm47xx_copy_bdata(dev_buttons)					\
390 	bcm47xx_buttons_copy(dev_buttons, ARRAY_SIZE(dev_buttons));
391 
392 int __init bcm47xx_buttons_register(void)
393 {
394 	enum bcm47xx_board board = bcm47xx_board_get();
395 	int err;
396 
397 	switch (board) {
398 	case BCM47XX_BOARD_ASUS_RTN12:
399 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_rtn12);
400 		break;
401 	case BCM47XX_BOARD_ASUS_RTN16:
402 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_rtn16);
403 		break;
404 	case BCM47XX_BOARD_ASUS_RTN66U:
405 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_rtn66u);
406 		break;
407 	case BCM47XX_BOARD_ASUS_WL300G:
408 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl300g);
409 		break;
410 	case BCM47XX_BOARD_ASUS_WL320GE:
411 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl320ge);
412 		break;
413 	case BCM47XX_BOARD_ASUS_WL330GE:
414 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl330ge);
415 		break;
416 	case BCM47XX_BOARD_ASUS_WL500G:
417 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500g);
418 		break;
419 	case BCM47XX_BOARD_ASUS_WL500GD:
420 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500gd);
421 		break;
422 	case BCM47XX_BOARD_ASUS_WL500GPV1:
423 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500gpv1);
424 		break;
425 	case BCM47XX_BOARD_ASUS_WL500GPV2:
426 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500gpv2);
427 		break;
428 	case BCM47XX_BOARD_ASUS_WL500W:
429 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl500w);
430 		break;
431 	case BCM47XX_BOARD_ASUS_WL520GC:
432 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl520gc);
433 		break;
434 	case BCM47XX_BOARD_ASUS_WL520GU:
435 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl520gu);
436 		break;
437 	case BCM47XX_BOARD_ASUS_WL700GE:
438 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wl700ge);
439 		break;
440 	case BCM47XX_BOARD_ASUS_WLHDD:
441 		err = bcm47xx_copy_bdata(bcm47xx_buttons_asus_wlhdd);
442 		break;
443 
444 	case BCM47XX_BOARD_BELKIN_F7D3301:
445 	case BCM47XX_BOARD_BELKIN_F7D3302:
446 	case BCM47XX_BOARD_BELKIN_F7D4301:
447 	case BCM47XX_BOARD_BELKIN_F7D4302:
448 	case BCM47XX_BOARD_BELKIN_F7D4401:
449 		err = bcm47xx_copy_bdata(bcm47xx_buttons_belkin_f7d4301);
450 		break;
451 
452 	case BCM47XX_BOARD_BUFFALO_WHR2_A54G54:
453 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr2_a54g54);
454 		break;
455 	case BCM47XX_BOARD_BUFFALO_WHR_G125:
456 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr_g125);
457 		break;
458 	case BCM47XX_BOARD_BUFFALO_WHR_G54S:
459 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr_g54s);
460 		break;
461 	case BCM47XX_BOARD_BUFFALO_WHR_HP_G54:
462 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_whr_hp_g54);
463 		break;
464 	case BCM47XX_BOARD_BUFFALO_WZR_G300N:
465 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_wzr_g300n);
466 		break;
467 	case BCM47XX_BOARD_BUFFALO_WZR_RS_G54:
468 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_wzr_rs_g54);
469 		break;
470 	case BCM47XX_BOARD_BUFFALO_WZR_RS_G54HP:
471 		err = bcm47xx_copy_bdata(bcm47xx_buttons_buffalo_wzr_rs_g54hp);
472 		break;
473 
474 	case BCM47XX_BOARD_DELL_TM2300:
475 		err = bcm47xx_copy_bdata(bcm47xx_buttons_dell_tm2300);
476 		break;
477 
478 	case BCM47XX_BOARD_DLINK_DIR130:
479 		err = bcm47xx_copy_bdata(bcm47xx_buttons_dlink_dir130);
480 		break;
481 	case BCM47XX_BOARD_DLINK_DIR330:
482 		err = bcm47xx_copy_bdata(bcm47xx_buttons_dlink_dir330);
483 		break;
484 
485 	case BCM47XX_BOARD_HUAWEI_E970:
486 		err = bcm47xx_copy_bdata(bcm47xx_buttons_huawei_e970);
487 		break;
488 
489 	case BCM47XX_BOARD_LINKSYS_E1000V1:
490 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e1000v1);
491 		break;
492 	case BCM47XX_BOARD_LINKSYS_E1000V21:
493 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e1000v21);
494 		break;
495 	case BCM47XX_BOARD_LINKSYS_E2000V1:
496 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e2000v1);
497 		break;
498 	case BCM47XX_BOARD_LINKSYS_E3000V1:
499 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e3000v1);
500 		break;
501 	case BCM47XX_BOARD_LINKSYS_E3200V1:
502 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e3200v1);
503 		break;
504 	case BCM47XX_BOARD_LINKSYS_E4200V1:
505 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_e4200v1);
506 		break;
507 	case BCM47XX_BOARD_LINKSYS_WRT150NV1:
508 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt150nv1);
509 		break;
510 	case BCM47XX_BOARD_LINKSYS_WRT150NV11:
511 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt150nv11);
512 		break;
513 	case BCM47XX_BOARD_LINKSYS_WRT160NV1:
514 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt160nv1);
515 		break;
516 	case BCM47XX_BOARD_LINKSYS_WRT160NV3:
517 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt160nv3);
518 		break;
519 	case BCM47XX_BOARD_LINKSYS_WRT300NV11:
520 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt300nv11);
521 		break;
522 	case BCM47XX_BOARD_LINKSYS_WRT310NV1:
523 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt310nv1);
524 		break;
525 	case BCM47XX_BOARD_LINKSYS_WRT54G3GV2:
526 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt54g3gv2);
527 		break;
528 	case BCM47XX_BOARD_LINKSYS_WRT54G_TYPE_0101:
529 	case BCM47XX_BOARD_LINKSYS_WRT54G_TYPE_0467:
530 	case BCM47XX_BOARD_LINKSYS_WRT54G_TYPE_0708:
531 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt54g_generic);
532 		break;
533 	case BCM47XX_BOARD_LINKSYS_WRT610NV1:
534 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt610nv1);
535 		break;
536 	case BCM47XX_BOARD_LINKSYS_WRT610NV2:
537 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrt610nv2);
538 		break;
539 	case BCM47XX_BOARD_LINKSYS_WRTSL54GS:
540 		err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrtsl54gs);
541 		break;
542 
543 	case BCM47XX_BOARD_MICROSOFT_MN700:
544 		err = bcm47xx_copy_bdata(bcm47xx_buttons_microsoft_nm700);
545 		break;
546 
547 	case BCM47XX_BOARD_MOTOROLA_WE800G:
548 		err = bcm47xx_copy_bdata(bcm47xx_buttons_motorola_we800g);
549 		break;
550 	case BCM47XX_BOARD_MOTOROLA_WR850GP:
551 		err = bcm47xx_copy_bdata(bcm47xx_buttons_motorola_wr850gp);
552 		break;
553 	case BCM47XX_BOARD_MOTOROLA_WR850GV2V3:
554 		err = bcm47xx_copy_bdata(bcm47xx_buttons_motorola_wr850gv2v3);
555 		break;
556 
557 	case BCM47XX_BOARD_NETGEAR_WNDR3400V1:
558 		err = bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wndr3400v1);
559 		break;
560 	case BCM47XX_BOARD_NETGEAR_WNDR3700V3:
561 		err = bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wndr3700v3);
562 		break;
563 	case BCM47XX_BOARD_NETGEAR_WNDR4500V1:
564 		err = bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wndr4500v1);
565 		break;
566 	case BCM47XX_BOARD_NETGEAR_WNR3500L:
567 		err = bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wnr3500lv1);
568 		break;
569 	case BCM47XX_BOARD_NETGEAR_WNR834BV2:
570 		err = bcm47xx_copy_bdata(bcm47xx_buttons_netgear_wnr834bv2);
571 		break;
572 
573 	case BCM47XX_BOARD_SIMPLETECH_SIMPLESHARE:
574 		err = bcm47xx_copy_bdata(bcm47xx_buttons_simpletech_simpleshare);
575 		break;
576 
577 	default:
578 		pr_debug("No buttons configuration found for this device\n");
579 		return -ENOTSUPP;
580 	}
581 
582 	if (err)
583 		return -ENOMEM;
584 
585 	err = platform_device_register(&bcm47xx_buttons_gpio_keys);
586 	if (err) {
587 		pr_err("Failed to register platform device: %d\n", err);
588 		return err;
589 	}
590 
591 	return 0;
592 }
593