SAN People | 73a59c1 | 2006-01-09 17:05:41 +0000 | [diff] [blame] | 1 | /* |
Andrew Victor | 9d04126 | 2007-02-05 11:42:07 +0100 | [diff] [blame] | 2 | * linux/arch/arm/mach-at91/generic.h |
SAN People | 73a59c1 | 2006-01-09 17:05:41 +0000 | [diff] [blame] | 3 | * |
| 4 | * Copyright (C) 2005 David Brownell |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License version 2 as |
| 8 | * published by the Free Software Foundation. |
| 9 | */ |
| 10 | |
Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 11 | /* Processors */ |
Andrew Victor | f217383 | 2006-09-27 13:23:00 +0100 | [diff] [blame] | 12 | extern void __init at91rm9200_initialize(unsigned long main_clock, unsigned short banks); |
Andrew Victor | 62c1660 | 2006-11-30 12:27:38 +0100 | [diff] [blame] | 13 | extern void __init at91sam9260_initialize(unsigned long main_clock); |
| 14 | extern void __init at91sam9261_initialize(unsigned long main_clock); |
Andrew Victor | b2c6561 | 2007-02-08 09:42:40 +0100 | [diff] [blame] | 15 | extern void __init at91sam9263_initialize(unsigned long main_clock); |
Andrew Victor | 877d772 | 2007-05-11 20:49:56 +0100 | [diff] [blame] | 16 | extern void __init at91sam9rl_initialize(unsigned long main_clock); |
Greg Ungerer | 9a7e246 | 2007-07-30 02:39:02 +0100 | [diff] [blame] | 17 | extern void __init at91x40_initialize(unsigned long main_clock); |
Andrew Victor | 2b3b351 | 2008-01-24 15:10:39 +0100 | [diff] [blame] | 18 | extern void __init at91cap9_initialize(unsigned long main_clock); |
Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 19 | |
Andrew Victor | ba854e1 | 2006-07-05 17:22:52 +0100 | [diff] [blame] | 20 | /* Interrupts */ |
Andrew Victor | f217383 | 2006-09-27 13:23:00 +0100 | [diff] [blame] | 21 | extern void __init at91rm9200_init_interrupts(unsigned int priority[]); |
Andrew Victor | 62c1660 | 2006-11-30 12:27:38 +0100 | [diff] [blame] | 22 | extern void __init at91sam9260_init_interrupts(unsigned int priority[]); |
| 23 | extern void __init at91sam9261_init_interrupts(unsigned int priority[]); |
Andrew Victor | b2c6561 | 2007-02-08 09:42:40 +0100 | [diff] [blame] | 24 | extern void __init at91sam9263_init_interrupts(unsigned int priority[]); |
Andrew Victor | 877d772 | 2007-05-11 20:49:56 +0100 | [diff] [blame] | 25 | extern void __init at91sam9rl_init_interrupts(unsigned int priority[]); |
Greg Ungerer | 9a7e246 | 2007-07-30 02:39:02 +0100 | [diff] [blame] | 26 | extern void __init at91x40_init_interrupts(unsigned int priority[]); |
Andrew Victor | 2b3b351 | 2008-01-24 15:10:39 +0100 | [diff] [blame] | 27 | extern void __init at91cap9_init_interrupts(unsigned int priority[]); |
Andrew Victor | ba854e1 | 2006-07-05 17:22:52 +0100 | [diff] [blame] | 28 | extern void __init at91_aic_init(unsigned int priority[]); |
SAN People | 73a59c1 | 2006-01-09 17:05:41 +0000 | [diff] [blame] | 29 | |
Andrew Victor | ba854e1 | 2006-07-05 17:22:52 +0100 | [diff] [blame] | 30 | /* Timer */ |
SAN People | 73a59c1 | 2006-01-09 17:05:41 +0000 | [diff] [blame] | 31 | struct sys_timer; |
| 32 | extern struct sys_timer at91rm9200_timer; |
Andrew Victor | 62c1660 | 2006-11-30 12:27:38 +0100 | [diff] [blame] | 33 | extern struct sys_timer at91sam926x_timer; |
Greg Ungerer | 9a7e246 | 2007-07-30 02:39:02 +0100 | [diff] [blame] | 34 | extern struct sys_timer at91x40_timer; |
SAN People | 73a59c1 | 2006-01-09 17:05:41 +0000 | [diff] [blame] | 35 | |
Andrew Victor | ba854e1 | 2006-07-05 17:22:52 +0100 | [diff] [blame] | 36 | /* Clocks */ |
SAN People | 73a59c1 | 2006-01-09 17:05:41 +0000 | [diff] [blame] | 37 | extern int __init at91_clock_init(unsigned long main_clock); |
Andrew Victor | 907d6de | 2006-06-20 19:30:19 +0100 | [diff] [blame] | 38 | struct device; |
| 39 | extern void __init at91_clock_associate(const char *id, struct device *dev, const char *func); |
| 40 | |
| 41 | /* Power Management */ |
| 42 | extern void at91_irq_suspend(void); |
| 43 | extern void at91_irq_resume(void); |
| 44 | |
Andrew Victor | f217383 | 2006-09-27 13:23:00 +0100 | [diff] [blame] | 45 | /* GPIO */ |
| 46 | #define AT91RM9200_PQFP 3 /* AT91RM9200 PQFP package has 3 banks */ |
| 47 | #define AT91RM9200_BGA 4 /* AT91RM9200 BGA package has 4 banks */ |
| 48 | |
| 49 | struct at91_gpio_bank { |
David Brownell | e83aff5 | 2008-01-04 18:30:24 +0100 | [diff] [blame] | 50 | unsigned chipbase; /* bank's first GPIO number */ |
| 51 | void __iomem *regbase; /* base of register bank */ |
| 52 | struct at91_gpio_bank *next; /* bank sharing same IRQ/clock/... */ |
Andrew Victor | f217383 | 2006-09-27 13:23:00 +0100 | [diff] [blame] | 53 | unsigned short id; /* peripheral ID */ |
| 54 | unsigned long offset; /* offset from system peripheral base */ |
| 55 | struct clk *clock; /* associated clock */ |
| 56 | }; |
| 57 | extern void __init at91_gpio_init(struct at91_gpio_bank *, int nr_banks); |
| 58 | extern void __init at91_gpio_irq_setup(void); |
Andrew Victor | 1f4fd0a | 2006-11-30 10:01:47 +0100 | [diff] [blame] | 59 | |
| 60 | extern void (*at91_arch_reset)(void); |
| 61 | extern int at91_extern_irq; |