diff options
author | Kuninori Morimoto <morimoto.kuninori@renesas.com> | 2009-08-26 07:04:31 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-08-26 22:36:09 -0400 |
commit | 907050a33d3b6a9f37e2ceca764b60f8e3922466 (patch) | |
tree | 0fa7772db97ee69a354d77c93dfddbc548bad7d9 /arch/sh | |
parent | 35a35408914bcd22dbaeea710ec1e711b673b59e (diff) |
sh: Add USB support for EcoVec24
Signed-off-by: Kuninori Morimoto <morimoto.kuninori@renesas.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh')
-rw-r--r-- | arch/sh/boards/mach-ecovec24/setup.c | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/arch/sh/boards/mach-ecovec24/setup.c b/arch/sh/boards/mach-ecovec24/setup.c index 8c0c8453d089..7850818bb4e8 100644 --- a/arch/sh/boards/mach-ecovec24/setup.c +++ b/arch/sh/boards/mach-ecovec24/setup.c | |||
@@ -16,6 +16,7 @@ | |||
16 | #include <linux/interrupt.h> | 16 | #include <linux/interrupt.h> |
17 | #include <linux/io.h> | 17 | #include <linux/io.h> |
18 | #include <linux/delay.h> | 18 | #include <linux/delay.h> |
19 | #include <linux/usb/r8a66597.h> | ||
19 | #include <asm/heartbeat.h> | 20 | #include <asm/heartbeat.h> |
20 | #include <asm/sh_eth.h> | 21 | #include <asm/sh_eth.h> |
21 | #include <cpu/sh7724.h> | 22 | #include <cpu/sh7724.h> |
@@ -126,10 +127,96 @@ static struct platform_device sh_eth_device = { | |||
126 | .resource = sh_eth_resources, | 127 | .resource = sh_eth_resources, |
127 | }; | 128 | }; |
128 | 129 | ||
130 | /* USB0 host */ | ||
131 | void usb0_port_power(int port, int power) | ||
132 | { | ||
133 | gpio_set_value(GPIO_PTB4, power); | ||
134 | } | ||
135 | |||
136 | static struct r8a66597_platdata usb0_host_data = { | ||
137 | .on_chip = 1, | ||
138 | .port_power = usb0_port_power, | ||
139 | }; | ||
140 | |||
141 | static struct resource usb0_host_resources[] = { | ||
142 | [0] = { | ||
143 | .start = 0xa4d80000, | ||
144 | .end = 0xa4d80124 - 1, | ||
145 | .flags = IORESOURCE_MEM, | ||
146 | }, | ||
147 | [1] = { | ||
148 | .start = 65, | ||
149 | .end = 65, | ||
150 | .flags = IORESOURCE_IRQ | IRQF_TRIGGER_LOW, | ||
151 | }, | ||
152 | }; | ||
153 | |||
154 | static struct platform_device usb0_host_device = { | ||
155 | .name = "r8a66597_hcd", | ||
156 | .id = 0, | ||
157 | .dev = { | ||
158 | .dma_mask = NULL, /* not use dma */ | ||
159 | .coherent_dma_mask = 0xffffffff, | ||
160 | .platform_data = &usb0_host_data, | ||
161 | }, | ||
162 | .num_resources = ARRAY_SIZE(usb0_host_resources), | ||
163 | .resource = usb0_host_resources, | ||
164 | }; | ||
165 | |||
166 | /* | ||
167 | * USB1 | ||
168 | * | ||
169 | * CN5 can use both host/function, | ||
170 | * and we can determine it by checking PTB[3] | ||
171 | * | ||
172 | * This time only USB1 host is supported. | ||
173 | */ | ||
174 | void usb1_port_power(int port, int power) | ||
175 | { | ||
176 | if (!gpio_get_value(GPIO_PTB3)) { | ||
177 | printk(KERN_ERR "USB1 function is not supported\n"); | ||
178 | return; | ||
179 | } | ||
180 | |||
181 | gpio_set_value(GPIO_PTB5, power); | ||
182 | } | ||
183 | |||
184 | static struct r8a66597_platdata usb1_host_data = { | ||
185 | .on_chip = 1, | ||
186 | .port_power = usb1_port_power, | ||
187 | }; | ||
188 | |||
189 | static struct resource usb1_host_resources[] = { | ||
190 | [0] = { | ||
191 | .start = 0xa4d90000, | ||
192 | .end = 0xa4d90124 - 1, | ||
193 | .flags = IORESOURCE_MEM, | ||
194 | }, | ||
195 | [1] = { | ||
196 | .start = 66, | ||
197 | .end = 66, | ||
198 | .flags = IORESOURCE_IRQ | IRQF_TRIGGER_LOW, | ||
199 | }, | ||
200 | }; | ||
201 | |||
202 | static struct platform_device usb1_host_device = { | ||
203 | .name = "r8a66597_hcd", | ||
204 | .id = 1, | ||
205 | .dev = { | ||
206 | .dma_mask = NULL, /* not use dma */ | ||
207 | .coherent_dma_mask = 0xffffffff, | ||
208 | .platform_data = &usb1_host_data, | ||
209 | }, | ||
210 | .num_resources = ARRAY_SIZE(usb1_host_resources), | ||
211 | .resource = usb1_host_resources, | ||
212 | }; | ||
213 | |||
129 | static struct platform_device *ecovec_devices[] __initdata = { | 214 | static struct platform_device *ecovec_devices[] __initdata = { |
130 | &heartbeat_device, | 215 | &heartbeat_device, |
131 | &nor_flash_device, | 216 | &nor_flash_device, |
132 | &sh_eth_device, | 217 | &sh_eth_device, |
218 | &usb0_host_device, | ||
219 | &usb1_host_device, /* USB1 host support */ | ||
133 | }; | 220 | }; |
134 | 221 | ||
135 | static int __init devices_setup(void) | 222 | static int __init devices_setup(void) |
@@ -165,6 +252,16 @@ static int __init devices_setup(void) | |||
165 | gpio_request(GPIO_FN_MDC, NULL); | 252 | gpio_request(GPIO_FN_MDC, NULL); |
166 | gpio_request(GPIO_FN_LNKSTA, NULL); | 253 | gpio_request(GPIO_FN_LNKSTA, NULL); |
167 | 254 | ||
255 | /* enable USB */ | ||
256 | gpio_request(GPIO_PTB3, NULL); | ||
257 | gpio_request(GPIO_PTB4, NULL); | ||
258 | gpio_request(GPIO_PTB5, NULL); | ||
259 | gpio_direction_input(GPIO_PTB3); | ||
260 | gpio_direction_output(GPIO_PTB4, 0); | ||
261 | gpio_direction_output(GPIO_PTB5, 0); | ||
262 | ctrl_outw(0x0600, 0xa40501d4); | ||
263 | ctrl_outw(0x0600, 0xa4050192); | ||
264 | |||
168 | return platform_add_devices(ecovec_devices, | 265 | return platform_add_devices(ecovec_devices, |
169 | ARRAY_SIZE(ecovec_devices)); | 266 | ARRAY_SIZE(ecovec_devices)); |
170 | } | 267 | } |