123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 |
- From 36b3b702c20e67b18070159dfba80d2084836928 Mon Sep 17 00:00:00 2001
- From: Dan Haab <dhaab@luxul.com>
- Date: Mon, 23 Jan 2017 12:50:38 -0700
- Subject: [PATCH] MIPS: BCM47XX: Add Luxul devices to the database
- MIME-Version: 1.0
- Content-Type: text/plain; charset=UTF-8
- Content-Transfer-Encoding: 8bit
- So far only Luxul XWR-1750 router was supported. This adds a set of
- other Luxul devices based on BCM47XX. It's a standard support for LEDs
- and buttons.
- Signed-off-by: Dan Haab <dhaab@luxul.com>
- Cc: Hauke Mehrtens <hauke@hauke-m.de>
- Cc: Rafał Miłecki <zajec5@gmail.com>
- Cc: linux-mips@linux-mips.org
- Patchwork: https://patchwork.linux-mips.org/patch/15106/
- Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
- ---
- arch/mips/bcm47xx/board.c | 9 +++
- arch/mips/bcm47xx/buttons.c | 72 +++++++++++++++++++
- arch/mips/bcm47xx/leds.c | 81 ++++++++++++++++++++++
- arch/mips/include/asm/mach-bcm47xx/bcm47xx_board.h | 9 +++
- 4 files changed, 171 insertions(+)
- --- a/arch/mips/bcm47xx/board.c
- +++ b/arch/mips/bcm47xx/board.c
- @@ -149,6 +149,15 @@ struct bcm47xx_board_type_list2 bcm47xx_
- /* board_id */
- static const
- struct bcm47xx_board_type_list1 bcm47xx_board_list_board_id[] __initconst = {
- + {{BCM47XX_BOARD_LUXUL_ABR_4400_V1, "Luxul ABR-4400 V1"}, "luxul_abr4400_v1"},
- + {{BCM47XX_BOARD_LUXUL_XAP_310_V1, "Luxul XAP-310 V1"}, "luxul_xap310_v1"},
- + {{BCM47XX_BOARD_LUXUL_XAP_1210_V1, "Luxul XAP-1210 V1"}, "luxul_xap1210_v1"},
- + {{BCM47XX_BOARD_LUXUL_XAP_1230_V1, "Luxul XAP-1230 V1"}, "luxul_xap1230_v1"},
- + {{BCM47XX_BOARD_LUXUL_XAP_1240_V1, "Luxul XAP-1240 V1"}, "luxul_xap1240_v1"},
- + {{BCM47XX_BOARD_LUXUL_XAP_1500_V1, "Luxul XAP-1500 V1"}, "luxul_xap1500_v1"},
- + {{BCM47XX_BOARD_LUXUL_XBR_4400_V1, "Luxul XBR-4400 V1"}, "luxul_xbr4400_v1"},
- + {{BCM47XX_BOARD_LUXUL_XVW_P30_V1, "Luxul XVW-P30 V1"}, "luxul_xvwp30_v1"},
- + {{BCM47XX_BOARD_LUXUL_XWR_600_V1, "Luxul XWR-600 V1"}, "luxul_xwr600_v1"},
- {{BCM47XX_BOARD_LUXUL_XWR_1750_V1, "Luxul XWR-1750 V1"}, "luxul_xwr1750_v1"},
- {{BCM47XX_BOARD_NETGEAR_WGR614V8, "Netgear WGR614 V8"}, "U12H072T00_NETGEAR"},
- {{BCM47XX_BOARD_NETGEAR_WGR614V9, "Netgear WGR614 V9"}, "U12H094T00_NETGEAR"},
- --- a/arch/mips/bcm47xx/buttons.c
- +++ b/arch/mips/bcm47xx/buttons.c
- @@ -308,6 +308,51 @@ bcm47xx_buttons_linksys_wrtsl54gs[] __in
- /* Luxul */
-
- static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_abr_4400_v1[] = {
- + BCM47XX_GPIO_KEY(14, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xap_310_v1[] = {
- + BCM47XX_GPIO_KEY(20, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xap_1210_v1[] = {
- + BCM47XX_GPIO_KEY(8, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xap_1230_v1[] = {
- + BCM47XX_GPIO_KEY(8, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xap_1240_v1[] = {
- + BCM47XX_GPIO_KEY(8, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xap_1500_v1[] = {
- + BCM47XX_GPIO_KEY(14, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xbr_4400_v1[] = {
- + BCM47XX_GPIO_KEY(14, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xvw_p30_v1[] = {
- + BCM47XX_GPIO_KEY(20, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- +bcm47xx_buttons_luxul_xwr_600_v1[] = {
- + BCM47XX_GPIO_KEY(8, KEY_RESTART),
- +};
- +
- +static const struct gpio_keys_button
- bcm47xx_buttons_luxul_xwr_1750_v1[] = {
- BCM47XX_GPIO_KEY(14, BTN_TASK),
- };
- @@ -567,6 +612,33 @@ int __init bcm47xx_buttons_register(void
- err = bcm47xx_copy_bdata(bcm47xx_buttons_linksys_wrtsl54gs);
- break;
-
- + case BCM47XX_BOARD_LUXUL_ABR_4400_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_abr_4400_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_310_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xap_310_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1210_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xap_1210_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1230_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xap_1230_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1240_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xap_1240_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1500_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xap_1500_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XBR_4400_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xbr_4400_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XVW_P30_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xvw_p30_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XWR_600_V1:
- + err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xwr_600_v1);
- + break;
- case BCM47XX_BOARD_LUXUL_XWR_1750_V1:
- err = bcm47xx_copy_bdata(bcm47xx_buttons_luxul_xwr_1750_v1);
- break;
- --- a/arch/mips/bcm47xx/leds.c
- +++ b/arch/mips/bcm47xx/leds.c
- @@ -373,6 +373,60 @@ bcm47xx_leds_linksys_wrtsl54gs[] __initc
- /* Luxul */
-
- static const struct gpio_led
- +bcm47xx_leds_luxul_abr_4400_v1[] __initconst = {
- + BCM47XX_GPIO_LED(12, "green", "usb", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED_TRIGGER(15, "green", "status", 0, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xap_310_v1[] __initconst = {
- + BCM47XX_GPIO_LED_TRIGGER(6, "green", "status", 1, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xap_1210_v1[] __initconst = {
- + BCM47XX_GPIO_LED_TRIGGER(6, "green", "status", 1, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xap_1230_v1[] __initconst = {
- + BCM47XX_GPIO_LED(3, "blue", "2ghz", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED(4, "green", "bridge", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED_TRIGGER(6, "green", "status", 1, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xap_1240_v1[] __initconst = {
- + BCM47XX_GPIO_LED(3, "blue", "2ghz", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED(4, "green", "bridge", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED_TRIGGER(6, "green", "status", 1, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xap_1500_v1[] __initconst = {
- + BCM47XX_GPIO_LED_TRIGGER(13, "green", "status", 1, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xbr_4400_v1[] __initconst = {
- + BCM47XX_GPIO_LED(12, "green", "usb", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED_TRIGGER(15, "green", "status", 0, "timer"),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xvw_p30_v1[] __initconst = {
- + BCM47XX_GPIO_LED_TRIGGER(0, "blue", "status", 1, "timer"),
- + BCM47XX_GPIO_LED(1, "green", "link", 1, LEDS_GPIO_DEFSTATE_OFF),
- +};
- +
- +static const struct gpio_led
- +bcm47xx_leds_luxul_xwr_600_v1[] __initconst = {
- + BCM47XX_GPIO_LED(3, "green", "wps", 0, LEDS_GPIO_DEFSTATE_OFF),
- + BCM47XX_GPIO_LED_TRIGGER(6, "green", "status", 1, "timer"),
- + BCM47XX_GPIO_LED(9, "green", "usb", 0, LEDS_GPIO_DEFSTATE_OFF),
- +};
- +
- +static const struct gpio_led
- bcm47xx_leds_luxul_xwr_1750_v1[] __initconst = {
- BCM47XX_GPIO_LED(5, "green", "5ghz", 0, LEDS_GPIO_DEFSTATE_OFF),
- BCM47XX_GPIO_LED(12, "green", "usb", 0, LEDS_GPIO_DEFSTATE_OFF),
- @@ -633,6 +687,33 @@ void __init bcm47xx_leds_register(void)
- bcm47xx_set_pdata(bcm47xx_leds_linksys_wrtsl54gs);
- break;
-
- + case BCM47XX_BOARD_LUXUL_ABR_4400_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_abr_4400_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_310_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xap_310_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1210_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xap_1210_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1230_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xap_1230_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1240_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xap_1240_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XAP_1500_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xap_1500_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XBR_4400_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xbr_4400_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XVW_P30_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xvw_p30_v1);
- + break;
- + case BCM47XX_BOARD_LUXUL_XWR_600_V1:
- + bcm47xx_set_pdata(bcm47xx_leds_luxul_xwr_600_v1);
- + break;
- case BCM47XX_BOARD_LUXUL_XWR_1750_V1:
- bcm47xx_set_pdata(bcm47xx_leds_luxul_xwr_1750_v1);
- break;
- --- a/arch/mips/include/asm/mach-bcm47xx/bcm47xx_board.h
- +++ b/arch/mips/include/asm/mach-bcm47xx/bcm47xx_board.h
- @@ -80,6 +80,15 @@ enum bcm47xx_board {
- BCM47XX_BOARD_LINKSYS_WRT610NV2,
- BCM47XX_BOARD_LINKSYS_WRTSL54GS,
-
- + BCM47XX_BOARD_LUXUL_ABR_4400_V1,
- + BCM47XX_BOARD_LUXUL_XAP_310_V1,
- + BCM47XX_BOARD_LUXUL_XAP_1210_V1,
- + BCM47XX_BOARD_LUXUL_XAP_1230_V1,
- + BCM47XX_BOARD_LUXUL_XAP_1240_V1,
- + BCM47XX_BOARD_LUXUL_XAP_1500_V1,
- + BCM47XX_BOARD_LUXUL_XBR_4400_V1,
- + BCM47XX_BOARD_LUXUL_XVW_P30_V1,
- + BCM47XX_BOARD_LUXUL_XWR_600_V1,
- BCM47XX_BOARD_LUXUL_XWR_1750_V1,
-
- BCM47XX_BOARD_MICROSOFT_MN700,
|