diff options
author | Neil Zhang <zhangwm@marvell.com> | 2012-05-03 02:19:15 -0400 |
---|---|---|
committer | Haojian Zhuang <haojian.zhuang@gmail.com> | 2012-05-03 03:06:05 -0400 |
commit | 161105bcb82a5df88f7594cb3b036ec13c6df626 (patch) | |
tree | cb8e5bbee7187b60df1785d724b71894f4e94bc2 /arch/arm/mach-mmp/pxa168.c | |
parent | 673eef981436ffb015f491e2c58b83b2015ed878 (diff) |
ARM: mmp: add usb host support for PXA168
The ehci-mv can support PXA168, PXA910 and PXA920, use this driver to
support pxa168 SPH usb.
Signed-off-by: Neil Zhang <zhangwm@marvell.com>
Signed-off-by: Haojian Zhuang <haojian.zhuang@gmail.com>
Diffstat (limited to 'arch/arm/mach-mmp/pxa168.c')
-rw-r--r-- | arch/arm/mach-mmp/pxa168.c | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/arch/arm/mach-mmp/pxa168.c b/arch/arm/mach-mmp/pxa168.c index b24d2c32cba9..62d787c34475 100644 --- a/arch/arm/mach-mmp/pxa168.c +++ b/arch/arm/mach-mmp/pxa168.c | |||
@@ -14,6 +14,7 @@ | |||
14 | #include <linux/io.h> | 14 | #include <linux/io.h> |
15 | #include <linux/clk.h> | 15 | #include <linux/clk.h> |
16 | #include <linux/platform_device.h> | 16 | #include <linux/platform_device.h> |
17 | #include <linux/platform_data/mv_usb.h> | ||
17 | 18 | ||
18 | #include <asm/mach/time.h> | 19 | #include <asm/mach/time.h> |
19 | #include <asm/system_misc.h> | 20 | #include <asm/system_misc.h> |
@@ -27,6 +28,7 @@ | |||
27 | #include <mach/mfp.h> | 28 | #include <mach/mfp.h> |
28 | #include <linux/dma-mapping.h> | 29 | #include <linux/dma-mapping.h> |
29 | #include <mach/pxa168.h> | 30 | #include <mach/pxa168.h> |
31 | #include <mach/regs-usb.h> | ||
30 | 32 | ||
31 | #include "common.h" | 33 | #include "common.h" |
32 | #include "clock.h" | 34 | #include "clock.h" |
@@ -93,7 +95,7 @@ static struct clk_lookup pxa168_clkregs[] = { | |||
93 | INIT_CLKREG(&clk_gpio, "pxa-gpio", NULL), | 95 | INIT_CLKREG(&clk_gpio, "pxa-gpio", NULL), |
94 | INIT_CLKREG(&clk_keypad, "pxa27x-keypad", NULL), | 96 | INIT_CLKREG(&clk_keypad, "pxa27x-keypad", NULL), |
95 | INIT_CLKREG(&clk_eth, "pxa168-eth", "MFUCLK"), | 97 | INIT_CLKREG(&clk_eth, "pxa168-eth", "MFUCLK"), |
96 | INIT_CLKREG(&clk_usb, "pxa168-ehci", "PXA168-USBCLK"), | 98 | INIT_CLKREG(&clk_usb, NULL, "PXA168-USBCLK"), |
97 | INIT_CLKREG(&clk_rtc, "sa1100-rtc", NULL), | 99 | INIT_CLKREG(&clk_rtc, "sa1100-rtc", NULL), |
98 | }; | 100 | }; |
99 | 101 | ||
@@ -184,17 +186,17 @@ struct platform_device pxa168_device_gpio = { | |||
184 | struct resource pxa168_usb_host_resources[] = { | 186 | struct resource pxa168_usb_host_resources[] = { |
185 | /* USB Host conroller register base */ | 187 | /* USB Host conroller register base */ |
186 | [0] = { | 188 | [0] = { |
187 | .start = 0xd4209000, | 189 | .start = PXA168_U2H_REGBASE + U2x_CAPREGS_OFFSET, |
188 | .end = 0xd4209000 + 0x200, | 190 | .end = PXA168_U2H_REGBASE + USB_REG_RANGE, |
189 | .flags = IORESOURCE_MEM, | 191 | .flags = IORESOURCE_MEM, |
190 | .name = "pxa168-usb-host", | 192 | .name = "capregs", |
191 | }, | 193 | }, |
192 | /* USB PHY register base */ | 194 | /* USB PHY register base */ |
193 | [1] = { | 195 | [1] = { |
194 | .start = 0xd4206000, | 196 | .start = PXA168_U2H_PHYBASE, |
195 | .end = 0xd4206000 + 0xff, | 197 | .end = PXA168_U2H_PHYBASE + USB_PHY_RANGE, |
196 | .flags = IORESOURCE_MEM, | 198 | .flags = IORESOURCE_MEM, |
197 | .name = "pxa168-usb-phy", | 199 | .name = "phyregs", |
198 | }, | 200 | }, |
199 | [2] = { | 201 | [2] = { |
200 | .start = IRQ_PXA168_USB2, | 202 | .start = IRQ_PXA168_USB2, |
@@ -205,7 +207,7 @@ struct resource pxa168_usb_host_resources[] = { | |||
205 | 207 | ||
206 | static u64 pxa168_usb_host_dmamask = DMA_BIT_MASK(32); | 208 | static u64 pxa168_usb_host_dmamask = DMA_BIT_MASK(32); |
207 | struct platform_device pxa168_device_usb_host = { | 209 | struct platform_device pxa168_device_usb_host = { |
208 | .name = "pxa168-ehci", | 210 | .name = "pxa-sph", |
209 | .id = -1, | 211 | .id = -1, |
210 | .dev = { | 212 | .dev = { |
211 | .dma_mask = &pxa168_usb_host_dmamask, | 213 | .dma_mask = &pxa168_usb_host_dmamask, |
@@ -216,7 +218,7 @@ struct platform_device pxa168_device_usb_host = { | |||
216 | .resource = pxa168_usb_host_resources, | 218 | .resource = pxa168_usb_host_resources, |
217 | }; | 219 | }; |
218 | 220 | ||
219 | int __init pxa168_add_usb_host(struct pxa168_usb_pdata *pdata) | 221 | int __init pxa168_add_usb_host(struct mv_usb_platform_data *pdata) |
220 | { | 222 | { |
221 | pxa168_device_usb_host.dev.platform_data = pdata; | 223 | pxa168_device_usb_host.dev.platform_data = pdata; |
222 | return platform_device_register(&pxa168_device_usb_host); | 224 | return platform_device_register(&pxa168_device_usb_host); |