Changeset 27665


Ignore:
Timestamp:
2011-07-17T21:27:44+02:00 (7 years ago)
Author:
blogic
Message:

[lantiq]

  • add gigasx76x update
  • rebase patches
  • add arv752DPW arv7525PD
  • fixes gpio_keys

Signed-off-by: Luka Perkov <openwrt@…>
Signed-off-by: John Crispin <blogic@…>

Location:
trunk/target/linux/lantiq
Files:
17 edited

Legend:

Unmodified
Added
Removed
  • trunk/target/linux/lantiq/config-default

    r27026 r27665  
    1 CONFIG_32BIT=y 
    21# CONFIG_64BIT is not set 
    3 # CONFIG_ALCHEMY_GPIO_INDIRECT is not set 
    4 # CONFIG_AR7 is not set 
    52# CONFIG_ARCH_HAS_ILOG2_U32 is not set 
    63# CONFIG_ARCH_HAS_ILOG2_U64 is not set 
     
    118CONFIG_ARCH_SUPPORTS_OPROFILE=y 
    129CONFIG_ARCH_SUSPEND_POSSIBLE=y 
    13 # CONFIG_BCM47XX is not set 
    14 # CONFIG_BCM63XX is not set 
    15 CONFIG_BITREVERSE=y 
    16 CONFIG_BOOT_RAW=y 
    17 # CONFIG_CAVIUM_OCTEON_REFERENCE_BOARD is not set 
    18 # CONFIG_CAVIUM_OCTEON_SIMULATOR is not set 
    1910CONFIG_CEVT_R4K=y 
    2011CONFIG_CEVT_R4K_LIB=y 
     
    8778CONFIG_LEDS_GPIO=y 
    8879# CONFIG_MACH_ALCHEMY is not set 
    89 # CONFIG_MACH_DECSTATION is not set 
    90 # CONFIG_MACH_JAZZ is not set 
    91 # CONFIG_MACH_LOONGSON is not set 
    92 # CONFIG_MACH_TX39XX is not set 
    93 # CONFIG_MACH_TX49XX is not set 
    94 # CONFIG_MACH_VR41XX is not set 
    95 # CONFIG_MIKROTIK_RB532 is not set 
    9680CONFIG_MIPS=y 
    97 # CONFIG_MIPS_COBALT is not set 
    9881CONFIG_MIPS_L1_CACHE_SHIFT=5 
    9982CONFIG_MIPS_MACHINE=y 
    100 # CONFIG_MIPS_MALTA is not set 
    10183CONFIG_MIPS_MT_DISABLED=y 
    10284# CONFIG_MIPS_MT_SMP is not set 
    10385# CONFIG_MIPS_MT_SMTC is not set 
    104 # CONFIG_MIPS_SIM is not set 
    10586# CONFIG_MIPS_VPE_LOADER is not set 
    10687CONFIG_MTD_CFI_ADV_OPTIONS=y 
     
    11091CONFIG_MTD_UIMAGE_SPLIT=y 
    11192CONFIG_NLS=y 
    112 # CONFIG_NO_IOPORT is not set 
    113 # CONFIG_NXP_STB220 is not set 
    114 # CONFIG_NXP_STB225 is not set 
    11593CONFIG_PAGEFLAGS_EXTENDED=y 
    11694CONFIG_PHYLIB=y 
    117 # CONFIG_PMC_MSP is not set 
    118 # CONFIG_PMC_YOSEMITE is not set 
    119 # CONFIG_PNX8550_JBS is not set 
    120 # CONFIG_PNX8550_STB810 is not set 
    121 CONFIG_SCHED_OMIT_FRAME_POINTER=y 
    12295# CONFIG_SCSI_DMA is not set 
    12396# CONFIG_SERIAL_8250 is not set 
    12497CONFIG_SERIAL_LANTIQ=y 
    125 # CONFIG_SGI_IP22 is not set 
    126 # CONFIG_SGI_IP27 is not set 
    127 # CONFIG_SGI_IP28 is not set 
    128 # CONFIG_SGI_IP32 is not set 
    129 # CONFIG_SIBYTE_BIGSUR is not set 
    130 # CONFIG_SIBYTE_CARMEL is not set 
    131 # CONFIG_SIBYTE_CRHINE is not set 
    132 # CONFIG_SIBYTE_CRHONE is not set 
    133 # CONFIG_SIBYTE_LITTLESUR is not set 
    134 # CONFIG_SIBYTE_RHONE is not set 
    135 # CONFIG_SIBYTE_SENTOSA is not set 
    136 # CONFIG_SIBYTE_SWARM is not set 
    13798CONFIG_SWAP_IO_SPACE=y 
    13899CONFIG_SWCONFIG=y 
     
    144105CONFIG_SYS_SUPPORTS_BIG_ENDIAN=y 
    145106CONFIG_SYS_SUPPORTS_MULTITHREADING=y 
    146 CONFIG_TRAD_SIGNALS=y 
    147 # CONFIG_TREE_PREEMPT_RCU is not set 
    148107CONFIG_TREE_RCU=y 
    149108CONFIG_ZONE_DMA_FLAG=0 
  • trunk/target/linux/lantiq/danube/profiles/002-arcadyan.mk

    r27535 r27665  
    6262$(eval $(call Profile,ARV4525PW)) 
    6363 
     64define Profile/ARV7525PW 
     65  NAME:=ARV7525PW - Speedport W303V Typ A 
     66  PACKAGES:= kmod-usb-core kmod-usb-dwc-otg \ 
     67        kmod-ledtrig-netdev kmod-ledtrig-usbdev kmod-leds-gpio kmod-button-hotplug \ 
     68        kmod-rt2800-pci wpad-mini kmod-ltq-dsl-firmware-b 
     69endef 
     70 
     71define Profile/ARV4525PW/Description 
     72        Package set optimized for the ARV4525PW 
     73endef 
     74 
     75$(eval $(call Profile,ARV7525PW)) 
     76 
    6477define Profile/ARV452CPW 
    6578  NAME:=ARV452CPW - Arcor Easybox 801 
     
    7487 
    7588$(eval $(call Profile,ARV452CPW)) 
     89 
     90define Profile/ARV752DPW 
     91  NAME:=ARV752DPW - Arcor Easybox 802 
     92  PACKAGES:= kmod-usb-core kmod-usb-dwc-otg \ 
     93        kmod-ledtrig-netdev kmod-ledtrig-usbdev kmod-leds-gpio kmod-button-hotplug \ 
     94        kmod-rt2800-pci kmod-ltq-dsl-firmware-b 
     95endef 
     96 
     97define Profile/ARV752DPW/Description 
     98        Package set optimized for the ARV752PW 
     99endef 
     100 
     101$(eval $(call Profile,ARV752DPW)) 
    76102 
    77103define Profile/ARV752DPW22 
  • trunk/target/linux/lantiq/image/Makefile

    r27550 r27665  
    113113endef 
    114114 
     115define Image/BuildKernel/Profile/ARV7525PW 
     116        $(call Image/BuildKernel/Template,ARV7525PW,$(xway_cmdline)) 
     117endef 
     118 
     119define Image/Build/Profile/ARV7525PW 
     120        $(call Image/Build/$(1),$(1),ARV7525PW) 
     121endef 
     122 
    115123define Image/BuildKernel/Profile/ARV452CPW 
    116124        $(call Image/BuildKernel/Template,ARV452CPW,$(xway_cmdline)) 
     
    127135define Image/Build/Profile/ARV7518PW 
    128136        $(call Image/Build/$(1),$(1),ARV7518PW) 
     137endef 
     138 
     139define Image/BuildKernel/Profile/ARV752DPW 
     140        $(call Image/BuildKernel/Template,ARV752DPW,$(xway_cmdline)) 
     141endef 
     142 
     143define Image/Build/Profile/ARV752DPW 
     144        $(call Image/Build/$(1),$(1),ARV752DPW) 
    129145endef 
    130146 
     
    155171        $(call Image/BuildKernel/Template,ARV452CPW,$(xway_cmdline)) 
    156172        $(call Image/BuildKernel/Template,ARV4525PW,$(xway_cmdline)) 
     173        $(call Image/BuildKernel/Template,ARV7525PW,$(xway_cmdline)) 
    157174        $(call Image/BuildKernel/Template,ARV7518PW,$(xway_cmdline)) 
    158175        $(call Image/BuildKernel/Template,ARV752DPW,$(xway_cmdline)) 
     
    172189        $(call Image/Build/$(1),$(1),ARV452CPW) 
    173190        $(call Image/Build/$(1),$(1),ARV4525PW) 
     191        $(call Image/Build/$(1),$(1),ARV7525PW) 
    174192        $(call Image/Build/$(1),$(1),ARV7518PW) 
    175193        $(call Image/Build/$(1),$(1),ARV752DPW) 
  • trunk/target/linux/lantiq/patches-2.6.39/0014-fix_mtd.patch

    r27489 r27665  
    11--- a/arch/mips/lantiq/xway/mach-easy50601.c 
    22+++ b/arch/mips/lantiq/xway/mach-easy50601.c 
    3 @@ -32,12 +32,7 @@ 
     3@@ -32,12 +32,7 @@ static struct mtd_partition easy50601_pa 
    44        { 
    55                .name   = "linux", 
     
    1717--- a/arch/mips/lantiq/xway/mach-easy50712.c 
    1818+++ b/arch/mips/lantiq/xway/mach-easy50712.c 
    19 @@ -34,12 +34,7 @@ 
     19@@ -34,12 +34,7 @@ static struct mtd_partition easy50712_pa 
    2020        { 
    2121                .name   = "linux", 
  • trunk/target/linux/lantiq/patches-2.6.39/150-falcon-easy98020.patch

    r27406 r27665  
    134134--- a/arch/mips/lantiq/falcon/Makefile 
    135135+++ b/arch/mips/lantiq/falcon/Makefile 
    136 @@ -2,3 +2,4 @@ obj-y := clk-falcon.o devices.o gpio.o p 
    137  obj-y += softdog_vpe.o 
     136@@ -3,3 +3,4 @@ obj-y += softdog_vpe.o 
     137 obj-$(CONFIG_LANTIQ_MACH_EASY98000) += addon-easy98000.o 
    138138 obj-$(CONFIG_LANTIQ_MACH_EASY98000) += mach-easy98000.o 
    139139 obj-$(CONFIG_LANTIQ_MACH_EASY98000) += dev-leds-easy98000-cpld.o 
  • trunk/target/linux/lantiq/patches-2.6.39/160-falcon-95C3AM1.patch

    r27104 r27665  
    120120--- a/arch/mips/lantiq/falcon/Makefile 
    121121+++ b/arch/mips/lantiq/falcon/Makefile 
    122 @@ -3,3 +3,4 @@ obj-y += softdog_vpe.o 
     122@@ -4,3 +4,4 @@ obj-$(CONFIG_LANTIQ_MACH_EASY98000) += a 
    123123 obj-$(CONFIG_LANTIQ_MACH_EASY98000) += mach-easy98000.o 
    124124 obj-$(CONFIG_LANTIQ_MACH_EASY98000) += dev-leds-easy98000-cpld.o 
     
    127127--- a/arch/mips/lantiq/machtypes.h 
    128128+++ b/arch/mips/lantiq/machtypes.h 
    129 @@ -20,6 +20,7 @@ enum lantiq_mach_type { 
    130         LANTIQ_MACH_EASY98000,          /* Falcon Eval Board, NOR Flash */ 
     129@@ -21,6 +21,7 @@ enum lantiq_mach_type { 
    131130        LANTIQ_MACH_EASY98000SF,        /* Falcon Eval Board, Serial Flash */ 
     131        LANTIQ_MACH_EASY98000NAND,      /* Falcon Eval Board, NAND Flash */ 
    132132        LANTIQ_MACH_EASY98020,          /* Falcon Reference Board */ 
    133133+       LANTIQ_MACH_95C3AM1,            /* Board 95C3AM1 */ 
  • trunk/target/linux/lantiq/patches-2.6.39/200-mach-arv45xx.patch

    r27172 r27665  
    11--- a/arch/mips/lantiq/xway/Kconfig 
    22+++ b/arch/mips/lantiq/xway/Kconfig 
    3 @@ -6,6 +6,10 @@ config LANTIQ_MACH_EASY50712 
     3@@ -6,6 +6,10 @@ 
    44        bool "Easy50712 - Danube" 
    55        default y 
     
    1414--- a/arch/mips/lantiq/xway/Makefile 
    1515+++ b/arch/mips/lantiq/xway/Makefile 
    16 @@ -5,3 +5,4 @@ obj-$(CONFIG_SOC_AMAZON_SE) += clk-ase.o 
     16@@ -5,3 +5,4 @@ 
    1717  
    1818 obj-$(CONFIG_LANTIQ_MACH_EASY50712) += mach-easy50712.o 
     
    2121--- /dev/null 
    2222+++ b/arch/mips/lantiq/xway/mach-arv45xx.c 
    23 @@ -0,0 +1,504 @@ 
     23@@ -0,0 +1,634 @@ 
    2424+/* 
    2525+ *  This program is free software; you can redistribute it and/or modify it 
     
    3434+#include <linux/leds.h> 
    3535+#include <linux/gpio.h> 
    36 +#include <linux/gpio_buttons.h> 
    3736+#include <linux/mtd/mtd.h> 
    3837+#include <linux/mtd/partitions.h> 
     
    5049+#include "dev-leds-gpio.h" 
    5150+#include "dev-dwc_otg.h" 
     51+#include "../dev-gpio-buttons.h" 
    5252+ 
    5353+#ifdef CONFIG_MTD_PARTITIONS 
     
    124124+}; 
    125125+ 
     126+static struct mtd_partition arv7525_partitions[] = 
     127+{ 
     128+       { 
     129+               .name   = "uboot", 
     130+               .offset = 0x0, 
     131+               .size   = 0x10000, 
     132+       }, 
     133+       { 
     134+               .name   = "uboot_env", 
     135+               .offset = 0x10000, 
     136+               .size   = 0x10000, 
     137+       }, 
     138+       { 
     139+               .name   = "linux", 
     140+               .offset = 0x20000, 
     141+               .size   = 0x3d0000, 
     142+       }, 
     143+       { 
     144+               .name   = "board_config", 
     145+               .offset = 0x3f0000, 
     146+               .size   = 0x10000, 
     147+       }, 
     148+}; 
    126149+#endif 
    127150+ 
     
    144167+       .nr_parts       = ARRAY_SIZE(arv75xx_partitions), 
    145168+       .parts          = arv75xx_partitions, 
     169+#endif 
     170+}; 
     171+ 
     172+static struct physmap_flash_data arv7525_flash_data = { 
     173+#ifdef CONFIG_MTD_PARTITIONS 
     174+       .nr_parts       = ARRAY_SIZE(arv7525_partitions), 
     175+       .parts          = arv7525_partitions, 
    146176+#endif 
    147177+}; 
     
    179209+}; 
    180210+ 
    181 +static struct gpio_button 
    182 +arv4518pw_gpio_buttons[] __initdata = { 
    183 +       { .desc = "wlan", .type = EV_KEY, .code = BTN_0, .threshold = 3, .gpio = 28, .active_low = 1, }, 
    184 +       { .desc = "wps", .type = EV_KEY, .code = BTN_1, .threshold = 3, .gpio = 29, .active_low = 1, }, 
    185 +       { .desc = "reset", .type = EV_KEY, .code = BTN_2, .threshold = 3, .gpio = 30, .active_low = 1, }, 
     211+static struct gpio_keys_button 
     212+arv4518pw_gpio_keys[] __initdata = { 
     213+       { 
     214+               .desc           = "wlan", 
     215+               .type           = EV_KEY, 
     216+               .code           = BTN_0, 
     217+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     218+               .gpio   = 28, 
     219+               .active_low     = 1, 
     220+       }, 
     221+       { 
     222+               .desc           = "wps", 
     223+               .type           = EV_KEY, 
     224+               .code           = BTN_1, 
     225+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     226+               .gpio           = 29, 
     227+               .active_low     = 1, 
     228+       }, 
     229+       { 
     230+               .desc           = "reset", 
     231+               .type           = EV_KEY, 
     232+               .code           = BTN_2, 
     233+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     234+               .gpio           = 30, 
     235+               .active_low     = 1, 
     236+       }, 
    186237+}; 
    187238+ 
     
    250301+}; 
    251302+ 
    252 +static struct gpio_button 
    253 +arv752dpw22_gpio_buttons[] __initdata = { 
    254 +       { .desc = "btn0", .type = EV_KEY, .code = BTN_0, .threshold = 3, .gpio = 12, .active_low = 1, }, 
    255 +       { .desc = "btn1", .type = EV_KEY, .code = BTN_1, .threshold = 3, .gpio = 13, .active_low = 1, }, 
    256 +       { .desc = "btn2", .type = EV_KEY, .code = BTN_2, .threshold = 3, .gpio = 28, .active_low = 1, }, 
     303+static struct gpio_keys_button 
     304+arv752dpw22_gpio_keys[] __initdata = { 
     305+       { 
     306+               .desc = "btn0", 
     307+               .type = EV_KEY, 
     308+               .code = BTN_0, 
     309+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     310+               .gpio = 12, 
     311+               .active_low = 1, 
     312+       }, 
     313+       { 
     314+               .desc = "btn1", 
     315+               .type = EV_KEY, 
     316+               .code = BTN_1, 
     317+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     318+               .gpio = 13, 
     319+               .active_low = 1, 
     320+       }, 
     321+       { 
     322+               .desc = "btn2", 
     323+               .type = EV_KEY, 
     324+               .code = BTN_2, 
     325+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     326+               .gpio = 28, 
     327+               .active_low = 1, 
     328+       }, 
    257329+}; 
    258330+ 
     
    267339+}; 
    268340+ 
    269 +static struct gpio_button 
    270 +arv7518pw_gpio_buttons[] __initdata = { 
    271 +       { .desc = "reset", .type = EV_KEY, .code = BTN_0, .threshold = 3, .gpio = 23, .active_low = 1, }, 
    272 +       { .desc = "wlan", .type = EV_KEY, .code = BTN_1, .threshold = 3, .gpio = 25, .active_low = 1, }, 
     341+static struct gpio_keys_button 
     342+arv7518pw_gpio_keys[] __initdata = { 
     343+       { 
     344+               .desc = "reset", 
     345+               .type = EV_KEY, 
     346+               .code = BTN_0, 
     347+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     348+               .gpio = 23, 
     349+               .active_low = 1, 
     350+       }, 
     351+       { 
     352+               .desc = "wlan", 
     353+               .type = EV_KEY, 
     354+               .code = BTN_1, 
     355+               .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     356+               .gpio = 25, 
     357+               .active_low = 1, 
     358+       }, 
    273359+}; 
    274360+ 
     
    329415+               if (i == 0xbf>>1){ 
    330416+                       // printk ("regdomain: 0x%x --> 0x%x\n", p[i], (p[i] & 0xffff0000)|0x67); 
    331 +                       /* regdomain is invalid?? how did original fw convert  
     417+                       /* regdomain is invalid?? how did original fw convert 
    332418+                       * value to 0x82d4 ?? 
    333419+                       * for now, force to 0x67 */ 
     
    379465+#define ARV4518PW_USB                  14 
    380466+#define ARV4518PW_SWITCH_RESET         13 
     467+#define ARV4518PW_MADWIFI_ADDR         0xb07f0400 
    381468+ 
    382469+       ltq_register_gpio_ebu(ARV4518PW_EBU); 
    383470+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(arv4518pw_leds_gpio), arv4518pw_leds_gpio); 
    384 +       ltq_register_gpio_buttons(arv4518pw_gpio_buttons, ARRAY_SIZE(arv4518pw_gpio_buttons)); 
     471+       ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(arv4518pw_gpio_keys), arv4518pw_gpio_keys); 
    385472+       ltq_register_nor(&arv45xx_flash_data); 
    386473+       ltq_pci_data.gpio = PCI_GNT2 | PCI_REQ2; 
    387474+       ltq_register_pci(&ltq_pci_data); 
    388 +       ltq_register_madwifi_eep(); 
     475+       ltq_register_madwifi_eep(ARV4518PW_MADWIFI_ADDR); 
    389476+       xway_register_dwc(ARV4518PW_USB); 
    390477+       arv45xx_register_ethernet(); 
     
    433520+#define ARV452CPW_RELAY2               79 
    434521+#define ARV452CPW_SWITCH_RESET         82 
     522+#define ARV452CPW_MADWIFI_ADDR         0xb07f0400 
    435523+ 
    436524+       ltq_register_gpio_ebu(ARV452CPW_EBU); 
     
    438526+       ltq_register_nor(&arv45xx_flash_data); 
    439527+       ltq_register_pci(&ltq_pci_data); 
    440 +       ltq_register_madwifi_eep(); 
     528+       ltq_register_madwifi_eep(ARV452CPW_MADWIFI_ADDR); 
    441529+       xway_register_dwc(ARV452CPW_USB); 
    442530+       arv45xx_register_ethernet(); 
     
    464552+arv4525pw_init(void) 
    465553+{ 
     554+#define ARV4525PW_MADWIFI_ADDR 0xb07f0400 
     555+ 
    466556+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(arv4525pw_leds_gpio), arv4525pw_leds_gpio); 
    467557+       ltq_register_nor(&arv45xx_flash_data); 
    468558+       ltq_pci_data.clock = PCI_CLOCK_INT; 
    469559+       ltq_register_pci(&ltq_pci_data); 
    470 +       ltq_register_madwifi_eep(); 
     560+       ltq_register_madwifi_eep(ARV4525PW_MADWIFI_ADDR); 
    471561+       ltq_eth_data.mii_mode = PHY_INTERFACE_MODE_MII; 
    472562+       arv45xx_register_ethernet(); 
     
    479569+ 
    480570+static void __init 
     571+arv7525pw_init(void) 
     572+{ 
     573+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(arv4525pw_leds_gpio), arv4525pw_leds_gpio); 
     574+       ltq_register_nor(&arv7525_flash_data); 
     575+       ltq_register_pci(&ltq_pci_data); 
     576+       ltq_eth_data.mii_mode = PHY_INTERFACE_MODE_MII; 
     577+       ltq_register_tapi(); 
     578+       arv45xx_register_ethernet(); 
     579+} 
     580+ 
     581+MIPS_MACHINE(LANTIQ_MACH_ARV7525PW, 
     582+                       "ARV7525PW", 
     583+                       "ARV7525PW - Speedport W303V", 
     584+                       arv7525pw_init); 
     585+ 
     586+static void __init 
    481587+arv7518pw_init(void) 
    482588+{ 
     
    486592+       ltq_register_gpio_ebu(ARV7518PW_EBU); 
    487593+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(arv7518pw_leds_gpio), arv7518pw_leds_gpio); 
    488 +       ltq_register_gpio_buttons(arv7518pw_gpio_buttons, ARRAY_SIZE(arv7518pw_gpio_buttons)); 
     594+       ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(arv7518pw_gpio_keys), arv7518pw_gpio_keys); 
    489595+       ltq_register_nor(&arv75xx_flash_data); 
    490596+       ltq_register_pci(&ltq_pci_data); 
     
    500606+                       arv7518pw_init); 
    501607+ 
     608+ 
     609+static void __init 
     610+arv752dpw_init(void) 
     611+{ 
     612+#define ARV752DPW22_EBU                 0x2 
     613+#define ARV752DPW22_USB                 72 
     614+#define ARV752DPW22_RELAY               73 
     615+       ltq_register_gpio_ebu(ARV752DPW22_EBU); 
     616+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(arv752dpw22_leds_gpio), arv752dpw22_leds_gpio); 
     617+       ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(arv752dpw22_gpio_keys), arv752dpw22_gpio_keys); 
     618+       ltq_register_nor(&arv75xx_flash_data); 
     619+       ltq_register_pci(&ltq_pci_data); 
     620+       xway_register_dwc(ARV752DPW22_USB); 
     621+       arv75xx_register_ethernet(); 
     622+       gpio_request(ARV752DPW22_RELAY, "relay"); 
     623+       gpio_set_value(ARV752DPW22_RELAY, 1); 
     624+       gpio_export(ARV752DPW22_RELAY, 0); 
     625+} 
     626+ 
     627+MIPS_MACHINE(LANTIQ_MACH_ARV752DPW, 
     628+                        "ARV752DPW", 
     629+                        "ARV752DPW - Arcor A802", 
     630+                        arv752dpw_init); 
     631+ 
    502632+static void __init 
    503633+arv752dpw22_init(void) 
     
    509639+       ltq_register_gpio_ebu(ARV752DPW22_EBU); 
    510640+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(arv752dpw22_leds_gpio), arv752dpw22_leds_gpio); 
    511 +       ltq_register_gpio_buttons(arv752dpw22_gpio_buttons, ARRAY_SIZE(arv752dpw22_gpio_buttons)); 
     641+       ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(arv752dpw22_gpio_keys), arv752dpw22_gpio_keys); 
    512642+       ltq_register_nor(&arv75xx_flash_data); 
    513 +       ltq_pci_data.irq[15] = (INT_NUM_IM2_IRL0 + 31); 
     643+       ltq_pci_data.irq[15] = (INT_NUM_IM3_IRL0 + 31); 
    514644+       ltq_pci_data.gpio |= PCI_EXIN1 | PCI_REQ2; 
    515645+       ltq_register_pci(&ltq_pci_data); 
     
    528658--- a/arch/mips/lantiq/machtypes.h 
    529659+++ b/arch/mips/lantiq/machtypes.h 
    530 @@ -21,6 +21,17 @@ enum lantiq_mach_type { 
    531         LANTIQ_MACH_EASY98000SF,        /* Falcon Eval Board, Serial Flash */ 
     660@@ -22,6 +22,18 @@ 
     661        LANTIQ_MACH_EASY98000NAND,      /* Falcon Eval Board, NAND Flash */ 
    532662        LANTIQ_MACH_EASY98020,          /* Falcon Reference Board */ 
    533663        LANTIQ_MACH_95C3AM1,            /* Board 95C3AM1 */ 
     
    540670+       LANTIQ_MACH_ARV452CPW,          /* Arcor EasyboxA801 */ 
    541671+       LANTIQ_MACH_ARV4525PW,          /* Speedport W502V */ 
     672+       LANTIQ_MACH_ARV7525PW,          /* Speedport W303V Typ A */ 
    542673+       LANTIQ_MACH_ARV752DPW,          /* Arcor easybox a802 */ 
    543674+       LANTIQ_MACH_ARV752DPW22,        /* Arcor easybox a803 */ 
  • trunk/target/linux/lantiq/patches-2.6.39/280-netif_receive_skb.patch

    r27410 r27665  
    11--- a/drivers/net/lantiq_etop.c 
    22+++ b/drivers/net/lantiq_etop.c 
    3 @@ -155,8 +155,12 @@ 
     3@@ -155,8 +155,12 @@ ltq_etop_hw_receive(struct ltq_etop_chan 
    44  
    55        skb_put(skb, len); 
  • trunk/target/linux/lantiq/patches-2.6.39/410-spi2.patch

    r27137 r27665  
    1111--- a/drivers/spi/Kconfig 
    1212+++ b/drivers/spi/Kconfig 
    13 @@ -193,6 +193,14 @@ 
     13@@ -193,6 +193,14 @@ config SPI_IMX 
    1414          This enables using the Freescale i.MX SPI controllers in master 
    1515          mode. 
     
    2828--- a/drivers/spi/Makefile 
    2929+++ b/drivers/spi/Makefile 
    30 @@ -26,6 +26,7 @@ 
     30@@ -26,6 +26,7 @@ obj-$(CONFIG_SPI_EP93XX)              += ep93xx_spi. 
    3131 obj-$(CONFIG_SPI_GPIO)                 += spi_gpio.o 
    3232 obj-$(CONFIG_SPI_GPIO_OLD)             += spi_gpio_old.o 
  • trunk/target/linux/lantiq/patches-2.6.39/420-spi3.patch

    r27137 r27665  
    1919 #include <asm/bootinfo.h> 
    2020 #include <asm/irq.h> 
    21 @@ -119,3 +120,41 @@ 
     21@@ -119,3 +120,41 @@ ltq_register_etop(struct ltq_eth_data *e 
    2222                platform_device_register(&ltq_etop); 
    2323        } 
  • trunk/target/linux/lantiq/patches-2.6.39/510-register_madwifi.patch

    r27104 r27665  
    11--- a/arch/mips/lantiq/xway/devices.c 
    22+++ b/arch/mips/lantiq/xway/devices.c 
    3 @@ -144,6 +144,16 @@ ltq_register_gpio_ebu(unsigned int value 
     3@@ -144,6 +144,19 @@ ltq_register_gpio_ebu(unsigned int value 
    44        platform_device_register(&ltq_ebu); 
    55 } 
     
    77+/* madwifi */ 
    88+int lantiq_emulate_madwifi_eep = 0; 
     9+unsigned long long lantiq_madwifi_eep_addr = 0; 
    910+EXPORT_SYMBOL(lantiq_emulate_madwifi_eep); 
     11+EXPORT_SYMBOL(lantiq_madwifi_eep_addr); 
    1012+ 
    1113+void __init 
    12 +ltq_register_madwifi_eep(void) 
     14+ltq_register_madwifi_eep(unsigned long long addr) 
    1315+{ 
    1416+       lantiq_emulate_madwifi_eep = 1; 
     17+       lantiq_madwifi_eep_addr = addr; 
    1518+} 
    1619+ 
     
    2427 extern void ltq_register_etop(struct ltq_eth_data *eth); 
    2528 extern void ltq_register_gpio_ebu(unsigned int value); 
    26 +extern void ltq_register_madwifi_eep(void); 
     29+extern void ltq_register_madwifi_eep(unsigned long long addr); 
    2730  
    2831 #endif 
  • trunk/target/linux/lantiq/patches-2.6.39/520-register_buttons.patch

    r27104 r27665  
    1 --- a/arch/mips/lantiq/xway/devices.c 
    2 +++ b/arch/mips/lantiq/xway/devices.c 
    3 @@ -154,6 +154,26 @@ ltq_register_madwifi_eep(void) 
    4         lantiq_emulate_madwifi_eep = 1; 
    5  } 
     1--- a/arch/mips/lantiq/Makefile 
     2+++ b/arch/mips/lantiq/Makefile 
     3@@ -4,7 +4,7 @@ 
     4 # under the terms of the GNU General Public License version 2 as published 
     5 # by the Free Software Foundation. 
    66  
    7 +/* gpio buttons */ 
    8 +static struct gpio_buttons_platform_data ltq_gpio_buttons_platform_data; 
     7-obj-y := irq.o setup.o clk.o prom.o devices.o 
     8+obj-y := irq.o setup.o clk.o prom.o devices.o dev-gpio-buttons.o 
     9  
     10 obj-$(CONFIG_EARLY_PRINTK) += early_printk.o 
     11  
     12--- /dev/null 
     13+++ b/arch/mips/lantiq/dev-gpio-buttons.c 
     14@@ -0,0 +1,58 @@ 
     15+/* 
     16+ *  Lantiq GPIO button support 
     17+ * 
     18+ *  Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org> 
     19+ *  Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org> 
     20+ * 
     21+ *  This program is free software; you can redistribute it and/or modify it 
     22+ *  under the terms of the GNU General Public License version 2 as published 
     23+ *  by the Free Software Foundation. 
     24+ */ 
    925+ 
    10 +static struct platform_device ltq_gpio_buttons_platform_device = 
     26+#include "linux/init.h" 
     27+#include "linux/slab.h" 
     28+#include <linux/platform_device.h> 
     29+ 
     30+#include "dev-gpio-buttons.h" 
     31+ 
     32+void __init ltq_register_gpio_keys_polled(int id, 
     33+                                            unsigned poll_interval, 
     34+                                            unsigned nbuttons, 
     35+                                            struct gpio_keys_button *buttons) 
    1136+{ 
    12 +       .name = "gpio-buttons", 
    13 +       .id = 0, 
    14 +       .dev = { 
    15 +               .platform_data = (void *) &ltq_gpio_buttons_platform_data, 
    16 +       }, 
    17 +}; 
     37+       struct platform_device *pdev; 
     38+       struct gpio_keys_platform_data pdata; 
     39+       struct gpio_keys_button *p; 
     40+       int err; 
    1841+ 
    19 +void __init 
    20 +ltq_register_gpio_buttons(struct gpio_button *buttons, int cnt) 
    21 +{ 
    22 +       ltq_gpio_buttons_platform_data.buttons = buttons; 
    23 +       ltq_gpio_buttons_platform_data.nbuttons = cnt; 
    24 +       platform_device_register(&ltq_gpio_buttons_platform_device); 
     42+       p = kmalloc(nbuttons * sizeof(*p), GFP_KERNEL); 
     43+       if (!p) 
     44+               return; 
     45+ 
     46+       memcpy(p, buttons, nbuttons * sizeof(*p)); 
     47+ 
     48+       pdev = platform_device_alloc("gpio-keys-polled", id); 
     49+       if (!pdev) 
     50+               goto err_free_buttons; 
     51+ 
     52+       memset(&pdata, 0, sizeof(pdata)); 
     53+       pdata.poll_interval = poll_interval; 
     54+       pdata.nbuttons = nbuttons; 
     55+       pdata.buttons = p; 
     56+ 
     57+       err = platform_device_add_data(pdev, &pdata, sizeof(pdata)); 
     58+       if (err) 
     59+               goto err_put_pdev; 
     60+ 
     61+       err = platform_device_add(pdev); 
     62+       if (err) 
     63+               goto err_put_pdev; 
     64+ 
     65+       return; 
     66+ 
     67+err_put_pdev: 
     68+       platform_device_put(pdev); 
     69+ 
     70+err_free_buttons: 
     71+       kfree(p); 
    2572+} 
     73--- /dev/null 
     74+++ b/arch/mips/lantiq/dev-gpio-buttons.h 
     75@@ -0,0 +1,26 @@ 
     76+/* 
     77+ *  Lantiq GPIO button support 
     78+ * 
     79+ *  Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org> 
     80+ *  Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org> 
     81+ * 
     82+ *  This program is free software; you can redistribute it and/or modify it 
     83+ *  under the terms of the GNU General Public License version 2 as published 
     84+ *  by the Free Software Foundation. 
     85+ */ 
    2686+ 
    27  static struct resource ltq_spi_resources[] = { 
    28         { 
    29                 .start  = LTQ_SSC_BASE_ADDR, 
    30 --- a/arch/mips/lantiq/xway/devices.h 
    31 +++ b/arch/mips/lantiq/xway/devices.h 
    32 @@ -11,6 +11,7 @@ 
    33   
    34  #include "../devices.h" 
    35  #include <linux/phy.h> 
    36 +#include <linux/gpio_buttons.h> 
    37   
    38  extern void ltq_register_gpio(void); 
    39  extern void ltq_register_gpio_stp(void); 
    40 @@ -18,5 +19,6 @@ extern void ltq_register_ase_asc(void); 
    41  extern void ltq_register_etop(struct ltq_eth_data *eth); 
    42  extern void ltq_register_gpio_ebu(unsigned int value); 
    43  extern void ltq_register_madwifi_eep(void); 
    44 +extern void ltq_register_gpio_buttons(struct gpio_button *buttons, int cnt); 
    45   
    46  #endif 
     87+#ifndef _LANTIQ_DEV_GPIO_BUTTONS_H 
     88+#define _LANTIQ_DEV_GPIO_BUTTONS_H 
     89+ 
     90+#include <linux/input.h> 
     91+#include <linux/gpio_keys.h> 
     92+ 
     93+#define LTQ_KEYS_POLL_INTERVAL         20 /* msecs */ 
     94+#define LTQ_KEYS_DEBOUNCE_INTERVAL     (3 * LTQ_KEYS_POLL_INTERVAL) 
     95+ 
     96+void ltq_register_gpio_keys_polled(int id, 
     97+                                     unsigned poll_interval, 
     98+                                     unsigned nbuttons, 
     99+                                     struct gpio_keys_button *buttons); 
     100+ 
     101+#endif /* _LANTIQ_DEV_GPIO_BUTTONS_H */ 
  • trunk/target/linux/lantiq/patches-2.6.39/530-register_tapi.patch

    r27104 r27665  
    3333--- a/arch/mips/lantiq/xway/mach-easy50712.c 
    3434+++ b/arch/mips/lantiq/xway/mach-easy50712.c 
    35 @@ -66,6 +66,7 @@ static void __init easy50712_init(void) 
     35@@ -61,6 +61,7 @@ static void __init easy50712_init(void) 
    3636        ltq_register_nor(&easy50712_flash_data); 
    3737        ltq_register_pci(&ltq_pci_data); 
  • trunk/target/linux/lantiq/patches-2.6.39/550-dwc_otg.patch

    r27104 r27665  
    1561415614--- a/drivers/usb/core/hub.c 
    1561515615+++ b/drivers/usb/core/hub.c 
    15616 @@ -2812,11 +2812,11 @@ hub_port_init (struct usb_hub *hub, stru 
     15616@@ -2814,11 +2814,11 @@ hub_port_init (struct usb_hub *hub, stru 
    1561715617                udev->ttport = hdev->ttport; 
    1561815618        } else if (udev->speed != USB_SPEED_HIGH 
  • trunk/target/linux/lantiq/patches-2.6.39/560-dev-leds-gpio.patch

    r27026 r27665  
    8989 # by the Free Software Foundation. 
    9090  
    91 -obj-y := irq.o setup.o clk.o prom.o devices.o 
    92 +obj-y := irq.o setup.o clk.o prom.o devices.o dev-leds-gpio.o 
     91-obj-y := irq.o setup.o clk.o prom.o devices.o dev-gpio-buttons.o 
     92+obj-y := irq.o setup.o clk.o prom.o devices.o dev-gpio-buttons.o dev-leds-gpio.o 
    9393  
    9494 obj-$(CONFIG_EARLY_PRINTK) += early_printk.o 
  • trunk/target/linux/lantiq/patches-2.6.39/600-mach-dgn3500.patch

    r27158 r27665  
    11--- a/arch/mips/lantiq/machtypes.h 
    22+++ b/arch/mips/lantiq/machtypes.h 
    3 @@ -32,6 +32,9 @@ 
     3@@ -34,6 +34,9 @@ enum lantiq_mach_type { 
    44        LANTIQ_MACH_ARV752DPW,          /* Arcor easybox a802 */ 
    55        LANTIQ_MACH_ARV752DPW22,        /* Arcor easybox a803 */ 
     
    1313--- a/arch/mips/lantiq/xway/Kconfig 
    1414+++ b/arch/mips/lantiq/xway/Kconfig 
    15 @@ -10,6 +10,10 @@ 
     15@@ -10,6 +10,10 @@ config LANTIQ_MACH_ARV45XX 
    1616        bool "ARV45XX" 
    1717        default y 
     
    2626--- a/arch/mips/lantiq/xway/Makefile 
    2727+++ b/arch/mips/lantiq/xway/Makefile 
    28 @@ -6,4 +6,5 @@ 
     28@@ -6,4 +6,5 @@ obj-$(CONFIG_SOC_AMAZON_SE) += clk-ase.o 
    2929 obj-$(CONFIG_LANTIQ_MACH_EASY50712) += mach-easy50712.o 
    3030 obj-$(CONFIG_LANTIQ_MACH_EASY50601) += mach-easy50601.o 
     
    3434--- a/arch/mips/lantiq/xway/devices.h 
    3535+++ b/arch/mips/lantiq/xway/devices.h 
    36 @@ -12,6 +12,7 @@ 
     36@@ -11,6 +11,7 @@ 
     37  
    3738 #include "../devices.h" 
    3839 #include <linux/phy.h> 
    39  #include <linux/gpio_buttons.h> 
    4040+#include <linux/spi/spi.h> 
    4141  
    4242 extern void ltq_register_gpio(void); 
    4343 extern void ltq_register_gpio_stp(void); 
    44 @@ -20,5 +21,7 @@ 
     44@@ -18,5 +19,7 @@ extern void ltq_register_ase_asc(void); 
     45 extern void ltq_register_etop(struct ltq_eth_data *eth); 
    4546 extern void ltq_register_gpio_ebu(unsigned int value); 
    46  extern void ltq_register_madwifi_eep(void); 
    47  extern void ltq_register_gpio_buttons(struct gpio_button *buttons, int cnt); 
     47 extern void ltq_register_madwifi_eep(unsigned long long addr); 
    4848+extern void ltq_register_spi(struct ltq_spi_platform_data *pdata, 
    4949+               struct spi_board_info const *info, unsigned n); 
  • trunk/target/linux/lantiq/patches-2.6.39/601-mach-gigasx76x.patch

    r27158 r27665  
    11--- a/arch/mips/lantiq/xway/Kconfig 
    22+++ b/arch/mips/lantiq/xway/Kconfig 
    3 @@ -14,6 +14,10 @@ 
     3@@ -14,6 +14,11 @@ config LANTIQ_MACH_NETGEAR 
    44        bool "Netgear" 
    55        default y 
     
    77+config LANTIQ_MACH_GIGASX76X 
    88+       bool "GIGASX76X" 
     9+       select LTQ_DEV_GPIO_BUTTONS 
    910+       default y 
    1011+ 
     
    1415--- a/arch/mips/lantiq/xway/Makefile 
    1516+++ b/arch/mips/lantiq/xway/Makefile 
    16 @@ -7,4 +7,5 @@ 
     17@@ -7,4 +7,5 @@ obj-$(CONFIG_LANTIQ_MACH_EASY50712) += m 
    1718 obj-$(CONFIG_LANTIQ_MACH_EASY50601) += mach-easy50601.o 
    1819 obj-$(CONFIG_LANTIQ_MACH_ARV45XX) += mach-arv45xx.o 
     
    2223--- /dev/null 
    2324+++ b/arch/mips/lantiq/xway/mach-gigasx76x.c 
    24 @@ -0,0 +1,113 @@ 
     25@@ -0,0 +1,209 @@ 
    2526+/* 
    2627+ *  This program is free software; you can redistribute it and/or modify it 
     
    3334+ */ 
    3435+ 
     36+#include <linux/kernel.h> 
    3537+#include <linux/init.h> 
    3638+#include <linux/platform_device.h> 
    3739+#include <linux/leds.h> 
    3840+#include <linux/gpio.h> 
    39 +#include <linux/gpio_buttons.h> 
    4041+#include <linux/mtd/mtd.h> 
    4142+#include <linux/mtd/partitions.h> 
     
    4546+#include <linux/pci.h> 
    4647+#include <linux/phy.h> 
     48+#include <linux/io.h> 
     49+#include <linux/string.h> 
    4750+ 
    4851+#include <irq.h> 
     
    5154+#include <lantiq_platform.h> 
    5255+ 
    53 +#include "../machtypes.h" 
    5456+#include "devices.h" 
    5557+#include "dev-dwc_otg.h" 
    56 +#include "dev-leds-gpio.h" 
     58+#include "../machtypes.h" 
     59+#include "../dev-leds-gpio.h" 
     60+#include "../dev-gpio-buttons.h" 
     61+ 
     62+#define UBOOT_ENV_OFFSET       0x010000 
     63+#define UBOOT_ENV_SIZE         0x010000 
    5764+ 
    5865+#ifdef CONFIG_MTD_PARTITIONS 
     
    6067+{ 
    6168+       { 
    62 +               .name   = "secondary_env", 
    63 +               .offset = 0xe000, 
    64 +               .size   = 0x2000, 
    65 +       }, 
    66 +       { 
    67 +               .name   = "secondary_boot", 
    68 +               .offset = 0x10000, 
    69 +               .size   = 0x10000, 
    70 +       }, 
    71 +       { 
    7269+               .name   = "uboot", 
    73 +               .offset = 0x20000, 
    74 +               .size   = 0x30000, 
     70+               .offset = 0x000000, 
     71+               .size   = 0x010000, 
     72+       }, 
     73+       { 
     74+               .name   = "uboot_env", 
     75+               .offset = UBOOT_ENV_OFFSET, 
     76+               .size   = UBOOT_ENV_SIZE, 
    7577+       }, 
    7678+       { 
    7779+               .name   = "linux", 
    78 +               .offset = 0x50000, 
    79 +               .size   = 0x7a0000, 
     80+               .offset = 0x020000, 
     81+               .size   = 0x7d0000, 
    8082+       }, 
    8183+       { 
    8284+               .name   = "board_config", 
    8385+               .offset = 0x7f0000, 
    84 +               .size   = 0x10000, 
     86+               .size   = 0x010000, 
    8587+       }, 
    8688+}; 
     
    8890+ 
    8991+static struct gpio_led 
    90 +gigasx76x_leds_gpio[] __initdata = { 
     92+gigasx76x_gpio_leds[] __initdata = { 
    9193+       { .name = "soc:green:usb", .gpio = 50, }, 
    9294+       { .name = "soc:green:wlan", .gpio = 51, }, 
     
    9597+       { .name = "soc:green:line", .gpio = 54, }, 
    9698+       { .name = "soc:green:online", .gpio = 55, }, 
    97 +}; 
    98 + 
     99+       { .name = "soc:green:voip", .gpio = 56, }, 
     100+}; 
     101+ 
     102+static struct gpio_keys_button 
     103+gigasx76x_gpio_keys[] __initdata = { 
     104+               { 
     105+                       .desc           = "reset", 
     106+                       .type           = EV_KEY, 
     107+                       .code           = KEY_RESTART, 
     108+                       .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, 
     109+                       .gpio = 14, 
     110+                       .active_low = 1, 
     111+               }, 
     112+}; 
    99113+ 
    100114+static struct physmap_flash_data gigasx76x_flash_data = { 
     
    106120+ 
    107121+static struct ltq_pci_data ltq_pci_data = { 
    108 +       .clock      = PCI_CLOCK_INT, 
    109 +       .gpio   = PCI_GNT1 | PCI_REQ1, 
    110 +       .irq    = { 
    111 +               [14] = INT_NUM_IM0_IRL0 + 22, 
    112 +       }, 
     122+       .clock  = PCI_CLOCK_INT, 
     123+       .gpio   = PCI_GNT1 | PCI_REQ1, 
     124+       .irq    = { [14] = INT_NUM_IM0_IRL0 + 22, }, 
    113125+}; 
    114126+ 
    115127+static struct ltq_eth_data ltq_eth_data = { 
    116 +  .mii_mode = PHY_INTERFACE_MODE_MII, 
    117 +}; 
    118 + 
    119 +static void __init 
    120 +gigasx76x_init(void) 
    121 +{ 
    122 +#define GIGASX76X_USB                  29 
     128+  .mii_mode    = PHY_INTERFACE_MODE_MII, 
     129+}; 
     130+ 
     131+static char __init *get_uboot_env_var(char *haystack, int haystack_len, char *needle, int needle_len) { 
     132+       int i; 
     133+       for (i = 0; i <= haystack_len - needle_len; i++) { 
     134+               if (memcmp(haystack + i, needle, needle_len) == 0) { 
     135+                       return haystack + i + needle_len; 
     136+               } 
     137+       } 
     138+       return NULL; 
     139+} 
     140+ 
     141+/* 
     142+ * gigasx76x_parse_hex_* are not uniq. in arm/orion there are also duplicates: 
     143+ * dns323_parse_hex_* 
     144+ * TODO: one day write a patch for this :) 
     145+ */ 
     146+static int __init gigasx76x_parse_hex_nibble(char n) { 
     147+       if (n >= '0' && n <= '9') 
     148+               return n - '0'; 
     149+ 
     150+       if (n >= 'A' && n <= 'F') 
     151+               return n - 'A' + 10; 
     152+ 
     153+       if (n >= 'a' && n <= 'f') 
     154+               return n - 'a' + 10; 
     155+ 
     156+       return -1; 
     157+} 
     158+ 
     159+static int __init gigasx76x_parse_hex_byte(const char *b) { 
     160+       int hi; 
     161+       int lo; 
     162+ 
     163+       hi = gigasx76x_parse_hex_nibble(b[0]); 
     164+       lo = gigasx76x_parse_hex_nibble(b[1]); 
     165+ 
     166+       if (hi < 0 || lo < 0) 
     167+               return -1; 
     168+ 
     169+       return (hi << 4) | lo; 
     170+} 
     171+ 
     172+static int __init gigasx76x_register_ethernet(void) { 
     173+       u_int8_t addr[6]; 
     174+       int i; 
     175+       char *uboot_env_page; 
     176+       char *mac; 
     177+ 
     178+       uboot_env_page = ioremap(LTQ_FLASH_START + UBOOT_ENV_OFFSET, UBOOT_ENV_SIZE); 
     179+       if (!uboot_env_page) 
     180+               return -ENOMEM; 
     181+ 
     182+       mac = get_uboot_env_var(uboot_env_page, UBOOT_ENV_SIZE, "\0ethaddr=", 9); 
     183+ 
     184+       if (!mac) { 
     185+       goto error_fail; 
     186+       } 
     187+ 
     188+       /* Sanity check the string we're looking at */ 
     189+       for (i = 0; i < 5; i++) { 
     190+       if (*(mac + (i * 3) + 2) != ':') { 
     191+               goto error_fail; 
     192+               } 
     193+       } 
     194+ 
     195+       for (i = 0; i < 6; i++) { 
     196+               int byte; 
     197+               byte = gigasx76x_parse_hex_byte(mac + (i * 3)); 
     198+               if (byte < 0) { 
     199+                       goto error_fail; 
     200+               } 
     201+               addr[i] = byte; 
     202+       } 
     203+ 
     204+       iounmap(uboot_env_page); 
     205+       printk("GIGASX76X: Found ethernet MAC address: "); 
     206+       for (i = 0; i < 6; i++) 
     207+               printk("%.2x%s", addr[i], (i < 5) ? ":" : ".\n"); 
     208+ 
     209+       memcpy(&ltq_eth_data.mac.sa_data, addr, 6); 
     210+       ltq_register_etop(&ltq_eth_data); 
     211+ 
     212+       return 0; 
     213+ 
     214+       error_fail: 
     215+               iounmap(uboot_env_page); 
     216+               return -EINVAL; 
     217+} 
     218+ 
     219+static void __init gigasx76x_init(void) { 
     220+#define GIGASX76X_USB          29 
     221+#define GIGASX76X_MADWIFI_ADDR 0xb07f0000 
    123222+ 
    124223+       ltq_register_gpio_stp(); 
    125224+       ltq_register_nor(&gigasx76x_flash_data); 
    126225+       ltq_register_pci(&ltq_pci_data); 
    127 +       ltq_register_etop(&ltq_eth_data); 
     226+       gigasx76x_register_ethernet(); 
    128227+       xway_register_dwc(GIGASX76X_USB); 
    129228+       ltq_register_tapi(); 
    130 +       ltq_register_madwifi_eep(); 
    131 +       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(gigasx76x_leds_gpio), gigasx76x_leds_gpio); 
    132 +} 
    133 + 
    134 +MIPS_MACHINE(LANTIQ_MACH_GIGASX76X, 
    135 +                       "GIGASX76X", 
    136 +                       "GIGASX76X - Gigaset SX761,SX762,SX763", 
    137 +                       gigasx76x_init); 
     229+       ltq_register_madwifi_eep(GIGASX76X_MADWIFI_ADDR); 
     230+       ltq_add_device_leds_gpio(-1, ARRAY_SIZE(gigasx76x_gpio_leds), gigasx76x_gpio_leds); 
     231+       ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(gigasx76x_gpio_keys), gigasx76x_gpio_keys); 
     232+} 
     233+ 
     234+MIPS_MACHINE(LANTIQ_MACH_GIGASX76X, "GIGASX76X", "GIGASX76X - Gigaset SX761,SX762,SX763", gigasx76x_init); 
    138235--- a/arch/mips/lantiq/machtypes.h 
    139236+++ b/arch/mips/lantiq/machtypes.h 
    140 @@ -35,6 +35,9 @@ 
     237@@ -37,6 +37,9 @@ enum lantiq_mach_type { 
    141238  
    142239        /* Netgear */ 
Note: See TracChangeset for help on using the changeset viewer.