summaryrefslogtreecommitdiffstats
path: root/target/linux/gemini/patches-4.1/132-arm-gemini-register-usb.patch
diff options
context:
space:
mode:
authorJohn Crispin <john@openwrt.org>2015-07-14 07:43:10 +0000
committerJohn Crispin <john@openwrt.org>2015-07-14 07:43:10 +0000
commitd5d3b5e49cf7f7ea8c46605236cbe06eaa850d42 (patch)
treef9d68e440f707d5ee0cd3015f8bf542650735ee1 /target/linux/gemini/patches-4.1/132-arm-gemini-register-usb.patch
parent023b0e0b38e9a6a9f30d04576ad665ac053b3661 (diff)
downloadmaster-31e0f0ae-d5d3b5e49cf7f7ea8c46605236cbe06eaa850d42.tar.gz
master-31e0f0ae-d5d3b5e49cf7f7ea8c46605236cbe06eaa850d42.tar.bz2
master-31e0f0ae-d5d3b5e49cf7f7ea8c46605236cbe06eaa850d42.zip
gemini: add 4.1 support
Signed-off-by: Roman Yeryomin <roman@advem.lv> SVN-Revision: 46353
Diffstat (limited to 'target/linux/gemini/patches-4.1/132-arm-gemini-register-usb.patch')
-rw-r--r--target/linux/gemini/patches-4.1/132-arm-gemini-register-usb.patch65
1 files changed, 65 insertions, 0 deletions
diff --git a/target/linux/gemini/patches-4.1/132-arm-gemini-register-usb.patch b/target/linux/gemini/patches-4.1/132-arm-gemini-register-usb.patch
new file mode 100644
index 0000000000..2a61d828ea
--- /dev/null
+++ b/target/linux/gemini/patches-4.1/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 @@ static void __init ib4220b_gmac_init(voi
+ 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);
+@@ -146,6 +159,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")