aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch
diff options
context:
space:
mode:
authorJohn Crispin <john@openwrt.org>2014-12-14 08:57:52 +0000
committerJohn Crispin <john@openwrt.org>2014-12-14 08:57:52 +0000
commit374ab9deccbb1ea0b92b3c14c7a4103b7eac49cd (patch)
treeac5c4576c973aac3e890e2049b8eb2540c37a2a4 /target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch
parentfef7b4241fc3af9e693cce4ada2d1a3ed0587eeb (diff)
downloadupstream-374ab9deccbb1ea0b92b3c14c7a4103b7eac49cd.tar.gz
upstream-374ab9deccbb1ea0b92b3c14c7a4103b7eac49cd.tar.bz2
upstream-374ab9deccbb1ea0b92b3c14c7a4103b7eac49cd.zip
gemini: update usb driver and merge registers into one patch
Signed-off-by: Roman Yeryomin <roman@advem.lv> SVN-Revision: 43703
Diffstat (limited to 'target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch')
-rw-r--r--target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch65
1 files changed, 65 insertions, 0 deletions
diff --git a/target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch b/target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch
new file mode 100644
index 0000000000..87a063cbe2
--- /dev/null
+++ b/target/linux/gemini/patches-3.10/132-arm-gemini-register-usb.patch
@@ -0,0 +1,65 @@
+--- a/arch/arm/mach-gemini/board-wbd111.c
++++ b/arch/arm/mach-gemini/board-wbd111.c
+@@ -145,6 +145,7 @@ static void __init wbd111_init(void)
+ platform_register_watchdog();
+ platform_device_register(&wbd111_phy_device);
+ platform_register_ethernet(&gmac_data);
++ platform_register_usb(0);
+ }
+
+ MACHINE_START(WBD111, "Wiliboard WBD-111")
+--- a/arch/arm/mach-gemini/board-wbd222.c
++++ b/arch/arm/mach-gemini/board-wbd222.c
+@@ -147,6 +147,7 @@ static void __init wbd222_init(void)
+ platform_register_watchdog();
+ platform_device_register(&wbd222_phy_device);
+ platform_register_ethernet(&gmac_data);
++ platform_register_usb(0);
+ }
+
+ MACHINE_START(WBD222, "Wiliboard WBD-222")
+--- a/arch/arm/mach-gemini/board-rut1xx.c
++++ b/arch/arm/mach-gemini/board-rut1xx.c
+@@ -105,6 +105,7 @@ static void __init rut1xx_init(void)
+ platform_register_watchdog();
+ platform_device_register(&rut1xx_phy_device);
+ platform_register_ethernet(&gmac_data);
++ platform_register_usb(0);
+ }
+
+ MACHINE_START(RUT100, "Teltonika RUT100")
+--- a/arch/arm/mach-gemini/board-nas4220b.c
++++ b/arch/arm/mach-gemini/board-nas4220b.c
+@@ -134,10 +134,23 @@
+ GLOBAL_ARBITRATION1_CTRL));
+ }
+
++static void __init usb_ib4220b_init(void)
++{
++ unsigned int val;
++
++ val = readl((void __iomem*)(IO_ADDRESS(GEMINI_GLOBAL_BASE) +
++ GLOBAL_MISC_CTRL));
++ val &= ~(USB0_PLUG_MINIB | USB1_PLUG_MINIB);
++ val |= USB0_VBUS_ON | USB1_VBUS_ON;
++ writel(val, (void __iomem*)(IO_ADDRESS(GEMINI_GLOBAL_BASE) +
++ GLOBAL_MISC_CTRL));
++}
++
+ static void __init ib4220b_init(void)
+ {
+ gemini_gpio_init();
+ ib4220b_gmac_init();
++ usb_ib4220b_init();
+ platform_register_uart();
+ platform_register_pflash(SZ_16M, NULL, 0);
+ platform_device_register(&ib4220b_led_device);
+@@ -168,6 +168,8 @@ static void __init ib4220b_init(void)
+ platform_register_watchdog();
+ platform_device_register(&ib4220b_phy_device);
+ platform_register_ethernet(&ib4220b_gmac_data);
++ platform_register_usb(0);
++ platform_register_usb(1);
+ }
+
+ MACHINE_START(NAS4220B, "Raidsonic NAS IB-4220-B")