blob: e21cb845d112c95fc25b7980afea150ed242176e [file] [log] [blame]
SAN People73a59c12006-01-09 17:05:41 +00001/*
Andrew Victor8fc5ffa2006-06-29 16:06:33 +01002 * arch/arm/mach-at91rm9200/at91rm9200.c
SAN People73a59c12006-01-09 17:05:41 +00003 *
4 * Copyright (C) 2005 SAN People
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 as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 */
12
SAN People73a59c12006-01-09 17:05:41 +000013#include <linux/module.h>
14
15#include <asm/mach/arch.h>
16#include <asm/mach/map.h>
17
Russell Kingea75ee92006-06-20 19:53:16 +010018#include <asm/hardware.h>
Andrew Victor10e8e1f2006-06-19 15:26:51 +010019#include "generic.h"
SAN People73a59c12006-01-09 17:05:41 +000020
21static struct map_desc at91rm9200_io_desc[] __initdata = {
22 {
23 .virtual = AT91_VA_BASE_SYS,
24 .pfn = __phys_to_pfn(AT91_BASE_SYS),
25 .length = SZ_4K,
26 .type = MT_DEVICE,
27 }, {
28 .virtual = AT91_VA_BASE_SPI,
Andrew Victor72729912006-09-27 09:44:11 +010029 .pfn = __phys_to_pfn(AT91RM9200_BASE_SPI),
SAN People73a59c12006-01-09 17:05:41 +000030 .length = SZ_16K,
31 .type = MT_DEVICE,
32 }, {
33 .virtual = AT91_VA_BASE_SSC2,
Andrew Victor72729912006-09-27 09:44:11 +010034 .pfn = __phys_to_pfn(AT91RM9200_BASE_SSC2),
SAN People73a59c12006-01-09 17:05:41 +000035 .length = SZ_16K,
36 .type = MT_DEVICE,
37 }, {
38 .virtual = AT91_VA_BASE_SSC1,
Andrew Victor72729912006-09-27 09:44:11 +010039 .pfn = __phys_to_pfn(AT91RM9200_BASE_SSC1),
SAN People73a59c12006-01-09 17:05:41 +000040 .length = SZ_16K,
41 .type = MT_DEVICE,
42 }, {
43 .virtual = AT91_VA_BASE_SSC0,
Andrew Victor72729912006-09-27 09:44:11 +010044 .pfn = __phys_to_pfn(AT91RM9200_BASE_SSC0),
SAN People73a59c12006-01-09 17:05:41 +000045 .length = SZ_16K,
46 .type = MT_DEVICE,
47 }, {
48 .virtual = AT91_VA_BASE_US3,
Andrew Victor72729912006-09-27 09:44:11 +010049 .pfn = __phys_to_pfn(AT91RM9200_BASE_US3),
SAN People73a59c12006-01-09 17:05:41 +000050 .length = SZ_16K,
51 .type = MT_DEVICE,
52 }, {
53 .virtual = AT91_VA_BASE_US2,
Andrew Victor72729912006-09-27 09:44:11 +010054 .pfn = __phys_to_pfn(AT91RM9200_BASE_US2),
SAN People73a59c12006-01-09 17:05:41 +000055 .length = SZ_16K,
56 .type = MT_DEVICE,
57 }, {
58 .virtual = AT91_VA_BASE_US1,
Andrew Victor72729912006-09-27 09:44:11 +010059 .pfn = __phys_to_pfn(AT91RM9200_BASE_US1),
SAN People73a59c12006-01-09 17:05:41 +000060 .length = SZ_16K,
61 .type = MT_DEVICE,
62 }, {
63 .virtual = AT91_VA_BASE_US0,
Andrew Victor72729912006-09-27 09:44:11 +010064 .pfn = __phys_to_pfn(AT91RM9200_BASE_US0),
SAN People73a59c12006-01-09 17:05:41 +000065 .length = SZ_16K,
66 .type = MT_DEVICE,
67 }, {
68 .virtual = AT91_VA_BASE_EMAC,
Andrew Victor72729912006-09-27 09:44:11 +010069 .pfn = __phys_to_pfn(AT91RM9200_BASE_EMAC),
SAN People73a59c12006-01-09 17:05:41 +000070 .length = SZ_16K,
71 .type = MT_DEVICE,
72 }, {
73 .virtual = AT91_VA_BASE_TWI,
Andrew Victor72729912006-09-27 09:44:11 +010074 .pfn = __phys_to_pfn(AT91RM9200_BASE_TWI),
SAN People73a59c12006-01-09 17:05:41 +000075 .length = SZ_16K,
76 .type = MT_DEVICE,
77 }, {
78 .virtual = AT91_VA_BASE_MCI,
Andrew Victor72729912006-09-27 09:44:11 +010079 .pfn = __phys_to_pfn(AT91RM9200_BASE_MCI),
SAN People73a59c12006-01-09 17:05:41 +000080 .length = SZ_16K,
81 .type = MT_DEVICE,
82 }, {
83 .virtual = AT91_VA_BASE_UDP,
Andrew Victor72729912006-09-27 09:44:11 +010084 .pfn = __phys_to_pfn(AT91RM9200_BASE_UDP),
SAN People73a59c12006-01-09 17:05:41 +000085 .length = SZ_16K,
86 .type = MT_DEVICE,
87 }, {
88 .virtual = AT91_VA_BASE_TCB1,
Andrew Victor72729912006-09-27 09:44:11 +010089 .pfn = __phys_to_pfn(AT91RM9200_BASE_TCB1),
SAN People73a59c12006-01-09 17:05:41 +000090 .length = SZ_16K,
91 .type = MT_DEVICE,
92 }, {
93 .virtual = AT91_VA_BASE_TCB0,
Andrew Victor72729912006-09-27 09:44:11 +010094 .pfn = __phys_to_pfn(AT91RM9200_BASE_TCB0),
SAN People73a59c12006-01-09 17:05:41 +000095 .length = SZ_16K,
96 .type = MT_DEVICE,
Andrew Victor10e8e1f2006-06-19 15:26:51 +010097 }, {
98 .virtual = AT91_SRAM_VIRT_BASE,
Andrew Victor72729912006-09-27 09:44:11 +010099 .pfn = __phys_to_pfn(AT91RM9200_SRAM_BASE),
100 .length = AT91RM9200_SRAM_SIZE,
Andrew Victor10e8e1f2006-06-19 15:26:51 +0100101 .type = MT_DEVICE,
SAN People73a59c12006-01-09 17:05:41 +0000102 },
103};
104
105void __init at91rm9200_map_io(void)
106{
107 iotable_init(at91rm9200_io_desc, ARRAY_SIZE(at91rm9200_io_desc));
108}
109
Andrew Victorba854e12006-07-05 17:22:52 +0100110/*
111 * The default interrupt priority levels (0 = lowest, 7 = highest).
112 */
113static unsigned int at91rm9200_default_irq_priority[NR_AIC_IRQS] __initdata = {
114 7, /* Advanced Interrupt Controller (FIQ) */
115 7, /* System Peripherals */
116 0, /* Parallel IO Controller A */
117 0, /* Parallel IO Controller B */
118 0, /* Parallel IO Controller C */
119 0, /* Parallel IO Controller D */
120 6, /* USART 0 */
121 6, /* USART 1 */
122 6, /* USART 2 */
123 6, /* USART 3 */
124 0, /* Multimedia Card Interface */
125 4, /* USB Device Port */
126 0, /* Two-Wire Interface */
127 6, /* Serial Peripheral Interface */
128 5, /* Serial Synchronous Controller 0 */
129 5, /* Serial Synchronous Controller 1 */
130 5, /* Serial Synchronous Controller 2 */
131 0, /* Timer Counter 0 */
132 0, /* Timer Counter 1 */
133 0, /* Timer Counter 2 */
134 0, /* Timer Counter 3 */
135 0, /* Timer Counter 4 */
136 0, /* Timer Counter 5 */
137 3, /* USB Host port */
138 3, /* Ethernet MAC */
139 0, /* Advanced Interrupt Controller (IRQ0) */
140 0, /* Advanced Interrupt Controller (IRQ1) */
141 0, /* Advanced Interrupt Controller (IRQ2) */
142 0, /* Advanced Interrupt Controller (IRQ3) */
143 0, /* Advanced Interrupt Controller (IRQ4) */
144 0, /* Advanced Interrupt Controller (IRQ5) */
145 0 /* Advanced Interrupt Controller (IRQ6) */
146};
147
148void __init at91rm9200_init_irq(unsigned int priority[NR_AIC_IRQS])
149{
150 if (!priority)
151 priority = at91rm9200_default_irq_priority;
152
153 at91_aic_init(priority);
154}