mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-12-25 03:13:20 +02:00
[brcm63xx] fix gpio_button device register
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@21252 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
eb30c3b7ce
commit
7b8a4fb8e0
@ -43,7 +43,7 @@
|
||||
};
|
||||
|
||||
static struct board_info __initdata board_FAST2404 = {
|
||||
@@ -771,6 +793,16 @@ static struct platform_device bcm63xx_gp
|
||||
@@ -771,12 +793,23 @@ static struct platform_device bcm63xx_gp
|
||||
.dev.platform_data = &bcm63xx_led_data,
|
||||
};
|
||||
|
||||
@ -60,12 +60,23 @@
|
||||
/*
|
||||
* third stage init callback, register all board devices.
|
||||
*/
|
||||
@@ -826,6 +858,13 @@ int __init board_register_devices(void)
|
||||
int __init board_register_devices(void)
|
||||
{
|
||||
u32 val;
|
||||
+ int button_count = 0;
|
||||
|
||||
if (board.has_pccard)
|
||||
bcm63xx_pcmcia_register();
|
||||
@@ -826,6 +859,17 @@ int __init board_register_devices(void)
|
||||
|
||||
platform_device_register(&bcm63xx_gpio_leds);
|
||||
|
||||
+ if (board.reset_buttons) {
|
||||
+ bcm63xx_gpio_buttons_data.nbuttons = ARRAY_SIZE(board.reset_buttons);
|
||||
+ /* count number of BUTTONs defined by this device */
|
||||
+ while (button_count < ARRAY_SIZE(board.reset_buttons) && board.reset_buttons[button_count].desc)
|
||||
+ button_count++;
|
||||
+
|
||||
+ if (button_count) {
|
||||
+ bcm63xx_gpio_buttons_data.nbuttons = button_count;
|
||||
+ bcm63xx_gpio_buttons_data.buttons = board.reset_buttons;
|
||||
+
|
||||
+ platform_device_register(&bcm63xx_gpio_buttons_device);
|
||||
|
@ -53,10 +53,10 @@
|
||||
{
|
||||
u32 val;
|
||||
+ int led_count = 0;
|
||||
int button_count = 0;
|
||||
|
||||
if (board.has_pccard)
|
||||
bcm63xx_pcmcia_register();
|
||||
@@ -901,7 +917,11 @@ int __init board_register_devices(void)
|
||||
@@ -902,7 +918,11 @@ int __init board_register_devices(void)
|
||||
|
||||
platform_device_register_simple("GPIODEV", 0, &gpiodev_resource, 1);
|
||||
|
||||
|
@ -43,7 +43,7 @@
|
||||
};
|
||||
|
||||
static struct board_info __initdata board_FAST2404 = {
|
||||
@@ -770,6 +792,16 @@ static struct platform_device bcm63xx_gp
|
||||
@@ -770,12 +792,23 @@ static struct platform_device bcm63xx_gp
|
||||
.dev.platform_data = &bcm63xx_led_data,
|
||||
};
|
||||
|
||||
@ -60,12 +60,23 @@
|
||||
/*
|
||||
* third stage init callback, register all board devices.
|
||||
*/
|
||||
@@ -825,6 +857,13 @@ int __init board_register_devices(void)
|
||||
int __init board_register_devices(void)
|
||||
{
|
||||
u32 val;
|
||||
+ int button_count = 0;
|
||||
|
||||
if (board.has_pccard)
|
||||
bcm63xx_pcmcia_register();
|
||||
@@ -825,6 +858,17 @@ int __init board_register_devices(void)
|
||||
|
||||
platform_device_register(&bcm63xx_gpio_leds);
|
||||
|
||||
+ if (board.reset_buttons) {
|
||||
+ bcm63xx_gpio_buttons_data.nbuttons = ARRAY_SIZE(board.reset_buttons);
|
||||
+ /* count number of BUTTONs defined by this device */
|
||||
+ while (button_count < ARRAY_SIZE(board.reset_buttons) && board.reset_buttons[button_count].desc)
|
||||
+ button_count++;
|
||||
+
|
||||
+ if (button_count) {
|
||||
+ bcm63xx_gpio_buttons_data.nbuttons = button_count;
|
||||
+ bcm63xx_gpio_buttons_data.buttons = board.reset_buttons;
|
||||
+
|
||||
+ platform_device_register(&bcm63xx_gpio_buttons_device);
|
||||
|
@ -53,10 +53,10 @@
|
||||
{
|
||||
u32 val;
|
||||
+ int led_count = 0;
|
||||
int button_count = 0;
|
||||
|
||||
if (board.has_pccard)
|
||||
bcm63xx_pcmcia_register();
|
||||
@@ -900,7 +916,11 @@ int __init board_register_devices(void)
|
||||
@@ -901,7 +917,11 @@ int __init board_register_devices(void)
|
||||
|
||||
platform_device_register_simple("GPIODEV", 0, &gpiodev_resource, 1);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user