diff options
author | Haavard Skinnemoen <haavard.skinnemoen@atmel.com> | 2009-01-05 09:51:52 -0500 |
---|---|---|
committer | Haavard Skinnemoen <haavard.skinnemoen@atmel.com> | 2009-01-05 09:51:52 -0500 |
commit | bc08969fe638bb164915aadd1dc1a21194847000 (patch) | |
tree | 3164782dc73e9589033b056e0850b37edadfe5ec | |
parent | 4a6908a3a050aacc9c3a2f36b276b46c0629ad91 (diff) | |
parent | adde42b5834ed367ef7455d465bd9610190ad2a0 (diff) |
Merge branch 'cleanups' into boards
-rw-r--r-- | arch/avr32/boards/atstk1000/atstk1002.c | 18 | ||||
-rw-r--r-- | arch/avr32/boards/atstk1000/atstk1003.c | 18 | ||||
-rw-r--r-- | arch/avr32/boards/favr-32/setup.c | 20 | ||||
-rw-r--r-- | arch/avr32/boards/mimc200/setup.c | 2 | ||||
-rw-r--r-- | arch/avr32/kernel/process.c | 1 | ||||
-rw-r--r-- | arch/avr32/kernel/signal.c | 1 | ||||
-rw-r--r-- | arch/avr32/kernel/sys_avr32.c | 1 | ||||
-rw-r--r-- | arch/avr32/mach-at32ap/clock.c | 4 | ||||
-rw-r--r-- | arch/avr32/mach-at32ap/include/mach/at32ap700x.h | 3 | ||||
-rw-r--r-- | arch/avr32/mach-at32ap/include/mach/portmux.h | 2 | ||||
-rw-r--r-- | arch/avr32/mach-at32ap/pio.c | 19 | ||||
-rw-r--r-- | arch/avr32/mm/cache.c | 1 | ||||
-rw-r--r-- | include/asm-avr32/syscalls.h | 39 |
13 files changed, 65 insertions, 64 deletions
diff --git a/arch/avr32/boards/atstk1000/atstk1002.c b/arch/avr32/boards/atstk1000/atstk1002.c index 5c5cdf3b464f..11e7800c1632 100644 --- a/arch/avr32/boards/atstk1000/atstk1002.c +++ b/arch/avr32/boards/atstk1000/atstk1002.c | |||
@@ -287,23 +287,7 @@ static int __init atstk1002_init(void) | |||
287 | * ATSTK1000 uses 32-bit SDRAM interface. Reserve the | 287 | * ATSTK1000 uses 32-bit SDRAM interface. Reserve the |
288 | * SDRAM-specific pins so that nobody messes with them. | 288 | * SDRAM-specific pins so that nobody messes with them. |
289 | */ | 289 | */ |
290 | at32_reserve_pin(GPIO_PIN_PE(0)); /* DATA[16] */ | 290 | at32_reserve_pin(GPIO_PIOE_BASE, ATMEL_EBI_PE_DATA_ALL); |
291 | at32_reserve_pin(GPIO_PIN_PE(1)); /* DATA[17] */ | ||
292 | at32_reserve_pin(GPIO_PIN_PE(2)); /* DATA[18] */ | ||
293 | at32_reserve_pin(GPIO_PIN_PE(3)); /* DATA[19] */ | ||
294 | at32_reserve_pin(GPIO_PIN_PE(4)); /* DATA[20] */ | ||
295 | at32_reserve_pin(GPIO_PIN_PE(5)); /* DATA[21] */ | ||
296 | at32_reserve_pin(GPIO_PIN_PE(6)); /* DATA[22] */ | ||
297 | at32_reserve_pin(GPIO_PIN_PE(7)); /* DATA[23] */ | ||
298 | at32_reserve_pin(GPIO_PIN_PE(8)); /* DATA[24] */ | ||
299 | at32_reserve_pin(GPIO_PIN_PE(9)); /* DATA[25] */ | ||
300 | at32_reserve_pin(GPIO_PIN_PE(10)); /* DATA[26] */ | ||
301 | at32_reserve_pin(GPIO_PIN_PE(11)); /* DATA[27] */ | ||
302 | at32_reserve_pin(GPIO_PIN_PE(12)); /* DATA[28] */ | ||
303 | at32_reserve_pin(GPIO_PIN_PE(13)); /* DATA[29] */ | ||
304 | at32_reserve_pin(GPIO_PIN_PE(14)); /* DATA[30] */ | ||
305 | at32_reserve_pin(GPIO_PIN_PE(15)); /* DATA[31] */ | ||
306 | at32_reserve_pin(GPIO_PIN_PE(26)); /* SDCS */ | ||
307 | 291 | ||
308 | #ifdef CONFIG_BOARD_ATSTK1006 | 292 | #ifdef CONFIG_BOARD_ATSTK1006 |
309 | smc_set_timing(&nand_config, &nand_timing); | 293 | smc_set_timing(&nand_config, &nand_timing); |
diff --git a/arch/avr32/boards/atstk1000/atstk1003.c b/arch/avr32/boards/atstk1000/atstk1003.c index 134b566630b0..ac31666613a1 100644 --- a/arch/avr32/boards/atstk1000/atstk1003.c +++ b/arch/avr32/boards/atstk1000/atstk1003.c | |||
@@ -131,23 +131,7 @@ static int __init atstk1003_init(void) | |||
131 | * ATSTK1000 uses 32-bit SDRAM interface. Reserve the | 131 | * ATSTK1000 uses 32-bit SDRAM interface. Reserve the |
132 | * SDRAM-specific pins so that nobody messes with them. | 132 | * SDRAM-specific pins so that nobody messes with them. |
133 | */ | 133 | */ |
134 | at32_reserve_pin(GPIO_PIN_PE(0)); /* DATA[16] */ | 134 | at32_reserve_pin(GPIO_PIOE_BASE, ATMEL_EBI_PE_DATA_ALL); |
135 | at32_reserve_pin(GPIO_PIN_PE(1)); /* DATA[17] */ | ||
136 | at32_reserve_pin(GPIO_PIN_PE(2)); /* DATA[18] */ | ||
137 | at32_reserve_pin(GPIO_PIN_PE(3)); /* DATA[19] */ | ||
138 | at32_reserve_pin(GPIO_PIN_PE(4)); /* DATA[20] */ | ||
139 | at32_reserve_pin(GPIO_PIN_PE(5)); /* DATA[21] */ | ||
140 | at32_reserve_pin(GPIO_PIN_PE(6)); /* DATA[22] */ | ||
141 | at32_reserve_pin(GPIO_PIN_PE(7)); /* DATA[23] */ | ||
142 | at32_reserve_pin(GPIO_PIN_PE(8)); /* DATA[24] */ | ||
143 | at32_reserve_pin(GPIO_PIN_PE(9)); /* DATA[25] */ | ||
144 | at32_reserve_pin(GPIO_PIN_PE(10)); /* DATA[26] */ | ||
145 | at32_reserve_pin(GPIO_PIN_PE(11)); /* DATA[27] */ | ||
146 | at32_reserve_pin(GPIO_PIN_PE(12)); /* DATA[28] */ | ||
147 | at32_reserve_pin(GPIO_PIN_PE(13)); /* DATA[29] */ | ||
148 | at32_reserve_pin(GPIO_PIN_PE(14)); /* DATA[30] */ | ||
149 | at32_reserve_pin(GPIO_PIN_PE(15)); /* DATA[31] */ | ||
150 | at32_reserve_pin(GPIO_PIN_PE(26)); /* SDCS */ | ||
151 | 135 | ||
152 | #ifdef CONFIG_BOARD_ATSTK100X_SW2_CUSTOM | 136 | #ifdef CONFIG_BOARD_ATSTK100X_SW2_CUSTOM |
153 | at32_add_device_usart(1); | 137 | at32_add_device_usart(1); |
diff --git a/arch/avr32/boards/favr-32/setup.c b/arch/avr32/boards/favr-32/setup.c index 1ee4faf0742d..1a12930df8e7 100644 --- a/arch/avr32/boards/favr-32/setup.c +++ b/arch/avr32/boards/favr-32/setup.c | |||
@@ -307,28 +307,10 @@ static int __init favr32_init(void) | |||
307 | * Favr-32 uses 32-bit SDRAM interface. Reserve the SDRAM-specific | 307 | * Favr-32 uses 32-bit SDRAM interface. Reserve the SDRAM-specific |
308 | * pins so that nobody messes with them. | 308 | * pins so that nobody messes with them. |
309 | */ | 309 | */ |
310 | at32_reserve_pin(GPIO_PIN_PE(0)); /* DATA[16] */ | 310 | at32_reserve_pin(GPIO_PIOE_BASE, ATMEL_EBI_PE_DATA_ALL); |
311 | at32_reserve_pin(GPIO_PIN_PE(1)); /* DATA[17] */ | ||
312 | at32_reserve_pin(GPIO_PIN_PE(2)); /* DATA[18] */ | ||
313 | at32_reserve_pin(GPIO_PIN_PE(3)); /* DATA[19] */ | ||
314 | at32_reserve_pin(GPIO_PIN_PE(4)); /* DATA[20] */ | ||
315 | at32_reserve_pin(GPIO_PIN_PE(5)); /* DATA[21] */ | ||
316 | at32_reserve_pin(GPIO_PIN_PE(6)); /* DATA[22] */ | ||
317 | at32_reserve_pin(GPIO_PIN_PE(7)); /* DATA[23] */ | ||
318 | at32_reserve_pin(GPIO_PIN_PE(8)); /* DATA[24] */ | ||
319 | at32_reserve_pin(GPIO_PIN_PE(9)); /* DATA[25] */ | ||
320 | at32_reserve_pin(GPIO_PIN_PE(10)); /* DATA[26] */ | ||
321 | at32_reserve_pin(GPIO_PIN_PE(11)); /* DATA[27] */ | ||
322 | at32_reserve_pin(GPIO_PIN_PE(12)); /* DATA[28] */ | ||
323 | at32_reserve_pin(GPIO_PIN_PE(13)); /* DATA[29] */ | ||
324 | at32_reserve_pin(GPIO_PIN_PE(14)); /* DATA[30] */ | ||
325 | at32_reserve_pin(GPIO_PIN_PE(15)); /* DATA[31] */ | ||
326 | at32_reserve_pin(GPIO_PIN_PE(26)); /* SDCS */ | ||
327 | 311 | ||
328 | at32_select_gpio(GPIO_PIN_PB(3), 0); /* IRQ from ADS7843 */ | 312 | at32_select_gpio(GPIO_PIN_PB(3), 0); /* IRQ from ADS7843 */ |
329 | 313 | ||
330 | at32_add_system_devices(); | ||
331 | |||
332 | at32_add_device_usart(0); | 314 | at32_add_device_usart(0); |
333 | 315 | ||
334 | set_hw_addr(at32_add_device_eth(0, ð_data[0])); | 316 | set_hw_addr(at32_add_device_eth(0, ð_data[0])); |
diff --git a/arch/avr32/boards/mimc200/setup.c b/arch/avr32/boards/mimc200/setup.c index 397cbb8f44c8..c060d4d2839e 100644 --- a/arch/avr32/boards/mimc200/setup.c +++ b/arch/avr32/boards/mimc200/setup.c | |||
@@ -207,8 +207,6 @@ static int __init mimc200_init(void) | |||
207 | * reserve any pins for it. | 207 | * reserve any pins for it. |
208 | */ | 208 | */ |
209 | 209 | ||
210 | at32_add_system_devices(); | ||
211 | |||
212 | at32_add_device_usart(0); | 210 | at32_add_device_usart(0); |
213 | at32_add_device_usart(1); | 211 | at32_add_device_usart(1); |
214 | at32_add_device_usart(2); | 212 | at32_add_device_usart(2); |
diff --git a/arch/avr32/kernel/process.c b/arch/avr32/kernel/process.c index 134d5302b6dd..43ae555ecb33 100644 --- a/arch/avr32/kernel/process.c +++ b/arch/avr32/kernel/process.c | |||
@@ -18,6 +18,7 @@ | |||
18 | 18 | ||
19 | #include <asm/sysreg.h> | 19 | #include <asm/sysreg.h> |
20 | #include <asm/ocd.h> | 20 | #include <asm/ocd.h> |
21 | #include <asm/syscalls.h> | ||
21 | 22 | ||
22 | #include <mach/pm.h> | 23 | #include <mach/pm.h> |
23 | 24 | ||
diff --git a/arch/avr32/kernel/signal.c b/arch/avr32/kernel/signal.c index c5b11f9067f1..803d7be0938f 100644 --- a/arch/avr32/kernel/signal.c +++ b/arch/avr32/kernel/signal.c | |||
@@ -19,6 +19,7 @@ | |||
19 | 19 | ||
20 | #include <asm/uaccess.h> | 20 | #include <asm/uaccess.h> |
21 | #include <asm/ucontext.h> | 21 | #include <asm/ucontext.h> |
22 | #include <asm/syscalls.h> | ||
22 | 23 | ||
23 | #define _BLOCKABLE (~(sigmask(SIGKILL) | sigmask(SIGSTOP))) | 24 | #define _BLOCKABLE (~(sigmask(SIGKILL) | sigmask(SIGSTOP))) |
24 | 25 | ||
diff --git a/arch/avr32/kernel/sys_avr32.c b/arch/avr32/kernel/sys_avr32.c index 8e8911e55c8f..5d2daeaf356f 100644 --- a/arch/avr32/kernel/sys_avr32.c +++ b/arch/avr32/kernel/sys_avr32.c | |||
@@ -13,6 +13,7 @@ | |||
13 | 13 | ||
14 | #include <asm/mman.h> | 14 | #include <asm/mman.h> |
15 | #include <asm/uaccess.h> | 15 | #include <asm/uaccess.h> |
16 | #include <asm/syscalls.h> | ||
16 | 17 | ||
17 | asmlinkage long sys_mmap2(unsigned long addr, unsigned long len, | 18 | asmlinkage long sys_mmap2(unsigned long addr, unsigned long len, |
18 | unsigned long prot, unsigned long flags, | 19 | unsigned long prot, unsigned long flags, |
diff --git a/arch/avr32/mach-at32ap/clock.c b/arch/avr32/mach-at32ap/clock.c index 138a00a2a2d0..442f08c5e641 100644 --- a/arch/avr32/mach-at32ap/clock.c +++ b/arch/avr32/mach-at32ap/clock.c | |||
@@ -198,7 +198,7 @@ dump_clock(struct clk *parent, struct clkinf *r) | |||
198 | unsigned i; | 198 | unsigned i; |
199 | 199 | ||
200 | /* skip clocks coupled to devices that aren't registered */ | 200 | /* skip clocks coupled to devices that aren't registered */ |
201 | if (parent->dev && !parent->dev->bus_id[0] && !parent->users) | 201 | if (parent->dev && !dev_name(parent->dev) && !parent->users) |
202 | return; | 202 | return; |
203 | 203 | ||
204 | /* <nest spaces> name <pad to end> */ | 204 | /* <nest spaces> name <pad to end> */ |
@@ -214,7 +214,7 @@ dump_clock(struct clk *parent, struct clkinf *r) | |||
214 | parent->users ? "on" : "off", /* NOTE: not-paranoid!! */ | 214 | parent->users ? "on" : "off", /* NOTE: not-paranoid!! */ |
215 | clk_get_rate(parent)); | 215 | clk_get_rate(parent)); |
216 | if (parent->dev) | 216 | if (parent->dev) |
217 | seq_printf(r->s, ", for %s", parent->dev->bus_id); | 217 | seq_printf(r->s, ", for %s", dev_name(parent->dev)); |
218 | seq_printf(r->s, "\n"); | 218 | seq_printf(r->s, "\n"); |
219 | 219 | ||
220 | /* cost of this scan is small, but not linear... */ | 220 | /* cost of this scan is small, but not linear... */ |
diff --git a/arch/avr32/mach-at32ap/include/mach/at32ap700x.h b/arch/avr32/mach-at32ap/include/mach/at32ap700x.h index a77d372f6f3e..5c4c971eed8e 100644 --- a/arch/avr32/mach-at32ap/include/mach/at32ap700x.h +++ b/arch/avr32/mach-at32ap/include/mach/at32ap700x.h | |||
@@ -211,4 +211,7 @@ | |||
211 | 211 | ||
212 | #define ATMEL_LCDC_ALT_15BIT (ATMEL_LCDC_CONTROL | ATMEL_LCDC_ALT_15B_DATA) | 212 | #define ATMEL_LCDC_ALT_15BIT (ATMEL_LCDC_CONTROL | ATMEL_LCDC_ALT_15B_DATA) |
213 | 213 | ||
214 | /* Bitmask for all EBI data (D16..D31) pins on port E */ | ||
215 | #define ATMEL_EBI_PE_DATA_ALL (0x0000FFFF) | ||
216 | |||
214 | #endif /* __ASM_ARCH_AT32AP700X_H__ */ | 217 | #endif /* __ASM_ARCH_AT32AP700X_H__ */ |
diff --git a/arch/avr32/mach-at32ap/include/mach/portmux.h b/arch/avr32/mach-at32ap/include/mach/portmux.h index 21c79373b53f..4873024e3b96 100644 --- a/arch/avr32/mach-at32ap/include/mach/portmux.h +++ b/arch/avr32/mach-at32ap/include/mach/portmux.h | |||
@@ -25,6 +25,6 @@ void at32_select_periph(unsigned int port, unsigned int pin, | |||
25 | unsigned int periph, unsigned long flags); | 25 | unsigned int periph, unsigned long flags); |
26 | void at32_select_gpio(unsigned int pin, unsigned long flags); | 26 | void at32_select_gpio(unsigned int pin, unsigned long flags); |
27 | void at32_deselect_pin(unsigned int pin); | 27 | void at32_deselect_pin(unsigned int pin); |
28 | void at32_reserve_pin(unsigned int pin); | 28 | void at32_reserve_pin(unsigned int port, u32 pin_mask); |
29 | 29 | ||
30 | #endif /* __ASM_ARCH_PORTMUX_H__ */ | 30 | #endif /* __ASM_ARCH_PORTMUX_H__ */ |
diff --git a/arch/avr32/mach-at32ap/pio.c b/arch/avr32/mach-at32ap/pio.c index ed81a8bcb22d..09a274c9d0b7 100644 --- a/arch/avr32/mach-at32ap/pio.c +++ b/arch/avr32/mach-at32ap/pio.c | |||
@@ -167,22 +167,29 @@ void at32_deselect_pin(unsigned int pin) | |||
167 | } | 167 | } |
168 | 168 | ||
169 | /* Reserve a pin, preventing anyone else from changing its configuration. */ | 169 | /* Reserve a pin, preventing anyone else from changing its configuration. */ |
170 | void __init at32_reserve_pin(unsigned int pin) | 170 | void __init at32_reserve_pin(unsigned int port, u32 pin_mask) |
171 | { | 171 | { |
172 | struct pio_device *pio; | 172 | struct pio_device *pio; |
173 | unsigned int pin_index = pin & 0x1f; | ||
174 | 173 | ||
175 | pio = gpio_to_pio(pin); | 174 | /* assign and verify pio */ |
175 | pio = gpio_to_pio(port); | ||
176 | if (unlikely(!pio)) { | 176 | if (unlikely(!pio)) { |
177 | printk("pio: invalid pin %u\n", pin); | 177 | printk(KERN_WARNING "pio: invalid port %u\n", port); |
178 | goto fail; | 178 | goto fail; |
179 | } | 179 | } |
180 | 180 | ||
181 | if (unlikely(test_and_set_bit(pin_index, &pio->pinmux_mask))) { | 181 | /* Test if any of the requested pins is already muxed */ |
182 | printk("%s: pin %u is busy\n", pio->name, pin_index); | 182 | spin_lock(&pio_lock); |
183 | if (unlikely(pio->pinmux_mask & pin_mask)) { | ||
184 | printk(KERN_WARNING "%s: pin(s) busy (req. 0x%x, busy 0x%x)\n", | ||
185 | pio->name, pin_mask, pio->pinmux_mask & pin_mask); | ||
186 | spin_unlock(&pio_lock); | ||
183 | goto fail; | 187 | goto fail; |
184 | } | 188 | } |
185 | 189 | ||
190 | /* Reserve pins */ | ||
191 | pio->pinmux_mask |= pin_mask; | ||
192 | spin_unlock(&pio_lock); | ||
186 | return; | 193 | return; |
187 | 194 | ||
188 | fail: | 195 | fail: |
diff --git a/arch/avr32/mm/cache.c b/arch/avr32/mm/cache.c index 15a4e5e142c1..24a74d1ca7d9 100644 --- a/arch/avr32/mm/cache.c +++ b/arch/avr32/mm/cache.c | |||
@@ -13,6 +13,7 @@ | |||
13 | #include <asm/cachectl.h> | 13 | #include <asm/cachectl.h> |
14 | #include <asm/processor.h> | 14 | #include <asm/processor.h> |
15 | #include <asm/uaccess.h> | 15 | #include <asm/uaccess.h> |
16 | #include <asm/syscalls.h> | ||
16 | 17 | ||
17 | /* | 18 | /* |
18 | * If you attempt to flush anything more than this, you need superuser | 19 | * If you attempt to flush anything more than this, you need superuser |
diff --git a/include/asm-avr32/syscalls.h b/include/asm-avr32/syscalls.h new file mode 100644 index 000000000000..483d666c27c0 --- /dev/null +++ b/include/asm-avr32/syscalls.h | |||
@@ -0,0 +1,39 @@ | |||
1 | /* | ||
2 | * syscalls.h - Linux syscall interfaces (arch-specific) | ||
3 | * | ||
4 | * Copyright (c) 2008 Jaswinder Singh | ||
5 | * | ||
6 | * This file is released under the GPLv2. | ||
7 | * See the file COPYING for more details. | ||
8 | */ | ||
9 | |||
10 | #ifndef _ASM_AVR32_SYSCALLS_H | ||
11 | #define _ASM_AVR32_SYSCALLS_H | ||
12 | |||
13 | #include <linux/compiler.h> | ||
14 | #include <linux/linkage.h> | ||
15 | #include <linux/types.h> | ||
16 | #include <linux/signal.h> | ||
17 | |||
18 | /* kernel/process.c */ | ||
19 | asmlinkage int sys_fork(struct pt_regs *); | ||
20 | asmlinkage int sys_clone(unsigned long, unsigned long, | ||
21 | unsigned long, unsigned long, | ||
22 | struct pt_regs *); | ||
23 | asmlinkage int sys_vfork(struct pt_regs *); | ||
24 | asmlinkage int sys_execve(char __user *, char __user *__user *, | ||
25 | char __user *__user *, struct pt_regs *); | ||
26 | |||
27 | /* kernel/signal.c */ | ||
28 | asmlinkage int sys_sigaltstack(const stack_t __user *, stack_t __user *, | ||
29 | struct pt_regs *); | ||
30 | asmlinkage int sys_rt_sigreturn(struct pt_regs *); | ||
31 | |||
32 | /* kernel/sys_avr32.c */ | ||
33 | asmlinkage long sys_mmap2(unsigned long, unsigned long, unsigned long, | ||
34 | unsigned long, unsigned long, off_t); | ||
35 | |||
36 | /* mm/cache.c */ | ||
37 | asmlinkage int sys_cacheflush(int, void __user *, size_t); | ||
38 | |||
39 | #endif /* _ASM_AVR32_SYSCALLS_H */ | ||