From 1a83d4d30ff700d0e77252bbfd6bf8bdf11fac27 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= Date: Tue, 24 Jan 2017 20:22:14 +0100 Subject: brcm47xx: backport arch patch with Luxul devices support MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Rafał Miłecki --- ...BCM47XX-Add-Luxul-devices-to-the-database.patch | 246 +++++++++++++++++++++ 1 file changed, 246 insertions(+) create mode 100644 target/linux/brcm47xx/patches-4.4/030-MIPS-BCM47XX-Add-Luxul-devices-to-the-database.patch (limited to 'target/linux/brcm47xx/patches-4.4/030-MIPS-BCM47XX-Add-Luxul-devices-to-the-database.patch') diff --git a/target/linux/brcm47xx/patches-4.4/030-MIPS-BCM47XX-Add-Luxul-devices-to-the-database.patch b/target/linux/brcm47xx/patches-4.4/030-MIPS-BCM47XX-Add-Luxul-devices-to-the-database.patch new file mode 100644 index 0000000000..402d9360f4 --- /dev/null +++ b/target/linux/brcm47xx/patches-4.4/030-MIPS-BCM47XX-Add-Luxul-devices-to-the-database.patch @@ -0,0 +1,246 @@ +From 36b3b702c20e67b18070159dfba80d2084836928 Mon Sep 17 00:00:00 2001 +From: Dan Haab +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 +Cc: Hauke Mehrtens +Cc: Rafał Miłecki +Cc: linux-mips@linux-mips.org +Patchwork: https://patchwork.linux-mips.org/patch/15106/ +Signed-off-by: Ralf Baechle +--- + 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 +@@ -302,6 +302,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), + }; +@@ -561,6 +606,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, -- cgit v1.2.3