diff options
Diffstat (limited to 'arch/arm/mach-ep93xx')
-rw-r--r-- | arch/arm/mach-ep93xx/adssphere.c | 11 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/clock.c | 217 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/core.c | 234 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/edb93xx.c | 10 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/gesbc9312.c | 11 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/gpio.c | 65 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/ep93xx-regs.h | 109 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/fb.h | 56 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/hardware.h | 17 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/io.h | 17 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/platform.h | 22 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/system.h | 12 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/include/mach/ts72xx.h | 1 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/micro9.c | 11 | ||||
-rw-r--r-- | arch/arm/mach-ep93xx/ts72xx.c | 15 |
15 files changed, 636 insertions, 172 deletions
diff --git a/arch/arm/mach-ep93xx/adssphere.c b/arch/arm/mach-ep93xx/adssphere.c index 3fbd9b0fbe24..caf6d5154aec 100644 --- a/arch/arm/mach-ep93xx/adssphere.c +++ b/arch/arm/mach-ep93xx/adssphere.c | |||
@@ -12,18 +12,15 @@ | |||
12 | 12 | ||
13 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
15 | #include <linux/mm.h> | ||
16 | #include <linux/sched.h> | ||
17 | #include <linux/interrupt.h> | ||
18 | #include <linux/ioport.h> | ||
19 | #include <linux/mtd/physmap.h> | ||
20 | #include <linux/platform_device.h> | 15 | #include <linux/platform_device.h> |
21 | #include <linux/io.h> | 16 | #include <linux/mtd/physmap.h> |
22 | #include <linux/i2c.h> | 17 | |
23 | #include <mach/hardware.h> | 18 | #include <mach/hardware.h> |
19 | |||
24 | #include <asm/mach-types.h> | 20 | #include <asm/mach-types.h> |
25 | #include <asm/mach/arch.h> | 21 | #include <asm/mach/arch.h> |
26 | 22 | ||
23 | |||
27 | static struct physmap_flash_data adssphere_flash_data = { | 24 | static struct physmap_flash_data adssphere_flash_data = { |
28 | .width = 4, | 25 | .width = 4, |
29 | }; | 26 | }; |
diff --git a/arch/arm/mach-ep93xx/clock.c b/arch/arm/mach-ep93xx/clock.c index 6c4c1633ed12..dda19cd76194 100644 --- a/arch/arm/mach-ep93xx/clock.c +++ b/arch/arm/mach-ep93xx/clock.c | |||
@@ -22,48 +22,39 @@ | |||
22 | #include <mach/hardware.h> | 22 | #include <mach/hardware.h> |
23 | 23 | ||
24 | 24 | ||
25 | /* | ||
26 | * The EP93xx has two external crystal oscillators. To generate the | ||
27 | * required high-frequency clocks, the processor uses two phase-locked- | ||
28 | * loops (PLLs) to multiply the incoming external clock signal to much | ||
29 | * higher frequencies that are then divided down by programmable dividers | ||
30 | * to produce the needed clocks. The PLLs operate independently of one | ||
31 | * another. | ||
32 | */ | ||
33 | #define EP93XX_EXT_CLK_RATE 14745600 | ||
34 | #define EP93XX_EXT_RTC_RATE 32768 | ||
35 | |||
36 | |||
37 | struct clk { | 25 | struct clk { |
38 | unsigned long rate; | 26 | unsigned long rate; |
39 | int users; | 27 | int users; |
40 | int sw_locked; | 28 | int sw_locked; |
41 | u32 enable_reg; | 29 | void __iomem *enable_reg; |
42 | u32 enable_mask; | 30 | u32 enable_mask; |
43 | 31 | ||
44 | unsigned long (*get_rate)(struct clk *clk); | 32 | unsigned long (*get_rate)(struct clk *clk); |
33 | int (*set_rate)(struct clk *clk, unsigned long rate); | ||
45 | }; | 34 | }; |
46 | 35 | ||
47 | 36 | ||
48 | static unsigned long get_uart_rate(struct clk *clk); | 37 | static unsigned long get_uart_rate(struct clk *clk); |
49 | 38 | ||
39 | static int set_keytchclk_rate(struct clk *clk, unsigned long rate); | ||
40 | static int set_div_rate(struct clk *clk, unsigned long rate); | ||
50 | 41 | ||
51 | static struct clk clk_uart1 = { | 42 | static struct clk clk_uart1 = { |
52 | .sw_locked = 1, | 43 | .sw_locked = 1, |
53 | .enable_reg = EP93XX_SYSCON_DEVICE_CONFIG, | 44 | .enable_reg = EP93XX_SYSCON_DEVCFG, |
54 | .enable_mask = EP93XX_SYSCON_DEVICE_CONFIG_U1EN, | 45 | .enable_mask = EP93XX_SYSCON_DEVCFG_U1EN, |
55 | .get_rate = get_uart_rate, | 46 | .get_rate = get_uart_rate, |
56 | }; | 47 | }; |
57 | static struct clk clk_uart2 = { | 48 | static struct clk clk_uart2 = { |
58 | .sw_locked = 1, | 49 | .sw_locked = 1, |
59 | .enable_reg = EP93XX_SYSCON_DEVICE_CONFIG, | 50 | .enable_reg = EP93XX_SYSCON_DEVCFG, |
60 | .enable_mask = EP93XX_SYSCON_DEVICE_CONFIG_U2EN, | 51 | .enable_mask = EP93XX_SYSCON_DEVCFG_U2EN, |
61 | .get_rate = get_uart_rate, | 52 | .get_rate = get_uart_rate, |
62 | }; | 53 | }; |
63 | static struct clk clk_uart3 = { | 54 | static struct clk clk_uart3 = { |
64 | .sw_locked = 1, | 55 | .sw_locked = 1, |
65 | .enable_reg = EP93XX_SYSCON_DEVICE_CONFIG, | 56 | .enable_reg = EP93XX_SYSCON_DEVCFG, |
66 | .enable_mask = EP93XX_SYSCON_DEVICE_CONFIG_U3EN, | 57 | .enable_mask = EP93XX_SYSCON_DEVCFG_U3EN, |
67 | .get_rate = get_uart_rate, | 58 | .get_rate = get_uart_rate, |
68 | }; | 59 | }; |
69 | static struct clk clk_pll1; | 60 | static struct clk clk_pll1; |
@@ -75,6 +66,22 @@ static struct clk clk_usb_host = { | |||
75 | .enable_reg = EP93XX_SYSCON_PWRCNT, | 66 | .enable_reg = EP93XX_SYSCON_PWRCNT, |
76 | .enable_mask = EP93XX_SYSCON_PWRCNT_USH_EN, | 67 | .enable_mask = EP93XX_SYSCON_PWRCNT_USH_EN, |
77 | }; | 68 | }; |
69 | static struct clk clk_keypad = { | ||
70 | .sw_locked = 1, | ||
71 | .enable_reg = EP93XX_SYSCON_KEYTCHCLKDIV, | ||
72 | .enable_mask = EP93XX_SYSCON_KEYTCHCLKDIV_KEN, | ||
73 | .set_rate = set_keytchclk_rate, | ||
74 | }; | ||
75 | static struct clk clk_pwm = { | ||
76 | .rate = EP93XX_EXT_CLK_RATE, | ||
77 | }; | ||
78 | |||
79 | static struct clk clk_video = { | ||
80 | .sw_locked = 1, | ||
81 | .enable_reg = EP93XX_SYSCON_VIDCLKDIV, | ||
82 | .enable_mask = EP93XX_SYSCON_CLKDIV_ENABLE, | ||
83 | .set_rate = set_div_rate, | ||
84 | }; | ||
78 | 85 | ||
79 | /* DMA Clocks */ | 86 | /* DMA Clocks */ |
80 | static struct clk clk_m2p0 = { | 87 | static struct clk clk_m2p0 = { |
@@ -130,27 +137,30 @@ static struct clk clk_m2m1 = { | |||
130 | { .dev_id = dev, .con_id = con, .clk = ck } | 137 | { .dev_id = dev, .con_id = con, .clk = ck } |
131 | 138 | ||
132 | static struct clk_lookup clocks[] = { | 139 | static struct clk_lookup clocks[] = { |
133 | INIT_CK("apb:uart1", NULL, &clk_uart1), | 140 | INIT_CK("apb:uart1", NULL, &clk_uart1), |
134 | INIT_CK("apb:uart2", NULL, &clk_uart2), | 141 | INIT_CK("apb:uart2", NULL, &clk_uart2), |
135 | INIT_CK("apb:uart3", NULL, &clk_uart3), | 142 | INIT_CK("apb:uart3", NULL, &clk_uart3), |
136 | INIT_CK(NULL, "pll1", &clk_pll1), | 143 | INIT_CK(NULL, "pll1", &clk_pll1), |
137 | INIT_CK(NULL, "fclk", &clk_f), | 144 | INIT_CK(NULL, "fclk", &clk_f), |
138 | INIT_CK(NULL, "hclk", &clk_h), | 145 | INIT_CK(NULL, "hclk", &clk_h), |
139 | INIT_CK(NULL, "pclk", &clk_p), | 146 | INIT_CK(NULL, "pclk", &clk_p), |
140 | INIT_CK(NULL, "pll2", &clk_pll2), | 147 | INIT_CK(NULL, "pll2", &clk_pll2), |
141 | INIT_CK("ep93xx-ohci", NULL, &clk_usb_host), | 148 | INIT_CK("ep93xx-ohci", NULL, &clk_usb_host), |
142 | INIT_CK(NULL, "m2p0", &clk_m2p0), | 149 | INIT_CK("ep93xx-keypad", NULL, &clk_keypad), |
143 | INIT_CK(NULL, "m2p1", &clk_m2p1), | 150 | INIT_CK("ep93xx-fb", NULL, &clk_video), |
144 | INIT_CK(NULL, "m2p2", &clk_m2p2), | 151 | INIT_CK(NULL, "pwm_clk", &clk_pwm), |
145 | INIT_CK(NULL, "m2p3", &clk_m2p3), | 152 | INIT_CK(NULL, "m2p0", &clk_m2p0), |
146 | INIT_CK(NULL, "m2p4", &clk_m2p4), | 153 | INIT_CK(NULL, "m2p1", &clk_m2p1), |
147 | INIT_CK(NULL, "m2p5", &clk_m2p5), | 154 | INIT_CK(NULL, "m2p2", &clk_m2p2), |
148 | INIT_CK(NULL, "m2p6", &clk_m2p6), | 155 | INIT_CK(NULL, "m2p3", &clk_m2p3), |
149 | INIT_CK(NULL, "m2p7", &clk_m2p7), | 156 | INIT_CK(NULL, "m2p4", &clk_m2p4), |
150 | INIT_CK(NULL, "m2p8", &clk_m2p8), | 157 | INIT_CK(NULL, "m2p5", &clk_m2p5), |
151 | INIT_CK(NULL, "m2p9", &clk_m2p9), | 158 | INIT_CK(NULL, "m2p6", &clk_m2p6), |
152 | INIT_CK(NULL, "m2m0", &clk_m2m0), | 159 | INIT_CK(NULL, "m2p7", &clk_m2p7), |
153 | INIT_CK(NULL, "m2m1", &clk_m2m1), | 160 | INIT_CK(NULL, "m2p8", &clk_m2p8), |
161 | INIT_CK(NULL, "m2p9", &clk_m2p9), | ||
162 | INIT_CK(NULL, "m2m0", &clk_m2m0), | ||
163 | INIT_CK(NULL, "m2m1", &clk_m2m1), | ||
154 | }; | 164 | }; |
155 | 165 | ||
156 | 166 | ||
@@ -160,9 +170,11 @@ int clk_enable(struct clk *clk) | |||
160 | u32 value; | 170 | u32 value; |
161 | 171 | ||
162 | value = __raw_readl(clk->enable_reg); | 172 | value = __raw_readl(clk->enable_reg); |
173 | value |= clk->enable_mask; | ||
163 | if (clk->sw_locked) | 174 | if (clk->sw_locked) |
164 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | 175 | ep93xx_syscon_swlocked_write(value, clk->enable_reg); |
165 | __raw_writel(value | clk->enable_mask, clk->enable_reg); | 176 | else |
177 | __raw_writel(value, clk->enable_reg); | ||
166 | } | 178 | } |
167 | 179 | ||
168 | return 0; | 180 | return 0; |
@@ -175,9 +187,11 @@ void clk_disable(struct clk *clk) | |||
175 | u32 value; | 187 | u32 value; |
176 | 188 | ||
177 | value = __raw_readl(clk->enable_reg); | 189 | value = __raw_readl(clk->enable_reg); |
190 | value &= ~clk->enable_mask; | ||
178 | if (clk->sw_locked) | 191 | if (clk->sw_locked) |
179 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | 192 | ep93xx_syscon_swlocked_write(value, clk->enable_reg); |
180 | __raw_writel(value & ~clk->enable_mask, clk->enable_reg); | 193 | else |
194 | __raw_writel(value, clk->enable_reg); | ||
181 | } | 195 | } |
182 | } | 196 | } |
183 | EXPORT_SYMBOL(clk_disable); | 197 | EXPORT_SYMBOL(clk_disable); |
@@ -202,6 +216,121 @@ unsigned long clk_get_rate(struct clk *clk) | |||
202 | } | 216 | } |
203 | EXPORT_SYMBOL(clk_get_rate); | 217 | EXPORT_SYMBOL(clk_get_rate); |
204 | 218 | ||
219 | static int set_keytchclk_rate(struct clk *clk, unsigned long rate) | ||
220 | { | ||
221 | u32 val; | ||
222 | u32 div_bit; | ||
223 | |||
224 | val = __raw_readl(clk->enable_reg); | ||
225 | |||
226 | /* | ||
227 | * The Key Matrix and ADC clocks are configured using the same | ||
228 | * System Controller register. The clock used will be either | ||
229 | * 1/4 or 1/16 the external clock rate depending on the | ||
230 | * EP93XX_SYSCON_KEYTCHCLKDIV_KDIV/EP93XX_SYSCON_KEYTCHCLKDIV_ADIV | ||
231 | * bit being set or cleared. | ||
232 | */ | ||
233 | div_bit = clk->enable_mask >> 15; | ||
234 | |||
235 | if (rate == EP93XX_KEYTCHCLK_DIV4) | ||
236 | val |= div_bit; | ||
237 | else if (rate == EP93XX_KEYTCHCLK_DIV16) | ||
238 | val &= ~div_bit; | ||
239 | else | ||
240 | return -EINVAL; | ||
241 | |||
242 | ep93xx_syscon_swlocked_write(val, clk->enable_reg); | ||
243 | clk->rate = rate; | ||
244 | return 0; | ||
245 | } | ||
246 | |||
247 | static unsigned long calc_clk_div(unsigned long rate, int *psel, int *esel, | ||
248 | int *pdiv, int *div) | ||
249 | { | ||
250 | unsigned long max_rate, best_rate = 0, | ||
251 | actual_rate = 0, mclk_rate = 0, rate_err = -1; | ||
252 | int i, found = 0, __div = 0, __pdiv = 0; | ||
253 | |||
254 | /* Don't exceed the maximum rate */ | ||
255 | max_rate = max(max(clk_pll1.rate / 4, clk_pll2.rate / 4), | ||
256 | (unsigned long)EP93XX_EXT_CLK_RATE / 4); | ||
257 | rate = min(rate, max_rate); | ||
258 | |||
259 | /* | ||
260 | * Try the two pll's and the external clock | ||
261 | * Because the valid predividers are 2, 2.5 and 3, we multiply | ||
262 | * all the clocks by 2 to avoid floating point math. | ||
263 | * | ||
264 | * This is based on the algorithm in the ep93xx raster guide: | ||
265 | * http://be-a-maverick.com/en/pubs/appNote/AN269REV1.pdf | ||
266 | * | ||
267 | */ | ||
268 | for (i = 0; i < 3; i++) { | ||
269 | if (i == 0) | ||
270 | mclk_rate = EP93XX_EXT_CLK_RATE * 2; | ||
271 | else if (i == 1) | ||
272 | mclk_rate = clk_pll1.rate * 2; | ||
273 | else if (i == 2) | ||
274 | mclk_rate = clk_pll2.rate * 2; | ||
275 | |||
276 | /* Try each predivider value */ | ||
277 | for (__pdiv = 4; __pdiv <= 6; __pdiv++) { | ||
278 | __div = mclk_rate / (rate * __pdiv); | ||
279 | if (__div < 2 || __div > 127) | ||
280 | continue; | ||
281 | |||
282 | actual_rate = mclk_rate / (__pdiv * __div); | ||
283 | |||
284 | if (!found || abs(actual_rate - rate) < rate_err) { | ||
285 | *pdiv = __pdiv - 3; | ||
286 | *div = __div; | ||
287 | *psel = (i == 2); | ||
288 | *esel = (i != 0); | ||
289 | best_rate = actual_rate; | ||
290 | rate_err = abs(actual_rate - rate); | ||
291 | found = 1; | ||
292 | } | ||
293 | } | ||
294 | } | ||
295 | |||
296 | if (!found) | ||
297 | return 0; | ||
298 | |||
299 | return best_rate; | ||
300 | } | ||
301 | |||
302 | static int set_div_rate(struct clk *clk, unsigned long rate) | ||
303 | { | ||
304 | unsigned long actual_rate; | ||
305 | int psel = 0, esel = 0, pdiv = 0, div = 0; | ||
306 | u32 val; | ||
307 | |||
308 | actual_rate = calc_clk_div(rate, &psel, &esel, &pdiv, &div); | ||
309 | if (actual_rate == 0) | ||
310 | return -EINVAL; | ||
311 | clk->rate = actual_rate; | ||
312 | |||
313 | /* Clear the esel, psel, pdiv and div bits */ | ||
314 | val = __raw_readl(clk->enable_reg); | ||
315 | val &= ~0x7fff; | ||
316 | |||
317 | /* Set the new esel, psel, pdiv and div bits for the new clock rate */ | ||
318 | val |= (esel ? EP93XX_SYSCON_CLKDIV_ESEL : 0) | | ||
319 | (psel ? EP93XX_SYSCON_CLKDIV_PSEL : 0) | | ||
320 | (pdiv << EP93XX_SYSCON_CLKDIV_PDIV_SHIFT) | div; | ||
321 | ep93xx_syscon_swlocked_write(val, clk->enable_reg); | ||
322 | return 0; | ||
323 | } | ||
324 | |||
325 | int clk_set_rate(struct clk *clk, unsigned long rate) | ||
326 | { | ||
327 | if (clk->set_rate) | ||
328 | return clk->set_rate(clk, rate); | ||
329 | |||
330 | return -EINVAL; | ||
331 | } | ||
332 | EXPORT_SYMBOL(clk_set_rate); | ||
333 | |||
205 | 334 | ||
206 | static char fclk_divisors[] = { 1, 2, 4, 8, 16, 1, 1, 1 }; | 335 | static char fclk_divisors[] = { 1, 2, 4, 8, 16, 1, 1, 1 }; |
207 | static char hclk_divisors[] = { 1, 2, 4, 5, 6, 8, 16, 32 }; | 336 | static char hclk_divisors[] = { 1, 2, 4, 5, 6, 8, 16, 32 }; |
diff --git a/arch/arm/mach-ep93xx/core.c b/arch/arm/mach-ep93xx/core.c index 204dc5cbd0b8..f7ebed942f66 100644 --- a/arch/arm/mach-ep93xx/core.c +++ b/arch/arm/mach-ep93xx/core.c | |||
@@ -16,40 +16,25 @@ | |||
16 | 16 | ||
17 | #include <linux/kernel.h> | 17 | #include <linux/kernel.h> |
18 | #include <linux/init.h> | 18 | #include <linux/init.h> |
19 | #include <linux/spinlock.h> | 19 | #include <linux/platform_device.h> |
20 | #include <linux/sched.h> | ||
21 | #include <linux/interrupt.h> | 20 | #include <linux/interrupt.h> |
22 | #include <linux/serial.h> | ||
23 | #include <linux/tty.h> | ||
24 | #include <linux/bitops.h> | ||
25 | #include <linux/serial_8250.h> | ||
26 | #include <linux/serial_core.h> | ||
27 | #include <linux/device.h> | ||
28 | #include <linux/mm.h> | ||
29 | #include <linux/dma-mapping.h> | 21 | #include <linux/dma-mapping.h> |
30 | #include <linux/time.h> | ||
31 | #include <linux/timex.h> | 22 | #include <linux/timex.h> |
32 | #include <linux/delay.h> | 23 | #include <linux/io.h> |
24 | #include <linux/gpio.h> | ||
25 | #include <linux/leds.h> | ||
33 | #include <linux/termios.h> | 26 | #include <linux/termios.h> |
34 | #include <linux/amba/bus.h> | 27 | #include <linux/amba/bus.h> |
35 | #include <linux/amba/serial.h> | 28 | #include <linux/amba/serial.h> |
36 | #include <linux/io.h> | ||
37 | #include <linux/i2c.h> | 29 | #include <linux/i2c.h> |
38 | #include <linux/i2c-gpio.h> | 30 | #include <linux/i2c-gpio.h> |
39 | 31 | ||
40 | #include <asm/types.h> | ||
41 | #include <asm/setup.h> | ||
42 | #include <asm/memory.h> | ||
43 | #include <mach/hardware.h> | 32 | #include <mach/hardware.h> |
44 | #include <asm/irq.h> | 33 | #include <mach/fb.h> |
45 | #include <asm/system.h> | ||
46 | #include <asm/tlbflush.h> | ||
47 | #include <asm/pgtable.h> | ||
48 | 34 | ||
49 | #include <asm/mach/map.h> | 35 | #include <asm/mach/map.h> |
50 | #include <asm/mach/time.h> | 36 | #include <asm/mach/time.h> |
51 | #include <asm/mach/irq.h> | 37 | #include <asm/mach/irq.h> |
52 | #include <mach/gpio.h> | ||
53 | 38 | ||
54 | #include <asm/hardware/vic.h> | 39 | #include <asm/hardware/vic.h> |
55 | 40 | ||
@@ -98,7 +83,7 @@ void __init ep93xx_map_io(void) | |||
98 | */ | 83 | */ |
99 | static unsigned int last_jiffy_time; | 84 | static unsigned int last_jiffy_time; |
100 | 85 | ||
101 | #define TIMER4_TICKS_PER_JIFFY ((CLOCK_TICK_RATE + (HZ/2)) / HZ) | 86 | #define TIMER4_TICKS_PER_JIFFY DIV_ROUND_CLOSEST(CLOCK_TICK_RATE, HZ) |
102 | 87 | ||
103 | static irqreturn_t ep93xx_timer_interrupt(int irq, void *dev_id) | 88 | static irqreturn_t ep93xx_timer_interrupt(int irq, void *dev_id) |
104 | { | 89 | { |
@@ -362,8 +347,8 @@ void __init ep93xx_init_irq(void) | |||
362 | { | 347 | { |
363 | int gpio_irq; | 348 | int gpio_irq; |
364 | 349 | ||
365 | vic_init((void *)EP93XX_VIC1_BASE, 0, EP93XX_VIC1_VALID_IRQ_MASK, 0); | 350 | vic_init(EP93XX_VIC1_BASE, 0, EP93XX_VIC1_VALID_IRQ_MASK, 0); |
366 | vic_init((void *)EP93XX_VIC2_BASE, 32, EP93XX_VIC2_VALID_IRQ_MASK, 0); | 351 | vic_init(EP93XX_VIC2_BASE, 32, EP93XX_VIC2_VALID_IRQ_MASK, 0); |
367 | 352 | ||
368 | for (gpio_irq = gpio_to_irq(0); | 353 | for (gpio_irq = gpio_to_irq(0); |
369 | gpio_irq <= gpio_to_irq(EP93XX_GPIO_LINE_MAX_IRQ); ++gpio_irq) { | 354 | gpio_irq <= gpio_to_irq(EP93XX_GPIO_LINE_MAX_IRQ); ++gpio_irq) { |
@@ -385,6 +370,47 @@ void __init ep93xx_init_irq(void) | |||
385 | 370 | ||
386 | 371 | ||
387 | /************************************************************************* | 372 | /************************************************************************* |
373 | * EP93xx System Controller Software Locked register handling | ||
374 | *************************************************************************/ | ||
375 | |||
376 | /* | ||
377 | * syscon_swlock prevents anything else from writing to the syscon | ||
378 | * block while a software locked register is being written. | ||
379 | */ | ||
380 | static DEFINE_SPINLOCK(syscon_swlock); | ||
381 | |||
382 | void ep93xx_syscon_swlocked_write(unsigned int val, void __iomem *reg) | ||
383 | { | ||
384 | unsigned long flags; | ||
385 | |||
386 | spin_lock_irqsave(&syscon_swlock, flags); | ||
387 | |||
388 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | ||
389 | __raw_writel(val, reg); | ||
390 | |||
391 | spin_unlock_irqrestore(&syscon_swlock, flags); | ||
392 | } | ||
393 | EXPORT_SYMBOL(ep93xx_syscon_swlocked_write); | ||
394 | |||
395 | void ep93xx_devcfg_set_clear(unsigned int set_bits, unsigned int clear_bits) | ||
396 | { | ||
397 | unsigned long flags; | ||
398 | unsigned int val; | ||
399 | |||
400 | spin_lock_irqsave(&syscon_swlock, flags); | ||
401 | |||
402 | val = __raw_readl(EP93XX_SYSCON_DEVCFG); | ||
403 | val |= set_bits; | ||
404 | val &= ~clear_bits; | ||
405 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | ||
406 | __raw_writel(val, EP93XX_SYSCON_DEVCFG); | ||
407 | |||
408 | spin_unlock_irqrestore(&syscon_swlock, flags); | ||
409 | } | ||
410 | EXPORT_SYMBOL(ep93xx_devcfg_set_clear); | ||
411 | |||
412 | |||
413 | /************************************************************************* | ||
388 | * EP93xx peripheral handling | 414 | * EP93xx peripheral handling |
389 | *************************************************************************/ | 415 | *************************************************************************/ |
390 | #define EP93XX_UART_MCR_OFFSET (0x0100) | 416 | #define EP93XX_UART_MCR_OFFSET (0x0100) |
@@ -517,10 +543,8 @@ static struct platform_device ep93xx_eth_device = { | |||
517 | 543 | ||
518 | void __init ep93xx_register_eth(struct ep93xx_eth_data *data, int copy_addr) | 544 | void __init ep93xx_register_eth(struct ep93xx_eth_data *data, int copy_addr) |
519 | { | 545 | { |
520 | if (copy_addr) { | 546 | if (copy_addr) |
521 | memcpy(data->dev_addr, | 547 | memcpy_fromio(data->dev_addr, EP93XX_ETHERNET_BASE + 0x50, 6); |
522 | (void *)(EP93XX_ETHERNET_BASE + 0x50), 6); | ||
523 | } | ||
524 | 548 | ||
525 | ep93xx_eth_data = *data; | 549 | ep93xx_eth_data = *data; |
526 | platform_device_register(&ep93xx_eth_device); | 550 | platform_device_register(&ep93xx_eth_device); |
@@ -546,19 +570,156 @@ void __init ep93xx_register_i2c(struct i2c_board_info *devices, int num) | |||
546 | platform_device_register(&ep93xx_i2c_device); | 570 | platform_device_register(&ep93xx_i2c_device); |
547 | } | 571 | } |
548 | 572 | ||
573 | |||
574 | /************************************************************************* | ||
575 | * EP93xx LEDs | ||
576 | *************************************************************************/ | ||
577 | static struct gpio_led ep93xx_led_pins[] = { | ||
578 | { | ||
579 | .name = "platform:grled", | ||
580 | .gpio = EP93XX_GPIO_LINE_GRLED, | ||
581 | }, { | ||
582 | .name = "platform:rdled", | ||
583 | .gpio = EP93XX_GPIO_LINE_RDLED, | ||
584 | }, | ||
585 | }; | ||
586 | |||
587 | static struct gpio_led_platform_data ep93xx_led_data = { | ||
588 | .num_leds = ARRAY_SIZE(ep93xx_led_pins), | ||
589 | .leds = ep93xx_led_pins, | ||
590 | }; | ||
591 | |||
592 | static struct platform_device ep93xx_leds = { | ||
593 | .name = "leds-gpio", | ||
594 | .id = -1, | ||
595 | .dev = { | ||
596 | .platform_data = &ep93xx_led_data, | ||
597 | }, | ||
598 | }; | ||
599 | |||
600 | |||
601 | /************************************************************************* | ||
602 | * EP93xx pwm peripheral handling | ||
603 | *************************************************************************/ | ||
604 | static struct resource ep93xx_pwm0_resource[] = { | ||
605 | { | ||
606 | .start = EP93XX_PWM_PHYS_BASE, | ||
607 | .end = EP93XX_PWM_PHYS_BASE + 0x10 - 1, | ||
608 | .flags = IORESOURCE_MEM, | ||
609 | }, | ||
610 | }; | ||
611 | |||
612 | static struct platform_device ep93xx_pwm0_device = { | ||
613 | .name = "ep93xx-pwm", | ||
614 | .id = 0, | ||
615 | .num_resources = ARRAY_SIZE(ep93xx_pwm0_resource), | ||
616 | .resource = ep93xx_pwm0_resource, | ||
617 | }; | ||
618 | |||
619 | static struct resource ep93xx_pwm1_resource[] = { | ||
620 | { | ||
621 | .start = EP93XX_PWM_PHYS_BASE + 0x20, | ||
622 | .end = EP93XX_PWM_PHYS_BASE + 0x30 - 1, | ||
623 | .flags = IORESOURCE_MEM, | ||
624 | }, | ||
625 | }; | ||
626 | |||
627 | static struct platform_device ep93xx_pwm1_device = { | ||
628 | .name = "ep93xx-pwm", | ||
629 | .id = 1, | ||
630 | .num_resources = ARRAY_SIZE(ep93xx_pwm1_resource), | ||
631 | .resource = ep93xx_pwm1_resource, | ||
632 | }; | ||
633 | |||
634 | void __init ep93xx_register_pwm(int pwm0, int pwm1) | ||
635 | { | ||
636 | if (pwm0) | ||
637 | platform_device_register(&ep93xx_pwm0_device); | ||
638 | |||
639 | /* NOTE: EP9307 does not have PWMOUT1 (pin EGPIO14) */ | ||
640 | if (pwm1) | ||
641 | platform_device_register(&ep93xx_pwm1_device); | ||
642 | } | ||
643 | |||
644 | int ep93xx_pwm_acquire_gpio(struct platform_device *pdev) | ||
645 | { | ||
646 | int err; | ||
647 | |||
648 | if (pdev->id == 0) { | ||
649 | err = 0; | ||
650 | } else if (pdev->id == 1) { | ||
651 | err = gpio_request(EP93XX_GPIO_LINE_EGPIO14, | ||
652 | dev_name(&pdev->dev)); | ||
653 | if (err) | ||
654 | return err; | ||
655 | err = gpio_direction_output(EP93XX_GPIO_LINE_EGPIO14, 0); | ||
656 | if (err) | ||
657 | goto fail; | ||
658 | |||
659 | /* PWM 1 output on EGPIO[14] */ | ||
660 | ep93xx_devcfg_set_bits(EP93XX_SYSCON_DEVCFG_PONG); | ||
661 | } else { | ||
662 | err = -ENODEV; | ||
663 | } | ||
664 | |||
665 | return err; | ||
666 | |||
667 | fail: | ||
668 | gpio_free(EP93XX_GPIO_LINE_EGPIO14); | ||
669 | return err; | ||
670 | } | ||
671 | EXPORT_SYMBOL(ep93xx_pwm_acquire_gpio); | ||
672 | |||
673 | void ep93xx_pwm_release_gpio(struct platform_device *pdev) | ||
674 | { | ||
675 | if (pdev->id == 1) { | ||
676 | gpio_direction_input(EP93XX_GPIO_LINE_EGPIO14); | ||
677 | gpio_free(EP93XX_GPIO_LINE_EGPIO14); | ||
678 | |||
679 | /* EGPIO[14] used for GPIO */ | ||
680 | ep93xx_devcfg_clear_bits(EP93XX_SYSCON_DEVCFG_PONG); | ||
681 | } | ||
682 | } | ||
683 | EXPORT_SYMBOL(ep93xx_pwm_release_gpio); | ||
684 | |||
685 | |||
686 | /************************************************************************* | ||
687 | * EP93xx video peripheral handling | ||
688 | *************************************************************************/ | ||
689 | static struct ep93xxfb_mach_info ep93xxfb_data; | ||
690 | |||
691 | static struct resource ep93xx_fb_resource[] = { | ||
692 | { | ||
693 | .start = EP93XX_RASTER_PHYS_BASE, | ||
694 | .end = EP93XX_RASTER_PHYS_BASE + 0x800 - 1, | ||
695 | .flags = IORESOURCE_MEM, | ||
696 | }, | ||
697 | }; | ||
698 | |||
699 | static struct platform_device ep93xx_fb_device = { | ||
700 | .name = "ep93xx-fb", | ||
701 | .id = -1, | ||
702 | .dev = { | ||
703 | .platform_data = &ep93xxfb_data, | ||
704 | .coherent_dma_mask = DMA_BIT_MASK(32), | ||
705 | .dma_mask = &ep93xx_fb_device.dev.coherent_dma_mask, | ||
706 | }, | ||
707 | .num_resources = ARRAY_SIZE(ep93xx_fb_resource), | ||
708 | .resource = ep93xx_fb_resource, | ||
709 | }; | ||
710 | |||
711 | void __init ep93xx_register_fb(struct ep93xxfb_mach_info *data) | ||
712 | { | ||
713 | ep93xxfb_data = *data; | ||
714 | platform_device_register(&ep93xx_fb_device); | ||
715 | } | ||
716 | |||
549 | extern void ep93xx_gpio_init(void); | 717 | extern void ep93xx_gpio_init(void); |
550 | 718 | ||
551 | void __init ep93xx_init_devices(void) | 719 | void __init ep93xx_init_devices(void) |
552 | { | 720 | { |
553 | unsigned int v; | 721 | /* Disallow access to MaverickCrunch initially */ |
554 | 722 | ep93xx_devcfg_clear_bits(EP93XX_SYSCON_DEVCFG_CPENA); | |
555 | /* | ||
556 | * Disallow access to MaverickCrunch initially. | ||
557 | */ | ||
558 | v = __raw_readl(EP93XX_SYSCON_DEVICE_CONFIG); | ||
559 | v &= ~EP93XX_SYSCON_DEVICE_CONFIG_CRUNCH_ENABLE; | ||
560 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | ||
561 | __raw_writel(v, EP93XX_SYSCON_DEVICE_CONFIG); | ||
562 | 723 | ||
563 | ep93xx_gpio_init(); | 724 | ep93xx_gpio_init(); |
564 | 725 | ||
@@ -568,4 +729,5 @@ void __init ep93xx_init_devices(void) | |||
568 | 729 | ||
569 | platform_device_register(&ep93xx_rtc_device); | 730 | platform_device_register(&ep93xx_rtc_device); |
570 | platform_device_register(&ep93xx_ohci_device); | 731 | platform_device_register(&ep93xx_ohci_device); |
732 | platform_device_register(&ep93xx_leds); | ||
571 | } | 733 | } |
diff --git a/arch/arm/mach-ep93xx/edb93xx.c b/arch/arm/mach-ep93xx/edb93xx.c index e9e45b92457e..73145ae5d3fa 100644 --- a/arch/arm/mach-ep93xx/edb93xx.c +++ b/arch/arm/mach-ep93xx/edb93xx.c | |||
@@ -26,18 +26,16 @@ | |||
26 | 26 | ||
27 | #include <linux/kernel.h> | 27 | #include <linux/kernel.h> |
28 | #include <linux/init.h> | 28 | #include <linux/init.h> |
29 | #include <linux/mm.h> | ||
30 | #include <linux/sched.h> | ||
31 | #include <linux/interrupt.h> | ||
32 | #include <linux/ioport.h> | ||
33 | #include <linux/mtd/physmap.h> | ||
34 | #include <linux/platform_device.h> | 29 | #include <linux/platform_device.h> |
35 | #include <linux/io.h> | ||
36 | #include <linux/i2c.h> | 30 | #include <linux/i2c.h> |
31 | #include <linux/mtd/physmap.h> | ||
32 | |||
37 | #include <mach/hardware.h> | 33 | #include <mach/hardware.h> |
34 | |||
38 | #include <asm/mach-types.h> | 35 | #include <asm/mach-types.h> |
39 | #include <asm/mach/arch.h> | 36 | #include <asm/mach/arch.h> |
40 | 37 | ||
38 | |||
41 | static struct physmap_flash_data edb93xx_flash_data; | 39 | static struct physmap_flash_data edb93xx_flash_data; |
42 | 40 | ||
43 | static struct resource edb93xx_flash_resource = { | 41 | static struct resource edb93xx_flash_resource = { |
diff --git a/arch/arm/mach-ep93xx/gesbc9312.c b/arch/arm/mach-ep93xx/gesbc9312.c index 3bad500b71b6..3da7ca816d19 100644 --- a/arch/arm/mach-ep93xx/gesbc9312.c +++ b/arch/arm/mach-ep93xx/gesbc9312.c | |||
@@ -12,18 +12,15 @@ | |||
12 | 12 | ||
13 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
15 | #include <linux/mm.h> | ||
16 | #include <linux/sched.h> | ||
17 | #include <linux/interrupt.h> | ||
18 | #include <linux/ioport.h> | ||
19 | #include <linux/mtd/physmap.h> | ||
20 | #include <linux/platform_device.h> | 15 | #include <linux/platform_device.h> |
21 | #include <linux/io.h> | 16 | #include <linux/mtd/physmap.h> |
22 | #include <linux/i2c.h> | 17 | |
23 | #include <mach/hardware.h> | 18 | #include <mach/hardware.h> |
19 | |||
24 | #include <asm/mach-types.h> | 20 | #include <asm/mach-types.h> |
25 | #include <asm/mach/arch.h> | 21 | #include <asm/mach/arch.h> |
26 | 22 | ||
23 | |||
27 | static struct physmap_flash_data gesbc9312_flash_data = { | 24 | static struct physmap_flash_data gesbc9312_flash_data = { |
28 | .width = 4, | 25 | .width = 4, |
29 | }; | 26 | }; |
diff --git a/arch/arm/mach-ep93xx/gpio.c b/arch/arm/mach-ep93xx/gpio.c index 482cf3d2fbcd..1ea8871e03a9 100644 --- a/arch/arm/mach-ep93xx/gpio.c +++ b/arch/arm/mach-ep93xx/gpio.c | |||
@@ -17,15 +17,16 @@ | |||
17 | #include <linux/module.h> | 17 | #include <linux/module.h> |
18 | #include <linux/seq_file.h> | 18 | #include <linux/seq_file.h> |
19 | #include <linux/io.h> | 19 | #include <linux/io.h> |
20 | #include <linux/gpio.h> | ||
21 | #include <linux/irq.h> | ||
20 | 22 | ||
21 | #include <mach/ep93xx-regs.h> | 23 | #include <mach/hardware.h> |
22 | #include <asm/gpio.h> | ||
23 | 24 | ||
24 | struct ep93xx_gpio_chip { | 25 | struct ep93xx_gpio_chip { |
25 | struct gpio_chip chip; | 26 | struct gpio_chip chip; |
26 | 27 | ||
27 | unsigned int data_reg; | 28 | void __iomem *data_reg; |
28 | unsigned int data_dir_reg; | 29 | void __iomem *data_dir_reg; |
29 | }; | 30 | }; |
30 | 31 | ||
31 | #define to_ep93xx_gpio_chip(c) container_of(c, struct ep93xx_gpio_chip, chip) | 32 | #define to_ep93xx_gpio_chip(c) container_of(c, struct ep93xx_gpio_chip, chip) |
@@ -111,15 +112,61 @@ static void ep93xx_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip) | |||
111 | { | 112 | { |
112 | struct ep93xx_gpio_chip *ep93xx_chip = to_ep93xx_gpio_chip(chip); | 113 | struct ep93xx_gpio_chip *ep93xx_chip = to_ep93xx_gpio_chip(chip); |
113 | u8 data_reg, data_dir_reg; | 114 | u8 data_reg, data_dir_reg; |
114 | int i; | 115 | int gpio, i; |
115 | 116 | ||
116 | data_reg = __raw_readb(ep93xx_chip->data_reg); | 117 | data_reg = __raw_readb(ep93xx_chip->data_reg); |
117 | data_dir_reg = __raw_readb(ep93xx_chip->data_dir_reg); | 118 | data_dir_reg = __raw_readb(ep93xx_chip->data_dir_reg); |
118 | 119 | ||
119 | for (i = 0; i < chip->ngpio; i++) | 120 | gpio = ep93xx_chip->chip.base; |
120 | seq_printf(s, "GPIO %s%d: %s %s\n", chip->label, i, | 121 | for (i = 0; i < chip->ngpio; i++, gpio++) { |
121 | (data_reg & (1 << i)) ? "set" : "clear", | 122 | int is_out = data_dir_reg & (1 << i); |
122 | (data_dir_reg & (1 << i)) ? "out" : "in"); | 123 | |
124 | seq_printf(s, " %s%d gpio-%-3d (%-12s) %s %s", | ||
125 | chip->label, i, gpio, | ||
126 | gpiochip_is_requested(chip, i) ? : "", | ||
127 | is_out ? "out" : "in ", | ||
128 | (data_reg & (1 << i)) ? "hi" : "lo"); | ||
129 | |||
130 | if (!is_out) { | ||
131 | int irq = gpio_to_irq(gpio); | ||
132 | struct irq_desc *desc = irq_desc + irq; | ||
133 | |||
134 | if (irq >= 0 && desc->action) { | ||
135 | char *trigger; | ||
136 | |||
137 | switch (desc->status & IRQ_TYPE_SENSE_MASK) { | ||
138 | case IRQ_TYPE_NONE: | ||
139 | trigger = "(default)"; | ||
140 | break; | ||
141 | case IRQ_TYPE_EDGE_FALLING: | ||
142 | trigger = "edge-falling"; | ||
143 | break; | ||
144 | case IRQ_TYPE_EDGE_RISING: | ||
145 | trigger = "edge-rising"; | ||
146 | break; | ||
147 | case IRQ_TYPE_EDGE_BOTH: | ||
148 | trigger = "edge-both"; | ||
149 | break; | ||
150 | case IRQ_TYPE_LEVEL_HIGH: | ||
151 | trigger = "level-high"; | ||
152 | break; | ||
153 | case IRQ_TYPE_LEVEL_LOW: | ||
154 | trigger = "level-low"; | ||
155 | break; | ||
156 | default: | ||
157 | trigger = "?trigger?"; | ||
158 | break; | ||
159 | } | ||
160 | |||
161 | seq_printf(s, " irq-%d %s%s", | ||
162 | irq, trigger, | ||
163 | (desc->status & IRQ_WAKEUP) | ||
164 | ? " wakeup" : ""); | ||
165 | } | ||
166 | } | ||
167 | |||
168 | seq_printf(s, "\n"); | ||
169 | } | ||
123 | } | 170 | } |
124 | 171 | ||
125 | #define EP93XX_GPIO_BANK(name, dr, ddr, base_gpio) \ | 172 | #define EP93XX_GPIO_BANK(name, dr, ddr, base_gpio) \ |
diff --git a/arch/arm/mach-ep93xx/include/mach/ep93xx-regs.h b/arch/arm/mach-ep93xx/include/mach/ep93xx-regs.h index 967c079180db..0fbf87b16338 100644 --- a/arch/arm/mach-ep93xx/include/mach/ep93xx-regs.h +++ b/arch/arm/mach-ep93xx/include/mach/ep93xx-regs.h | |||
@@ -52,40 +52,44 @@ | |||
52 | #define EP93XX_AHB_VIRT_BASE 0xfef00000 | 52 | #define EP93XX_AHB_VIRT_BASE 0xfef00000 |
53 | #define EP93XX_AHB_SIZE 0x00100000 | 53 | #define EP93XX_AHB_SIZE 0x00100000 |
54 | 54 | ||
55 | #define EP93XX_AHB_IOMEM(x) IOMEM(EP93XX_AHB_VIRT_BASE + (x)) | ||
56 | |||
55 | #define EP93XX_APB_PHYS_BASE 0x80800000 | 57 | #define EP93XX_APB_PHYS_BASE 0x80800000 |
56 | #define EP93XX_APB_VIRT_BASE 0xfed00000 | 58 | #define EP93XX_APB_VIRT_BASE 0xfed00000 |
57 | #define EP93XX_APB_SIZE 0x00200000 | 59 | #define EP93XX_APB_SIZE 0x00200000 |
58 | 60 | ||
61 | #define EP93XX_APB_IOMEM(x) IOMEM(EP93XX_APB_VIRT_BASE + (x)) | ||
62 | |||
59 | 63 | ||
60 | /* AHB peripherals */ | 64 | /* AHB peripherals */ |
61 | #define EP93XX_DMA_BASE ((void __iomem *) \ | 65 | #define EP93XX_DMA_BASE EP93XX_AHB_IOMEM(0x00000000) |
62 | (EP93XX_AHB_VIRT_BASE + 0x00000000)) | ||
63 | 66 | ||
64 | #define EP93XX_ETHERNET_BASE (EP93XX_AHB_VIRT_BASE + 0x00010000) | ||
65 | #define EP93XX_ETHERNET_PHYS_BASE (EP93XX_AHB_PHYS_BASE + 0x00010000) | 67 | #define EP93XX_ETHERNET_PHYS_BASE (EP93XX_AHB_PHYS_BASE + 0x00010000) |
68 | #define EP93XX_ETHERNET_BASE EP93XX_AHB_IOMEM(0x00010000) | ||
66 | 69 | ||
67 | #define EP93XX_USB_BASE (EP93XX_AHB_VIRT_BASE + 0x00020000) | ||
68 | #define EP93XX_USB_PHYS_BASE (EP93XX_AHB_PHYS_BASE + 0x00020000) | 70 | #define EP93XX_USB_PHYS_BASE (EP93XX_AHB_PHYS_BASE + 0x00020000) |
71 | #define EP93XX_USB_BASE EP93XX_AHB_IOMEM(0x00020000) | ||
69 | 72 | ||
70 | #define EP93XX_RASTER_BASE (EP93XX_AHB_VIRT_BASE + 0x00030000) | 73 | #define EP93XX_RASTER_PHYS_BASE (EP93XX_AHB_PHYS_BASE + 0x00030000) |
74 | #define EP93XX_RASTER_BASE EP93XX_AHB_IOMEM(0x00030000) | ||
71 | 75 | ||
72 | #define EP93XX_GRAPHICS_ACCEL_BASE (EP93XX_AHB_VIRT_BASE + 0x00040000) | 76 | #define EP93XX_GRAPHICS_ACCEL_BASE EP93XX_AHB_IOMEM(0x00040000) |
73 | 77 | ||
74 | #define EP93XX_SDRAM_CONTROLLER_BASE (EP93XX_AHB_VIRT_BASE + 0x00060000) | 78 | #define EP93XX_SDRAM_CONTROLLER_BASE EP93XX_AHB_IOMEM(0x00060000) |
75 | 79 | ||
76 | #define EP93XX_PCMCIA_CONTROLLER_BASE (EP93XX_AHB_VIRT_BASE + 0x00080000) | 80 | #define EP93XX_PCMCIA_CONTROLLER_BASE EP93XX_AHB_IOMEM(0x00080000) |
77 | 81 | ||
78 | #define EP93XX_BOOT_ROM_BASE (EP93XX_AHB_VIRT_BASE + 0x00090000) | 82 | #define EP93XX_BOOT_ROM_BASE EP93XX_AHB_IOMEM(0x00090000) |
79 | 83 | ||
80 | #define EP93XX_IDE_BASE (EP93XX_AHB_VIRT_BASE + 0x000a0000) | 84 | #define EP93XX_IDE_BASE EP93XX_AHB_IOMEM(0x000a0000) |
81 | 85 | ||
82 | #define EP93XX_VIC1_BASE (EP93XX_AHB_VIRT_BASE + 0x000b0000) | 86 | #define EP93XX_VIC1_BASE EP93XX_AHB_IOMEM(0x000b0000) |
83 | 87 | ||
84 | #define EP93XX_VIC2_BASE (EP93XX_AHB_VIRT_BASE + 0x000c0000) | 88 | #define EP93XX_VIC2_BASE EP93XX_AHB_IOMEM(0x000c0000) |
85 | 89 | ||
86 | 90 | ||
87 | /* APB peripherals */ | 91 | /* APB peripherals */ |
88 | #define EP93XX_TIMER_BASE (EP93XX_APB_VIRT_BASE + 0x00010000) | 92 | #define EP93XX_TIMER_BASE EP93XX_APB_IOMEM(0x00010000) |
89 | #define EP93XX_TIMER_REG(x) (EP93XX_TIMER_BASE + (x)) | 93 | #define EP93XX_TIMER_REG(x) (EP93XX_TIMER_BASE + (x)) |
90 | #define EP93XX_TIMER1_LOAD EP93XX_TIMER_REG(0x00) | 94 | #define EP93XX_TIMER1_LOAD EP93XX_TIMER_REG(0x00) |
91 | #define EP93XX_TIMER1_VALUE EP93XX_TIMER_REG(0x04) | 95 | #define EP93XX_TIMER1_VALUE EP93XX_TIMER_REG(0x04) |
@@ -102,11 +106,11 @@ | |||
102 | #define EP93XX_TIMER3_CONTROL EP93XX_TIMER_REG(0x88) | 106 | #define EP93XX_TIMER3_CONTROL EP93XX_TIMER_REG(0x88) |
103 | #define EP93XX_TIMER3_CLEAR EP93XX_TIMER_REG(0x8c) | 107 | #define EP93XX_TIMER3_CLEAR EP93XX_TIMER_REG(0x8c) |
104 | 108 | ||
105 | #define EP93XX_I2S_BASE (EP93XX_APB_VIRT_BASE + 0x00020000) | 109 | #define EP93XX_I2S_BASE EP93XX_APB_IOMEM(0x00020000) |
106 | 110 | ||
107 | #define EP93XX_SECURITY_BASE (EP93XX_APB_VIRT_BASE + 0x00030000) | 111 | #define EP93XX_SECURITY_BASE EP93XX_APB_IOMEM(0x00030000) |
108 | 112 | ||
109 | #define EP93XX_GPIO_BASE (EP93XX_APB_VIRT_BASE + 0x00040000) | 113 | #define EP93XX_GPIO_BASE EP93XX_APB_IOMEM(0x00040000) |
110 | #define EP93XX_GPIO_REG(x) (EP93XX_GPIO_BASE + (x)) | 114 | #define EP93XX_GPIO_REG(x) (EP93XX_GPIO_BASE + (x)) |
111 | #define EP93XX_GPIO_F_INT_TYPE1 EP93XX_GPIO_REG(0x4c) | 115 | #define EP93XX_GPIO_F_INT_TYPE1 EP93XX_GPIO_REG(0x4c) |
112 | #define EP93XX_GPIO_F_INT_TYPE2 EP93XX_GPIO_REG(0x50) | 116 | #define EP93XX_GPIO_F_INT_TYPE2 EP93XX_GPIO_REG(0x50) |
@@ -124,32 +128,33 @@ | |||
124 | #define EP93XX_GPIO_B_INT_ENABLE EP93XX_GPIO_REG(0xb8) | 128 | #define EP93XX_GPIO_B_INT_ENABLE EP93XX_GPIO_REG(0xb8) |
125 | #define EP93XX_GPIO_B_INT_STATUS EP93XX_GPIO_REG(0xbc) | 129 | #define EP93XX_GPIO_B_INT_STATUS EP93XX_GPIO_REG(0xbc) |
126 | 130 | ||
127 | #define EP93XX_AAC_BASE (EP93XX_APB_VIRT_BASE + 0x00080000) | 131 | #define EP93XX_AAC_BASE EP93XX_APB_IOMEM(0x00080000) |
128 | 132 | ||
129 | #define EP93XX_SPI_BASE (EP93XX_APB_VIRT_BASE + 0x000a0000) | 133 | #define EP93XX_SPI_BASE EP93XX_APB_IOMEM(0x000a0000) |
130 | 134 | ||
131 | #define EP93XX_IRDA_BASE (EP93XX_APB_VIRT_BASE + 0x000b0000) | 135 | #define EP93XX_IRDA_BASE EP93XX_APB_IOMEM(0x000b0000) |
132 | 136 | ||
133 | #define EP93XX_UART1_BASE (EP93XX_APB_VIRT_BASE + 0x000c0000) | ||
134 | #define EP93XX_UART1_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x000c0000) | 137 | #define EP93XX_UART1_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x000c0000) |
138 | #define EP93XX_UART1_BASE EP93XX_APB_IOMEM(0x000c0000) | ||
135 | 139 | ||
136 | #define EP93XX_UART2_BASE (EP93XX_APB_VIRT_BASE + 0x000d0000) | ||
137 | #define EP93XX_UART2_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x000d0000) | 140 | #define EP93XX_UART2_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x000d0000) |
141 | #define EP93XX_UART2_BASE EP93XX_APB_IOMEM(0x000d0000) | ||
138 | 142 | ||
139 | #define EP93XX_UART3_BASE (EP93XX_APB_VIRT_BASE + 0x000e0000) | ||
140 | #define EP93XX_UART3_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x000e0000) | 143 | #define EP93XX_UART3_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x000e0000) |
144 | #define EP93XX_UART3_BASE EP93XX_APB_IOMEM(0x000e0000) | ||
141 | 145 | ||
142 | #define EP93XX_KEY_MATRIX_BASE (EP93XX_APB_VIRT_BASE + 0x000f0000) | 146 | #define EP93XX_KEY_MATRIX_BASE EP93XX_APB_IOMEM(0x000f0000) |
143 | 147 | ||
144 | #define EP93XX_ADC_BASE (EP93XX_APB_VIRT_BASE + 0x00100000) | 148 | #define EP93XX_ADC_BASE EP93XX_APB_IOMEM(0x00100000) |
145 | #define EP93XX_TOUCHSCREEN_BASE (EP93XX_APB_VIRT_BASE + 0x00100000) | 149 | #define EP93XX_TOUCHSCREEN_BASE EP93XX_APB_IOMEM(0x00100000) |
146 | 150 | ||
147 | #define EP93XX_PWM_BASE (EP93XX_APB_VIRT_BASE + 0x00110000) | 151 | #define EP93XX_PWM_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x00110000) |
152 | #define EP93XX_PWM_BASE EP93XX_APB_IOMEM(0x00110000) | ||
148 | 153 | ||
149 | #define EP93XX_RTC_BASE (EP93XX_APB_VIRT_BASE + 0x00120000) | ||
150 | #define EP93XX_RTC_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x00120000) | 154 | #define EP93XX_RTC_PHYS_BASE (EP93XX_APB_PHYS_BASE + 0x00120000) |
155 | #define EP93XX_RTC_BASE EP93XX_APB_IOMEM(0x00120000) | ||
151 | 156 | ||
152 | #define EP93XX_SYSCON_BASE (EP93XX_APB_VIRT_BASE + 0x00130000) | 157 | #define EP93XX_SYSCON_BASE EP93XX_APB_IOMEM(0x00130000) |
153 | #define EP93XX_SYSCON_REG(x) (EP93XX_SYSCON_BASE + (x)) | 158 | #define EP93XX_SYSCON_REG(x) (EP93XX_SYSCON_BASE + (x)) |
154 | #define EP93XX_SYSCON_POWER_STATE EP93XX_SYSCON_REG(0x00) | 159 | #define EP93XX_SYSCON_POWER_STATE EP93XX_SYSCON_REG(0x00) |
155 | #define EP93XX_SYSCON_PWRCNT EP93XX_SYSCON_REG(0x04) | 160 | #define EP93XX_SYSCON_PWRCNT EP93XX_SYSCON_REG(0x04) |
@@ -172,14 +177,50 @@ | |||
172 | #define EP93XX_SYSCON_STANDBY EP93XX_SYSCON_REG(0x0c) | 177 | #define EP93XX_SYSCON_STANDBY EP93XX_SYSCON_REG(0x0c) |
173 | #define EP93XX_SYSCON_CLOCK_SET1 EP93XX_SYSCON_REG(0x20) | 178 | #define EP93XX_SYSCON_CLOCK_SET1 EP93XX_SYSCON_REG(0x20) |
174 | #define EP93XX_SYSCON_CLOCK_SET2 EP93XX_SYSCON_REG(0x24) | 179 | #define EP93XX_SYSCON_CLOCK_SET2 EP93XX_SYSCON_REG(0x24) |
175 | #define EP93XX_SYSCON_DEVICE_CONFIG EP93XX_SYSCON_REG(0x80) | 180 | #define EP93XX_SYSCON_DEVCFG EP93XX_SYSCON_REG(0x80) |
176 | #define EP93XX_SYSCON_DEVICE_CONFIG_U3EN (1<<24) | 181 | #define EP93XX_SYSCON_DEVCFG_SWRST (1<<31) |
177 | #define EP93XX_SYSCON_DEVICE_CONFIG_CRUNCH_ENABLE (1<<23) | 182 | #define EP93XX_SYSCON_DEVCFG_D1ONG (1<<30) |
178 | #define EP93XX_SYSCON_DEVICE_CONFIG_U2EN (1<<20) | 183 | #define EP93XX_SYSCON_DEVCFG_D0ONG (1<<29) |
179 | #define EP93XX_SYSCON_DEVICE_CONFIG_U1EN (1<<18) | 184 | #define EP93XX_SYSCON_DEVCFG_IONU2 (1<<28) |
185 | #define EP93XX_SYSCON_DEVCFG_GONK (1<<27) | ||
186 | #define EP93XX_SYSCON_DEVCFG_TONG (1<<26) | ||
187 | #define EP93XX_SYSCON_DEVCFG_MONG (1<<25) | ||
188 | #define EP93XX_SYSCON_DEVCFG_U3EN (1<<24) | ||
189 | #define EP93XX_SYSCON_DEVCFG_CPENA (1<<23) | ||
190 | #define EP93XX_SYSCON_DEVCFG_A2ONG (1<<22) | ||
191 | #define EP93XX_SYSCON_DEVCFG_A1ONG (1<<21) | ||
192 | #define EP93XX_SYSCON_DEVCFG_U2EN (1<<20) | ||
193 | #define EP93XX_SYSCON_DEVCFG_EXVC (1<<19) | ||
194 | #define EP93XX_SYSCON_DEVCFG_U1EN (1<<18) | ||
195 | #define EP93XX_SYSCON_DEVCFG_TIN (1<<17) | ||
196 | #define EP93XX_SYSCON_DEVCFG_HC3IN (1<<15) | ||
197 | #define EP93XX_SYSCON_DEVCFG_HC3EN (1<<14) | ||
198 | #define EP93XX_SYSCON_DEVCFG_HC1IN (1<<13) | ||
199 | #define EP93XX_SYSCON_DEVCFG_HC1EN (1<<12) | ||
200 | #define EP93XX_SYSCON_DEVCFG_HONIDE (1<<11) | ||
201 | #define EP93XX_SYSCON_DEVCFG_GONIDE (1<<10) | ||
202 | #define EP93XX_SYSCON_DEVCFG_PONG (1<<9) | ||
203 | #define EP93XX_SYSCON_DEVCFG_EONIDE (1<<8) | ||
204 | #define EP93XX_SYSCON_DEVCFG_I2SONSSP (1<<7) | ||
205 | #define EP93XX_SYSCON_DEVCFG_I2SONAC97 (1<<6) | ||
206 | #define EP93XX_SYSCON_DEVCFG_RASONP3 (1<<4) | ||
207 | #define EP93XX_SYSCON_DEVCFG_RAS (1<<3) | ||
208 | #define EP93XX_SYSCON_DEVCFG_ADCPD (1<<2) | ||
209 | #define EP93XX_SYSCON_DEVCFG_KEYS (1<<1) | ||
210 | #define EP93XX_SYSCON_DEVCFG_SHENA (1<<0) | ||
211 | #define EP93XX_SYSCON_VIDCLKDIV EP93XX_SYSCON_REG(0x84) | ||
212 | #define EP93XX_SYSCON_CLKDIV_ENABLE (1<<15) | ||
213 | #define EP93XX_SYSCON_CLKDIV_ESEL (1<<14) | ||
214 | #define EP93XX_SYSCON_CLKDIV_PSEL (1<<13) | ||
215 | #define EP93XX_SYSCON_CLKDIV_PDIV_SHIFT 8 | ||
216 | #define EP93XX_SYSCON_KEYTCHCLKDIV EP93XX_SYSCON_REG(0x90) | ||
217 | #define EP93XX_SYSCON_KEYTCHCLKDIV_TSEN (1<<31) | ||
218 | #define EP93XX_SYSCON_KEYTCHCLKDIV_ADIV (1<<16) | ||
219 | #define EP93XX_SYSCON_KEYTCHCLKDIV_KEN (1<<15) | ||
220 | #define EP93XX_SYSCON_KEYTCHCLKDIV_KDIV (1<<0) | ||
180 | #define EP93XX_SYSCON_SWLOCK EP93XX_SYSCON_REG(0xc0) | 221 | #define EP93XX_SYSCON_SWLOCK EP93XX_SYSCON_REG(0xc0) |
181 | 222 | ||
182 | #define EP93XX_WATCHDOG_BASE (EP93XX_APB_VIRT_BASE + 0x00140000) | 223 | #define EP93XX_WATCHDOG_BASE EP93XX_APB_IOMEM(0x00140000) |
183 | 224 | ||
184 | 225 | ||
185 | #endif | 226 | #endif |
diff --git a/arch/arm/mach-ep93xx/include/mach/fb.h b/arch/arm/mach-ep93xx/include/mach/fb.h new file mode 100644 index 000000000000..d5ae11d7c453 --- /dev/null +++ b/arch/arm/mach-ep93xx/include/mach/fb.h | |||
@@ -0,0 +1,56 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-ep93xx/include/mach/fb.h | ||
3 | */ | ||
4 | |||
5 | #ifndef __ASM_ARCH_EP93XXFB_H | ||
6 | #define __ASM_ARCH_EP93XXFB_H | ||
7 | |||
8 | struct platform_device; | ||
9 | struct fb_videomode; | ||
10 | struct fb_info; | ||
11 | |||
12 | #define EP93XXFB_USE_MODEDB 0 | ||
13 | |||
14 | /* VideoAttributes flags */ | ||
15 | #define EP93XXFB_STATE_MACHINE_ENABLE (1 << 0) | ||
16 | #define EP93XXFB_PIXEL_CLOCK_ENABLE (1 << 1) | ||
17 | #define EP93XXFB_VSYNC_ENABLE (1 << 2) | ||
18 | #define EP93XXFB_PIXEL_DATA_ENABLE (1 << 3) | ||
19 | #define EP93XXFB_COMPOSITE_SYNC (1 << 4) | ||
20 | #define EP93XXFB_SYNC_VERT_HIGH (1 << 5) | ||
21 | #define EP93XXFB_SYNC_HORIZ_HIGH (1 << 6) | ||
22 | #define EP93XXFB_SYNC_BLANK_HIGH (1 << 7) | ||
23 | #define EP93XXFB_PCLK_FALLING (1 << 8) | ||
24 | #define EP93XXFB_ENABLE_AC (1 << 9) | ||
25 | #define EP93XXFB_ENABLE_LCD (1 << 10) | ||
26 | #define EP93XXFB_ENABLE_CCIR (1 << 12) | ||
27 | #define EP93XXFB_USE_PARALLEL_INTERFACE (1 << 13) | ||
28 | #define EP93XXFB_ENABLE_INTERRUPT (1 << 14) | ||
29 | #define EP93XXFB_USB_INTERLACE (1 << 16) | ||
30 | #define EP93XXFB_USE_EQUALIZATION (1 << 17) | ||
31 | #define EP93XXFB_USE_DOUBLE_HORZ (1 << 18) | ||
32 | #define EP93XXFB_USE_DOUBLE_VERT (1 << 19) | ||
33 | #define EP93XXFB_USE_BLANK_PIXEL (1 << 20) | ||
34 | #define EP93XXFB_USE_SDCSN0 (0 << 21) | ||
35 | #define EP93XXFB_USE_SDCSN1 (1 << 21) | ||
36 | #define EP93XXFB_USE_SDCSN2 (2 << 21) | ||
37 | #define EP93XXFB_USE_SDCSN3 (3 << 21) | ||
38 | |||
39 | #define EP93XXFB_ENABLE (EP93XXFB_STATE_MACHINE_ENABLE | \ | ||
40 | EP93XXFB_PIXEL_CLOCK_ENABLE | \ | ||
41 | EP93XXFB_VSYNC_ENABLE | \ | ||
42 | EP93XXFB_PIXEL_DATA_ENABLE) | ||
43 | |||
44 | struct ep93xxfb_mach_info { | ||
45 | unsigned int num_modes; | ||
46 | const struct fb_videomode *modes; | ||
47 | const struct fb_videomode *default_mode; | ||
48 | int bpp; | ||
49 | unsigned int flags; | ||
50 | |||
51 | int (*setup)(struct platform_device *pdev); | ||
52 | void (*teardown)(struct platform_device *pdev); | ||
53 | void (*blank)(int blank_mode, struct fb_info *info); | ||
54 | }; | ||
55 | |||
56 | #endif /* __ASM_ARCH_EP93XXFB_H */ | ||
diff --git a/arch/arm/mach-ep93xx/include/mach/hardware.h b/arch/arm/mach-ep93xx/include/mach/hardware.h index 2866297310b7..349fa7cb72d5 100644 --- a/arch/arm/mach-ep93xx/include/mach/hardware.h +++ b/arch/arm/mach-ep93xx/include/mach/hardware.h | |||
@@ -4,12 +4,23 @@ | |||
4 | #ifndef __ASM_ARCH_HARDWARE_H | 4 | #ifndef __ASM_ARCH_HARDWARE_H |
5 | #define __ASM_ARCH_HARDWARE_H | 5 | #define __ASM_ARCH_HARDWARE_H |
6 | 6 | ||
7 | #include "ep93xx-regs.h" | 7 | #include <mach/ep93xx-regs.h> |
8 | #include <mach/platform.h> | ||
8 | 9 | ||
9 | #define pcibios_assign_all_busses() 0 | 10 | #define pcibios_assign_all_busses() 0 |
10 | 11 | ||
11 | #include "platform.h" | 12 | /* |
13 | * The EP93xx has two external crystal oscillators. To generate the | ||
14 | * required high-frequency clocks, the processor uses two phase-locked- | ||
15 | * loops (PLLs) to multiply the incoming external clock signal to much | ||
16 | * higher frequencies that are then divided down by programmable dividers | ||
17 | * to produce the needed clocks. The PLLs operate independently of one | ||
18 | * another. | ||
19 | */ | ||
20 | #define EP93XX_EXT_CLK_RATE 14745600 | ||
21 | #define EP93XX_EXT_RTC_RATE 32768 | ||
12 | 22 | ||
13 | #include "ts72xx.h" | 23 | #define EP93XX_KEYTCHCLK_DIV4 (EP93XX_EXT_CLK_RATE / 4) |
24 | #define EP93XX_KEYTCHCLK_DIV16 (EP93XX_EXT_CLK_RATE / 16) | ||
14 | 25 | ||
15 | #endif | 26 | #endif |
diff --git a/arch/arm/mach-ep93xx/include/mach/io.h b/arch/arm/mach-ep93xx/include/mach/io.h index fd5f081cc8b7..cebcc1c53d63 100644 --- a/arch/arm/mach-ep93xx/include/mach/io.h +++ b/arch/arm/mach-ep93xx/include/mach/io.h | |||
@@ -1,8 +1,21 @@ | |||
1 | /* | 1 | /* |
2 | * arch/arm/mach-ep93xx/include/mach/io.h | 2 | * arch/arm/mach-ep93xx/include/mach/io.h |
3 | */ | 3 | */ |
4 | #ifndef __ASM_MACH_IO_H | ||
5 | #define __ASM_MACH_IO_H | ||
4 | 6 | ||
5 | #define IO_SPACE_LIMIT 0xffffffff | 7 | #define IO_SPACE_LIMIT 0xffffffff |
6 | 8 | ||
7 | #define __io(p) __typesafe_io(p) | 9 | #define __io(p) __typesafe_io(p) |
8 | #define __mem_pci(p) (p) | 10 | #define __mem_pci(p) (p) |
11 | |||
12 | /* | ||
13 | * A typesafe __io() variation for variable initialisers | ||
14 | */ | ||
15 | #ifdef __ASSEMBLER__ | ||
16 | #define IOMEM(p) p | ||
17 | #else | ||
18 | #define IOMEM(p) ((void __iomem __force *)(p)) | ||
19 | #endif | ||
20 | |||
21 | #endif /* __ASM_MACH_IO_H */ | ||
diff --git a/arch/arm/mach-ep93xx/include/mach/platform.h b/arch/arm/mach-ep93xx/include/mach/platform.h index 05f0f4f2f3ce..01a0f0838e5b 100644 --- a/arch/arm/mach-ep93xx/include/mach/platform.h +++ b/arch/arm/mach-ep93xx/include/mach/platform.h | |||
@@ -5,6 +5,8 @@ | |||
5 | #ifndef __ASSEMBLY__ | 5 | #ifndef __ASSEMBLY__ |
6 | 6 | ||
7 | struct i2c_board_info; | 7 | struct i2c_board_info; |
8 | struct platform_device; | ||
9 | struct ep93xxfb_mach_info; | ||
8 | 10 | ||
9 | struct ep93xx_eth_data | 11 | struct ep93xx_eth_data |
10 | { | 12 | { |
@@ -15,8 +17,28 @@ struct ep93xx_eth_data | |||
15 | void ep93xx_map_io(void); | 17 | void ep93xx_map_io(void); |
16 | void ep93xx_init_irq(void); | 18 | void ep93xx_init_irq(void); |
17 | void ep93xx_init_time(unsigned long); | 19 | void ep93xx_init_time(unsigned long); |
20 | |||
21 | /* EP93xx System Controller software locked register write */ | ||
22 | void ep93xx_syscon_swlocked_write(unsigned int val, void __iomem *reg); | ||
23 | void ep93xx_devcfg_set_clear(unsigned int set_bits, unsigned int clear_bits); | ||
24 | |||
25 | static inline void ep93xx_devcfg_set_bits(unsigned int bits) | ||
26 | { | ||
27 | ep93xx_devcfg_set_clear(bits, 0x00); | ||
28 | } | ||
29 | |||
30 | static inline void ep93xx_devcfg_clear_bits(unsigned int bits) | ||
31 | { | ||
32 | ep93xx_devcfg_set_clear(0x00, bits); | ||
33 | } | ||
34 | |||
18 | void ep93xx_register_eth(struct ep93xx_eth_data *data, int copy_addr); | 35 | void ep93xx_register_eth(struct ep93xx_eth_data *data, int copy_addr); |
19 | void ep93xx_register_i2c(struct i2c_board_info *devices, int num); | 36 | void ep93xx_register_i2c(struct i2c_board_info *devices, int num); |
37 | void ep93xx_register_fb(struct ep93xxfb_mach_info *data); | ||
38 | void ep93xx_register_pwm(int pwm0, int pwm1); | ||
39 | int ep93xx_pwm_acquire_gpio(struct platform_device *pdev); | ||
40 | void ep93xx_pwm_release_gpio(struct platform_device *pdev); | ||
41 | |||
20 | void ep93xx_init_devices(void); | 42 | void ep93xx_init_devices(void); |
21 | extern struct sys_timer ep93xx_timer; | 43 | extern struct sys_timer ep93xx_timer; |
22 | 44 | ||
diff --git a/arch/arm/mach-ep93xx/include/mach/system.h b/arch/arm/mach-ep93xx/include/mach/system.h index ed8f35e4f068..6d661fe9d66c 100644 --- a/arch/arm/mach-ep93xx/include/mach/system.h +++ b/arch/arm/mach-ep93xx/include/mach/system.h | |||
@@ -11,15 +11,13 @@ static inline void arch_idle(void) | |||
11 | 11 | ||
12 | static inline void arch_reset(char mode, const char *cmd) | 12 | static inline void arch_reset(char mode, const char *cmd) |
13 | { | 13 | { |
14 | u32 devicecfg; | ||
15 | |||
16 | local_irq_disable(); | 14 | local_irq_disable(); |
17 | 15 | ||
18 | devicecfg = __raw_readl(EP93XX_SYSCON_DEVICE_CONFIG); | 16 | /* |
19 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | 17 | * Set then clear the SWRST bit to initiate a software reset |
20 | __raw_writel(devicecfg | 0x80000000, EP93XX_SYSCON_DEVICE_CONFIG); | 18 | */ |
21 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | 19 | ep93xx_devcfg_set_bits(EP93XX_SYSCON_DEVCFG_SWRST); |
22 | __raw_writel(devicecfg & ~0x80000000, EP93XX_SYSCON_DEVICE_CONFIG); | 20 | ep93xx_devcfg_clear_bits(EP93XX_SYSCON_DEVCFG_SWRST); |
23 | 21 | ||
24 | while (1) | 22 | while (1) |
25 | ; | 23 | ; |
diff --git a/arch/arm/mach-ep93xx/include/mach/ts72xx.h b/arch/arm/mach-ep93xx/include/mach/ts72xx.h index 411734422c1d..3bd934e9a7f1 100644 --- a/arch/arm/mach-ep93xx/include/mach/ts72xx.h +++ b/arch/arm/mach-ep93xx/include/mach/ts72xx.h | |||
@@ -67,7 +67,6 @@ | |||
67 | 67 | ||
68 | 68 | ||
69 | #ifndef __ASSEMBLY__ | 69 | #ifndef __ASSEMBLY__ |
70 | #include <linux/io.h> | ||
71 | 70 | ||
72 | static inline int board_is_ts7200(void) | 71 | static inline int board_is_ts7200(void) |
73 | { | 72 | { |
diff --git a/arch/arm/mach-ep93xx/micro9.c b/arch/arm/mach-ep93xx/micro9.c index 15d6815d78c4..0a313e82fb74 100644 --- a/arch/arm/mach-ep93xx/micro9.c +++ b/arch/arm/mach-ep93xx/micro9.c | |||
@@ -9,21 +9,16 @@ | |||
9 | * published by the Free Software Foundation. | 9 | * published by the Free Software Foundation. |
10 | */ | 10 | */ |
11 | 11 | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/interrupt.h> | ||
14 | #include <linux/ioport.h> | ||
15 | #include <linux/kernel.h> | 12 | #include <linux/kernel.h> |
16 | #include <linux/mm.h> | 13 | #include <linux/init.h> |
17 | #include <linux/platform_device.h> | 14 | #include <linux/platform_device.h> |
18 | #include <linux/sched.h> | ||
19 | #include <linux/io.h> | ||
20 | #include <linux/i2c.h> | ||
21 | #include <linux/mtd/physmap.h> | 15 | #include <linux/mtd/physmap.h> |
22 | 16 | ||
23 | #include <mach/hardware.h> | 17 | #include <mach/hardware.h> |
24 | 18 | ||
25 | #include <asm/mach/arch.h> | ||
26 | #include <asm/mach-types.h> | 19 | #include <asm/mach-types.h> |
20 | #include <asm/mach/arch.h> | ||
21 | |||
27 | 22 | ||
28 | static struct ep93xx_eth_data micro9_eth_data = { | 23 | static struct ep93xx_eth_data micro9_eth_data = { |
29 | .phy_id = 0x1f, | 24 | .phy_id = 0x1f, |
diff --git a/arch/arm/mach-ep93xx/ts72xx.c b/arch/arm/mach-ep93xx/ts72xx.c index aaf1371412af..259f7822ba52 100644 --- a/arch/arm/mach-ep93xx/ts72xx.c +++ b/arch/arm/mach-ep93xx/ts72xx.c | |||
@@ -12,19 +12,18 @@ | |||
12 | 12 | ||
13 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
15 | #include <linux/mm.h> | ||
16 | #include <linux/sched.h> | ||
17 | #include <linux/interrupt.h> | ||
18 | #include <linux/ioport.h> | ||
19 | #include <linux/mtd/physmap.h> | ||
20 | #include <linux/platform_device.h> | 15 | #include <linux/platform_device.h> |
21 | #include <linux/m48t86.h> | ||
22 | #include <linux/io.h> | 16 | #include <linux/io.h> |
23 | #include <linux/i2c.h> | 17 | #include <linux/m48t86.h> |
18 | #include <linux/mtd/physmap.h> | ||
19 | |||
24 | #include <mach/hardware.h> | 20 | #include <mach/hardware.h> |
21 | #include <mach/ts72xx.h> | ||
22 | |||
25 | #include <asm/mach-types.h> | 23 | #include <asm/mach-types.h> |
26 | #include <asm/mach/arch.h> | ||
27 | #include <asm/mach/map.h> | 24 | #include <asm/mach/map.h> |
25 | #include <asm/mach/arch.h> | ||
26 | |||
28 | 27 | ||
29 | static struct map_desc ts72xx_io_desc[] __initdata = { | 28 | static struct map_desc ts72xx_io_desc[] __initdata = { |
30 | { | 29 | { |