fd774b4f33f620c65958551983faa98023e56b57
[karo-tx-uboot.git] / arch / arm / include / asm / arch-at91 / at91rm9200.h
1 /*
2  * See file CREDITS for list of people who contributed to this
3  * project.
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License as
7  * published by the Free Software Foundation; either version 2 of
8  * the License, or (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
18  * MA 02111-1307 USA
19  */
20
21 #ifndef __AT91RM9200_H__
22 #define __AT91RM9200_H__
23
24 #define CONFIG_AT91FAMILY       /* it's a member of AT91 */
25 #define CONFIG_ARCH_CPU_INIT    /* we need arch_cpu_init() for hw timers */
26 #define CONFIG_ARM920T          /* This is an ARM920T Core      */
27
28 /* Periperial Identifiers */
29
30 #define ATMEL_ID_SYS    1       /* System Peripheral */
31 #define ATMEL_ID_PIOA   2       /* PIO port A */
32 #define ATMEL_ID_PIOB   3       /* PIO port B */
33 #define ATMEL_ID_PIOC   4       /* PIO port C */
34 #define ATMEL_ID_PIOD   5       /* PIO port D BGA only */
35 #define ATMEL_ID_USART0 6       /* USART 0 */
36 #define ATMEL_ID_USART1 7       /* USART 1 */
37 #define ATMEL_ID_USART2 8       /* USART 2 */
38 #define ATMEL_ID_USART3 9       /* USART 3 */
39 #define ATMEL_ID_MCI    10      /* Multimedia Card Interface */
40 #define ATMEL_ID_UDP    11      /* USB Device Port */
41 #define ATMEL_ID_TWI    12      /* Two Wire Interface */
42 #define ATMEL_ID_SPI    13      /* Serial Peripheral Interface */
43 #define ATMEL_ID_SSC0   14      /* Synch. Serial Controller 0 */
44 #define ATMEL_ID_SSC1   15      /* Synch. Serial Controller 1 */
45 #define ATMEL_ID_SSC2   16      /* Synch. Serial Controller 2 */
46 #define ATMEL_ID_TC0    17      /* Timer Counter 0 */
47 #define ATMEL_ID_TC1    18      /* Timer Counter 1 */
48 #define ATMEL_ID_TC2    19      /* Timer Counter 2 */
49 #define ATMEL_ID_TC3    20      /* Timer Counter 3 */
50 #define ATMEL_ID_TC4    21      /* Timer Counter 4 */
51 #define ATMEL_ID_TC5    22      /* Timer Counter 5 */
52 #define ATMEL_ID_UHP    23      /* OHCI USB Host Port */
53 #define ATMEL_ID_EMAC   24      /* Ethernet MAC */
54 #define ATMEL_ID_IRQ0   25      /* Advanced Interrupt Controller */
55 #define ATMEL_ID_IRQ1   26      /* Advanced Interrupt Controller */
56 #define ATMEL_ID_IRQ2   27      /* Advanced Interrupt Controller */
57 #define ATMEL_ID_IRQ3   28      /* Advanced Interrupt Controller */
58 #define ATMEL_ID_IRQ4   29      /* Advanced Interrupt Controller */
59 #define ATMEL_ID_IRQ5   30      /* Advanced Interrupt Controller */
60 #define ATMEL_ID_IRQ6   31      /* Advanced Interrupt Controller */
61
62 #define ATMEL_USB_HOST_BASE     0x00300000
63
64 #define ATMEL_BASE_TC           0xFFFA0000
65 #define ATMEL_BASE_UDP          0xFFFB0000
66 #define ATMEL_BASE_MCI          0xFFFB4000
67 #define ATMEL_BASE_TWI          0xFFFB8000
68 #define ATMEL_BASE_EMAC         0xFFFBC000
69 #define ATMEL_BASE_USART        0xFFFC0000      /* 4x 0x4000 Offset */
70 #define ATMEL_BASE_USART0       ATMEL_BASE_USART
71 #define ATMEL_BASE_USART1       (ATMEL_BASE_USART + 0x4000)
72 #define ATMEL_BASE_USART2       (ATMEL_BASE_USART + 0x8000)
73 #define ATMEL_BASE_USART3       (ATMEL_BASE_USART + 0xC000)
74
75 #define ATMEL_BASE_SCC          0xFFFD0000      /* 4x 0x4000 Offset */
76 #define ATMEL_BASE_SPI          0xFFFE0000
77
78 #define ATMEL_BASE_AIC          0xFFFFF000
79 #define ATMEL_BASE_DBGU         0xFFFFF200
80 #define ATMEL_BASE_PIO          0xFFFFF400      /* 4x 0x200 Offset */
81 #define ATMEL_BASE_PMC          0xFFFFFC00
82 #define ATMEL_BASE_ST           0xFFFFFD00
83 #define ATMEL_BASE_RTC          0xFFFFFE00
84 #define ATMEL_BASE_MC           0xFFFFFF00
85
86 #define AT91_PIO_BASE   ATMEL_BASE_PIO
87
88 /* AT91RM9200 Periperial Multiplexing A */
89 /* Port A */
90 #define ATMEL_PMX_AA_EREFCK     0x00000080
91 #define ATMEL_PMX_AA_ETXCK      0x00000080
92 #define ATMEL_PMX_AA_ETXEN      0x00000100
93 #define ATMEL_PMX_AA_ETX0       0x00000200
94 #define ATMEL_PMX_AA_ETX1       0x00000400
95 #define ATMEL_PMX_AA_ECRS       0x00000800
96 #define ATMEL_PMX_AA_ECRSDV     0x00000800
97 #define ATMEL_PMX_AA_ERX0       0x00001000
98 #define ATMEL_PMX_AA_ERX1       0x00002000
99 #define ATMEL_PMX_AA_ERXER      0x00004000
100 #define ATMEL_PMX_AA_EMDC       0x00008000
101 #define ATMEL_PMX_AA_EMDIO      0x00010000
102
103 #define ATMEL_PMX_AA_TXD2       0x00800000
104
105 #define ATMEL_PMX_AA_TWD        0x02000000
106 #define ATMEL_PMX_AA_TWCK       0x04000000
107
108 /* Port B */
109 #define ATMEL_PMX_BA_ERXCK      0x00080000
110 #define ATMEL_PMX_BA_ECOL       0x00040000
111 #define ATMEL_PMX_BA_ERXDV      0x00020000
112 #define ATMEL_PMX_BA_ERX3       0x00010000
113 #define ATMEL_PMX_BA_ERX2       0x00008000
114 #define ATMEL_PMX_BA_ETXER      0x00004000
115 #define ATMEL_PMX_BA_ETX3       0x00002000
116 #define ATMEL_PMX_BA_ETX2       0x00001000
117
118 /* Port B */
119
120 #define ATMEL_PMX_CA_BFCK       0x00000001
121 #define ATMEL_PMX_CA_BFRDY      0x00000002
122 #define ATMEL_PMX_CA_SMOE       0x00000002
123 #define ATMEL_PMX_CA_BFAVD      0x00000004
124 #define ATMEL_PMX_CA_BFBAA      0x00000008
125 #define ATMEL_PMX_CA_SMWE       0x00000008
126 #define ATMEL_PMX_CA_BFOE       0x00000010
127 #define ATMEL_PMX_CA_BFWE       0x00000020
128 #define ATMEL_PMX_CA_NWAIT      0x00000040
129 #define ATMEL_PMX_CA_A23        0x00000080
130 #define ATMEL_PMX_CA_A24        0x00000100
131 #define ATMEL_PMX_CA_A25        0x00000200
132 #define ATMEL_PMX_CA_CFRNW      0x00000200
133 #define ATMEL_PMX_CA_NCS4       0x00000400
134 #define ATMEL_PMX_CA_CFCS       0x00000400
135 #define ATMEL_PMX_CA_NCS5       0x00000800
136 #define ATMEL_PMX_CA_CFCE1      0x00001000
137 #define ATMEL_PMX_CA_NCS6       0x00001000
138 #define ATMEL_PMX_CA_CFCE2      0x00002000
139 #define ATMEL_PMX_CA_NCS7       0x00002000
140 #define ATMEL_PMX_CA_D16_31     0xFFFF0000
141
142 #define ATMEL_PIO_PORTS         4       /* theese SoCs have 4 PIO */
143 #define ATMEL_PMC_UHP           AT91RM9200_PMC_UHP
144
145 #define CONFIG_SYS_ATMEL_CPU_NAME       "AT91RM9200"
146
147 #endif