blob: d4b4941c78e81e3be87902b1dee4485f71b16e54 [file] [log] [blame]
Rob Herring253d7ad2011-08-10 15:22:11 -05001/*
2 * Copyright 2011 Calxeda, Inc.
3 *
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms and conditions of the GNU General Public License,
6 * version 2, as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope it will be useful, but WITHOUT
9 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
11 * more details.
12 *
13 * You should have received a copy of the GNU General Public License along with
14 * this program. If not, see <http://www.gnu.org/licenses/>.
15 */
16
17/dts-v1/;
18
19/* First 4KB has pen for secondary cores. */
20/memreserve/ 0x00000000 0x0001000;
21
22/ {
23 model = "Calxeda Highbank";
24 compatible = "calxeda,highbank";
25 #address-cells = <1>;
26 #size-cells = <1>;
27
28 cpus {
29 #address-cells = <1>;
30 #size-cells = <0>;
31
32 cpu@0 {
33 compatible = "arm,cortex-a9";
34 reg = <0>;
35 next-level-cache = <&L2>;
36 };
37
38 cpu@1 {
39 compatible = "arm,cortex-a9";
40 reg = <1>;
41 next-level-cache = <&L2>;
42 };
43
44 cpu@2 {
45 compatible = "arm,cortex-a9";
46 reg = <2>;
47 next-level-cache = <&L2>;
48 };
49
50 cpu@3 {
51 compatible = "arm,cortex-a9";
52 reg = <3>;
53 next-level-cache = <&L2>;
54 };
55 };
56
57 memory {
58 name = "memory";
59 device_type = "memory";
60 reg = <0x00000000 0xff900000>;
61 };
62
63 chosen {
64 bootargs = "console=ttyAMA0";
65 };
66
67 soc {
68 #address-cells = <1>;
69 #size-cells = <1>;
70 compatible = "simple-bus";
71 interrupt-parent = <&intc>;
72 ranges;
73
74 timer@fff10600 {
Marc Zyngier7ac9b9e2012-01-10 19:44:19 +000075 compatible = "arm,cortex-a9-twd-timer";
Rob Herring253d7ad2011-08-10 15:22:11 -050076 reg = <0xfff10600 0x20>;
Marc Zyngier7ac9b9e2012-01-10 19:44:19 +000077 interrupts = <1 13 0xf01>;
Rob Herring253d7ad2011-08-10 15:22:11 -050078 };
79
80 watchdog@fff10620 {
Marc Zyngier7ac9b9e2012-01-10 19:44:19 +000081 compatible = "arm,cortex-a9-twd-wdt";
Rob Herring253d7ad2011-08-10 15:22:11 -050082 reg = <0xfff10620 0x20>;
Marc Zyngier7ac9b9e2012-01-10 19:44:19 +000083 interrupts = <1 14 0xf01>;
Rob Herring253d7ad2011-08-10 15:22:11 -050084 };
85
86 intc: interrupt-controller@fff11000 {
87 compatible = "arm,cortex-a9-gic";
88 #interrupt-cells = <3>;
89 #size-cells = <0>;
90 #address-cells = <1>;
91 interrupt-controller;
Rob Herring253d7ad2011-08-10 15:22:11 -050092 reg = <0xfff11000 0x1000>,
93 <0xfff10100 0x100>;
94 };
95
96 L2: l2-cache {
97 compatible = "arm,pl310-cache";
98 reg = <0xfff12000 0x1000>;
99 interrupts = <0 70 4>;
100 cache-unified;
101 cache-level = <2>;
102 };
103
104 pmu {
105 compatible = "arm,cortex-a9-pmu";
106 interrupts = <0 76 4 0 75 4 0 74 4 0 73 4>;
107 };
108
109 sata@ffe08000 {
110 compatible = "calxeda,hb-ahci";
111 reg = <0xffe08000 0x10000>;
112 interrupts = <0 83 4>;
113 };
114
115 sdhci@ffe0e000 {
116 compatible = "calxeda,hb-sdhci";
117 reg = <0xffe0e000 0x1000>;
118 interrupts = <0 90 4>;
119 };
120
Rob Herringa1b01ed2012-06-13 12:01:55 -0500121 memory-controller@fff00000 {
122 compatible = "calxeda,hb-ddr-ctrl";
123 reg = <0xfff00000 0x1000>;
124 interrupts = <0 91 4>;
125 };
126
Rob Herring253d7ad2011-08-10 15:22:11 -0500127 ipc@fff20000 {
128 compatible = "arm,pl320", "arm,primecell";
129 reg = <0xfff20000 0x1000>;
130 interrupts = <0 7 4>;
131 };
132
133 gpioe: gpio@fff30000 {
134 #gpio-cells = <2>;
135 compatible = "arm,pl061", "arm,primecell";
136 gpio-controller;
137 reg = <0xfff30000 0x1000>;
138 interrupts = <0 14 4>;
139 };
140
141 gpiof: gpio@fff31000 {
142 #gpio-cells = <2>;
143 compatible = "arm,pl061", "arm,primecell";
144 gpio-controller;
145 reg = <0xfff31000 0x1000>;
146 interrupts = <0 15 4>;
147 };
148
149 gpiog: gpio@fff32000 {
150 #gpio-cells = <2>;
151 compatible = "arm,pl061", "arm,primecell";
152 gpio-controller;
153 reg = <0xfff32000 0x1000>;
154 interrupts = <0 16 4>;
155 };
156
157 gpioh: gpio@fff33000 {
158 #gpio-cells = <2>;
159 compatible = "arm,pl061", "arm,primecell";
160 gpio-controller;
161 reg = <0xfff33000 0x1000>;
162 interrupts = <0 17 4>;
163 };
164
165 timer {
166 compatible = "arm,sp804", "arm,primecell";
167 reg = <0xfff34000 0x1000>;
168 interrupts = <0 18 4>;
169 };
170
171 rtc@fff35000 {
172 compatible = "arm,pl031", "arm,primecell";
173 reg = <0xfff35000 0x1000>;
174 interrupts = <0 19 4>;
175 };
176
177 serial@fff36000 {
178 compatible = "arm,pl011", "arm,primecell";
179 reg = <0xfff36000 0x1000>;
180 interrupts = <0 20 4>;
181 };
182
183 smic@fff3a000 {
184 compatible = "ipmi-smic";
185 device_type = "ipmi";
186 reg = <0xfff3a000 0x1000>;
187 interrupts = <0 24 4>;
188 reg-size = <4>;
189 reg-spacing = <4>;
190 };
191
192 sregs@fff3c000 {
193 compatible = "calxeda,hb-sregs";
194 reg = <0xfff3c000 0x1000>;
195 };
196
197 dma@fff3d000 {
198 compatible = "arm,pl330", "arm,primecell";
199 reg = <0xfff3d000 0x1000>;
200 interrupts = <0 92 4>;
201 };
Rob Herringbd0552e2011-12-05 08:35:55 -0600202
203 ethernet@fff50000 {
204 compatible = "calxeda,hb-xgmac";
205 reg = <0xfff50000 0x1000>;
206 interrupts = <0 77 4 0 78 4 0 79 4>;
207 };
208
209 ethernet@fff51000 {
210 compatible = "calxeda,hb-xgmac";
211 reg = <0xfff51000 0x1000>;
212 interrupts = <0 80 4 0 81 4 0 82 4>;
213 };
Rob Herring253d7ad2011-08-10 15:22:11 -0500214 };
215};