openwrt/target/linux/brcm63xx/patches-3.14/534-board_hw556.patch
Jonas Gorski 52b0935efe brcm63xx: use dtb board detection for HW556
This requires individual images for each board version for now.
Linux partition was shrunk to ensure writing thewrong image won't
erase wifi calibration data.

Signed-off-by: Jonas Gorski <jogo@openwrt.org>

SVN-Revision: 42126
2014-08-11 11:37:14 +00:00

532 lines
10 KiB
Diff

--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
@@ -12,6 +12,7 @@
#include <linux/string.h>
#include <linux/gpio_keys.h>
#include <linux/input.h>
+#include <linux/pci_ids.h>
#include <linux/platform_device.h>
#include <linux/spi/spi.h>
#include <linux/spi/spi_gpio.h>
@@ -3006,6 +3007,495 @@ static struct board_info __initdata boar
},
};
+static struct board_info __initdata board_HW556 = {
+ .name = "HW556",
+ .expected_cpu_id = 0x6358,
+
+ .has_uart0 = 1,
+ .has_pci = 1,
+ .has_ohci0 = 1,
+ .has_ehci0 = 1,
+ .num_usbh_ports = 2,
+
+ .has_caldata = 1,
+ .caldata = {
+ {
+ .caldata_offset = 0xe00000,
+ },
+ },
+
+ .has_enet1 = 1,
+ .enet1 = {
+ .has_phy = 1,
+ .phy_id = 0,
+ .force_speed_100 = 1,
+ .force_duplex_full = 1,
+ },
+
+ .leds = {
+ {
+ .name = "HW556:red:message",
+ .gpio = 0,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:hspa",
+ .gpio = 1,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:dsl",
+ .gpio = 2,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:power",
+ .gpio = 3,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ {
+ .name = "HW556:red:all",
+ .gpio = 6,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ },
+
+ .buttons = {
+ {
+ .desc = "help",
+ .gpio = 8,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_HELP,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "wlan",
+ .gpio = 9,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_WLAN,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "restart",
+ .gpio = 10,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_RESTART,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "reset",
+ .gpio = 11,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_CONFIG,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ },
+};
+static struct board_info __initdata board_HW556_A = {
+ .name = "HW556_A",
+ .of_board_id = "huawei,hg556a-a",
+ .expected_cpu_id = 0x6358,
+
+ .has_uart0 = 1,
+ .has_pci = 1,
+ .has_ohci0 = 1,
+ .has_ehci0 = 1,
+ .num_usbh_ports = 2,
+
+ .has_caldata = 1,
+ .caldata = {
+ {
+ .vendor = PCI_VENDOR_ID_RALINK,
+ .caldata_offset = 0xeffe00,
+ .slot = 1,
+ .eeprom = "rt2x00.eeprom",
+ },
+ },
+
+ .has_enet1 = 1,
+ .enet1 = {
+ .has_phy = 1,
+ .phy_id = 0,
+ .force_speed_100 = 1,
+ .force_duplex_full = 1,
+ },
+
+ .leds = {
+ {
+ .name = "HW556:green:lan1",
+ .gpio = 0,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan2",
+ .gpio = 1,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:dsl",
+ .gpio = 2,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:power",
+ .gpio = 3,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ {
+ .name = "HW556:red:message",
+ .gpio = 12,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan1",
+ .gpio = 13,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:hspa",
+ .gpio = 15,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan2",
+ .gpio = 22,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan3",
+ .gpio = 23,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan3",
+ .gpio = 26,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan4",
+ .gpio = 27,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan4",
+ .gpio = 28,
+ .active_low = 1,
+ },
+ },
+
+ .buttons = {
+ {
+ .desc = "help",
+ .gpio = 8,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_HELP,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "wlan",
+ .gpio = 9,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_WLAN,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "restart",
+ .gpio = 10,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_RESTART,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "reset",
+ .gpio = 11,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_CONFIG,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ },
+};
+static struct board_info __initdata board_HW556_B = {
+ .name = "HW556_B",
+ .of_board_id = "huawei,hg556a-b",
+ .expected_cpu_id = 0x6358,
+
+ .has_uart0 = 1,
+ .has_pci = 1,
+ .has_ohci0 = 1,
+ .has_ehci0 = 1,
+ .num_usbh_ports = 2,
+
+ .has_caldata = 1,
+ .caldata = {
+ {
+ .vendor = PCI_VENDOR_ID_ATHEROS,
+ .caldata_offset = 0xf7e000,
+ .slot = 1,
+ .endian_check = 1,
+ .led_pin = 2,
+ },
+ },
+
+ .has_enet1 = 1,
+ .enet1 = {
+ .has_phy = 1,
+ .phy_id = 0,
+ .force_speed_100 = 1,
+ .force_duplex_full = 1,
+ },
+
+ .leds = {
+ {
+ .name = "HW556:red:message",
+ .gpio = 0,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:hspa",
+ .gpio = 1,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:dsl",
+ .gpio = 2,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:power",
+ .gpio = 3,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ {
+ .name = "HW556:red:all",
+ .gpio = 6,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ {
+ .name = "HW556:green:lan1",
+ .gpio = 12,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan1",
+ .gpio = 13,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan2",
+ .gpio = 15,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan2",
+ .gpio = 22,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan3",
+ .gpio = 23,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan3",
+ .gpio = 26,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan4",
+ .gpio = 27,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan4",
+ .gpio = 28,
+ .active_low = 1,
+ },
+ },
+
+ .buttons = {
+ {
+ .desc = "help",
+ .gpio = 8,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_HELP,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "wlan",
+ .gpio = 9,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_WLAN,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "restart",
+ .gpio = 10,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_RESTART,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "reset",
+ .gpio = 11,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_CONFIG,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ },
+};
+static struct board_info __initdata board_HW556_C = {
+ .name = "HW556_C",
+ .of_board_id = "huawei,hg556a-c",
+ .expected_cpu_id = 0x6358,
+
+ .has_uart0 = 1,
+ .has_pci = 1,
+ .has_ohci0 = 1,
+ .has_ehci0 = 1,
+ .num_usbh_ports = 2,
+
+ .has_caldata = 1,
+ .caldata = {
+ {
+ .vendor = PCI_VENDOR_ID_ATHEROS,
+ .caldata_offset = 0xefe000,
+ .slot = 1,
+ .endian_check = 1,
+ .led_pin = 2,
+ },
+ },
+
+ .has_enet1 = 1,
+ .enet1 = {
+ .has_phy = 1,
+ .phy_id = 0,
+ .force_speed_100 = 1,
+ .force_duplex_full = 1,
+ },
+
+ .leds = {
+ {
+ .name = "HW556:red:message",
+ .gpio = 0,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:hspa",
+ .gpio = 1,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:dsl",
+ .gpio = 2,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:power",
+ .gpio = 3,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ {
+ .name = "HW556:red:all",
+ .gpio = 6,
+ .active_low = 1,
+ .default_trigger = "default-on",
+ },
+ {
+ .name = "HW556:green:lan1",
+ .gpio = 12,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan1",
+ .gpio = 13,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan2",
+ .gpio = 15,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan2",
+ .gpio = 22,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan3",
+ .gpio = 23,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan3",
+ .gpio = 26,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:green:lan4",
+ .gpio = 27,
+ .active_low = 1,
+ },
+ {
+ .name = "HW556:red:lan4",
+ .gpio = 28,
+ .active_low = 1,
+ },
+ },
+
+ .buttons = {
+ {
+ .desc = "help",
+ .gpio = 8,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_HELP,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "wlan",
+ .gpio = 9,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_WLAN,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "restart",
+ .gpio = 10,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_RESTART,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ {
+ .desc = "reset",
+ .gpio = 11,
+ .active_low = 1,
+ .type = EV_KEY,
+ .code = KEY_CONFIG,
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
+ },
+ },
+};
+
/* T-Home Speedport W 303V Typ B */
static struct board_info __initdata board_spw303v = {
.name = "96358-502V",
@@ -3446,6 +3936,10 @@ static const struct board_info __initcon
&board_nb4_fxc_r2,
&board_ct6373_1,
&board_HW553,
+ &board_HW556,
+ &board_HW556_A,
+ &board_HW556_B,
+ &board_HW556_C,
&board_spw303v,
&board_DVAG3810BN,
#endif
--- a/drivers/mtd/bcm63xxpart.c
+++ b/drivers/mtd/bcm63xxpart.c
@@ -224,6 +224,11 @@ static int bcm63xx_parse_cfe_partitions(
BCM63XX_CFE_BLOCK_SIZE);
cfelen = cfe_erasesize;
+
+ /* Fix HW556 MX29LV128DB */
+ if (!strncmp(bcm63xx_nvram_get_name(), "HW556", 5))
+ cfelen = 0x20000;
+
nvramlen = bcm63xx_nvram_get_psi_size() * SZ_1K;
nvramlen = roundup(nvramlen, cfe_erasesize);
nvramaddr = master->size - nvramlen;