blob: 40f423da2560920c443d7b193cb432d96ae1d7de [file] [log] [blame]
Simon Glass66c164b2014-02-26 15:59:14 -07001/dts-v1/;
2
Simon Glassce3ca2e2015-03-25 12:22:42 -06003#define USB_CLASS_HUB 9
4
Simon Glass66c164b2014-02-26 15:59:14 -07005/ {
Simon Glassfd91fc92014-10-13 23:41:48 -06006 #address-cells = <1>;
Simon Glassf905be82015-03-05 12:25:13 -07007 #size-cells = <1>;
Simon Glassfd91fc92014-10-13 23:41:48 -06008
Simon Glass70778bc2015-03-05 12:25:26 -07009 aliases {
Joe Hershbergera8921922015-03-22 17:09:23 -050010 eth5 = "/eth@90000000";
Simon Glass72138b92015-04-20 12:37:28 -060011 i2c0 = &i2c_0;
Simon Glass70778bc2015-03-05 12:25:26 -070012 pci0 = &pci;
Simon Glass72138b92015-04-20 12:37:28 -060013 rtc0 = &rtc_0;
Simon Glass70778bc2015-03-05 12:25:26 -070014 };
15
Simon Glasscdbbfe32014-09-04 16:27:29 -060016 chosen {
17 stdout-path = "/serial";
18 };
19
Simon Glass73f220c2015-03-26 09:29:39 -060020 cros_ec: cros-ec@0 {
21 reg = <0 0>;
22 compatible = "google,cros-ec-sandbox";
Simon Glass1f6acb52014-02-27 13:25:59 -070023
Simon Glass73f220c2015-03-26 09:29:39 -060024 /*
25 * This describes the flash memory within the EC. Note
26 * that the STM32L flash erases to 0, not 0xff.
27 */
28 #address-cells = <1>;
29 #size-cells = <1>;
30 flash@8000000 {
31 reg = <0x08000000 0x20000>;
32 erase-value = <0>;
Simon Glass1f6acb52014-02-27 13:25:59 -070033 #address-cells = <1>;
34 #size-cells = <1>;
Simon Glass1f6acb52014-02-27 13:25:59 -070035
Simon Glass73f220c2015-03-26 09:29:39 -060036 /* Information for sandbox */
37 ro {
38 reg = <0 0xf000>;
39 };
40 wp-ro {
41 reg = <0xf000 0x1000>;
42 };
43 rw {
44 reg = <0x10000 0x10000>;
Simon Glass1f6acb52014-02-27 13:25:59 -070045 };
46 };
47 };
48
Simon Glass45ab0082015-05-22 15:42:16 -060049 eth@10002000 {
50 compatible = "sandbox,eth";
51 reg = <0x10002000 0x1000>;
52 fake-host-hwaddr = [00 00 66 44 22 00];
53 };
54
55 eth@80000000 {
56 compatible = "sandbox,eth-raw";
57 reg = <0x80000000 0x1000>;
58 host-raw-interface = "eth0";
59 };
60
61 eth@90000000 {
62 compatible = "sandbox,eth-raw";
63 reg = <0x90000000 0x1000>;
64 host-raw-interface = "lo";
Simon Glass1f6acb52014-02-27 13:25:59 -070065 };
66
Simon Glass120834d2015-01-05 20:05:31 -070067 gpio_a: gpios@0 {
Simon Glass093f3a72014-08-11 09:24:03 -060068 gpio-controller;
69 compatible = "sandbox,gpio";
70 #gpio-cells = <1>;
71 gpio-bank-name = "a";
72 num-gpios = <20>;
73 };
74
Simon Glass120834d2015-01-05 20:05:31 -070075 gpio_b: gpios@1 {
76 gpio-controller;
77 compatible = "sandbox,gpio";
78 #gpio-cells = <2>;
79 gpio-bank-name = "b";
80 num-gpios = <10>;
81 };
82
Simon Glass45ab0082015-05-22 15:42:16 -060083 hexagon {
84 compatible = "demo-simple";
85 colour = "white";
86 sides = <6>;
87 };
88
Simon Glass72138b92015-04-20 12:37:28 -060089 i2c_0: i2c@0 {
Simon Glass4f46a592014-12-10 08:55:53 -070090 #address-cells = <1>;
91 #size-cells = <0>;
Simon Glassf905be82015-03-05 12:25:13 -070092 reg = <0 0>;
Simon Glass4f46a592014-12-10 08:55:53 -070093 compatible = "sandbox,i2c";
94 clock-frequency = <400000>;
Masahiro Yamada0b53a752015-08-27 12:44:30 +090095 pinctrl-names = "default";
96 pinctrl-0 = <&pinctrl_i2c0>;
Simon Glass4f46a592014-12-10 08:55:53 -070097 eeprom@2c {
98 reg = <0x2c>;
99 compatible = "i2c-eeprom";
100 emul {
101 compatible = "sandbox,i2c-eeprom";
102 sandbox,filename = "i2c.bin";
103 sandbox,size = <128>;
104 };
105 };
Simon Glass72138b92015-04-20 12:37:28 -0600106
107 rtc_0: rtc@43 {
108 reg = <0x43>;
109 compatible = "sandbox-rtc";
110 emul {
111 compatible = "sandbox,i2c-rtc";
112 };
113 };
Przemyslaw Marczak77bee052015-05-13 13:38:35 +0200114 sandbox_pmic: sandbox_pmic {
115 reg = <0x40>;
116 };
Simon Glass4f46a592014-12-10 08:55:53 -0700117 };
118
Simon Glass45ab0082015-05-22 15:42:16 -0600119 lcd {
Simon Glass38a2ae22016-01-18 19:52:25 -0700120 u-boot,dm-pre-reloc;
Simon Glass45ab0082015-05-22 15:42:16 -0600121 compatible = "sandbox,lcd-sdl";
122 xres = <1366>;
123 yres = <768>;
Simon Glassfd91fc92014-10-13 23:41:48 -0600124 };
125
Simon Glassfefc7ba2017-04-10 11:34:51 -0600126 leds {
127 compatible = "gpio-leds";
128
129 iracibble {
130 gpios = <&gpio_a 1 0>;
131 label = "sandbox:red";
132 };
133
134 martinet {
135 gpios = <&gpio_a 2 0>;
136 label = "sandbox:green";
137 };
138 };
139
Simon Glass70778bc2015-03-05 12:25:26 -0700140 pci: pci-controller {
141 compatible = "sandbox,pci";
142 device_type = "pci";
143 #address-cells = <3>;
144 #size-cells = <2>;
145 ranges = <0x02000000 0 0x10000000 0x10000000 0 0x2000
146 0x01000000 0 0x20000000 0x20000000 0 0x2000>;
147 pci@1f,0 {
148 compatible = "pci-generic";
149 reg = <0xf800 0 0 0 0>;
150 emul@1f,0 {
151 compatible = "sandbox,swap-case";
152 };
153 };
154 };
155
Masahiro Yamada0b53a752015-08-27 12:44:30 +0900156 pinctrl {
157 compatible = "sandbox,pinctrl";
158
159 pinctrl_i2c0: i2c0 {
160 groups = "i2c";
161 function = "i2c";
162 bias-pull-up;
163 };
164
165 pinctrl_serial0: uart0 {
166 groups = "serial_a";
167 function = "serial";
168 };
169 };
170
Simon Glass68a3d492015-10-03 11:21:16 -0600171 reset@1 {
172 compatible = "sandbox,reset";
173 };
174
Simon Glass45ab0082015-05-22 15:42:16 -0600175 spi@0 {
176 #address-cells = <1>;
177 #size-cells = <0>;
178 reg = <0 0>;
179 compatible = "sandbox,spi";
180 cs-gpios = <0>, <&gpio_a 0>;
181 firmware_storage_spi: flash@0 {
182 reg = <0>;
183 compatible = "spansion,m25p16", "sandbox,spi-flash";
184 spi-max-frequency = <40000000>;
185 sandbox,filename = "spi.bin";
186 };
Joe Hershberger6ab76992015-03-22 17:09:13 -0500187 };
Joe Hershberger586cbd12015-03-22 17:09:21 -0500188
Simon Glass4e9c1312016-07-04 11:57:55 -0600189 spl-test {
190 u-boot,dm-pre-reloc;
191 compatible = "sandbox,spl-test";
192 boolval;
193 intval = <1>;
194 intarray = <2 3 4>;
195 byteval = [05];
196 bytearray = [06];
197 longbytearray = [09 0a 0b 0c 0d 0e 0f 10 11];
198 stringval = "message";
199 stringarray = "multi-word", "message";
200 };
201
202 spl-test2 {
203 u-boot,dm-pre-reloc;
204 compatible = "sandbox,spl-test";
205 intval = <3>;
206 intarray = <5>;
207 byteval = [08];
208 bytearray = [01 23 34];
209 longbytearray = [09 0a 0b 0c];
210 stringval = "message2";
211 stringarray = "another", "multi-word", "message";
212 };
213
214 spl-test3 {
215 u-boot,dm-pre-reloc;
216 compatible = "sandbox,spl-test";
217 stringarray = "one";
218 };
219
Simon Glassb17ab152017-01-15 21:09:08 -0700220 spl-test4 {
221 u-boot,dm-pre-reloc;
222 compatible = "sandbox,spl-test.2";
223 };
224
Simon Glass45ab0082015-05-22 15:42:16 -0600225 square {
226 compatible = "demo-shape";
227 colour = "blue";
228 sides = <4>;
Joe Hershberger586cbd12015-03-22 17:09:21 -0500229 };
Joe Hershbergera8921922015-03-22 17:09:23 -0500230
Thomas Chou7b059dc2015-10-30 15:35:52 +0800231 timer {
232 compatible = "sandbox,timer";
Bin Mengd041c422015-11-13 00:11:17 -0800233 clock-frequency = <1000000>;
Thomas Chou7b059dc2015-10-30 15:35:52 +0800234 };
235
Simon Glassa425f762015-08-22 18:31:35 -0600236 tpm {
237 compatible = "google,sandbox-tpm";
238 };
239
Simon Glass45ab0082015-05-22 15:42:16 -0600240 triangle {
241 compatible = "demo-shape";
242 colour = "cyan";
243 sides = <3>;
244 character = <83>;
245 light-gpios = <&gpio_a 2>, <&gpio_b 6 0>;
246 };
247
248 /* Needs to be available prior to relocation */
249 uart0: serial {
250 compatible = "sandbox,serial";
251 sandbox,text-colour = "cyan";
Masahiro Yamada0b53a752015-08-27 12:44:30 +0900252 pinctrl-names = "default";
253 pinctrl-0 = <&pinctrl_serial0>;
Joe Hershbergera8921922015-03-22 17:09:23 -0500254 };
Simon Glassce3ca2e2015-03-25 12:22:42 -0600255
256 usb@0 {
257 compatible = "sandbox,usb";
258 status = "disabled";
259 hub {
260 compatible = "sandbox,usb-hub";
261 #address-cells = <1>;
262 #size-cells = <0>;
263 flash-stick {
264 reg = <0>;
265 compatible = "sandbox,usb-flash";
266 };
267 };
268 };
269
270 usb@1 {
271 compatible = "sandbox,usb";
272 hub {
273 compatible = "usb-hub";
274 usb,device-class = <USB_CLASS_HUB>;
275 hub-emul {
276 compatible = "sandbox,usb-hub";
277 #address-cells = <1>;
278 #size-cells = <0>;
279 flash-stick {
280 reg = <0>;
281 compatible = "sandbox,usb-flash";
282 sandbox,filepath = "flash.bin";
283 };
284 };
285 };
286 };
287
288 usb@2 {
289 compatible = "sandbox,usb";
290 status = "disabled";
291 };
292
Mateusz Kulikowskic7e4fbb2016-03-31 23:12:28 +0200293 spmi: spmi@0 {
294 compatible = "sandbox,spmi";
295 #address-cells = <0x1>;
296 #size-cells = <0x1>;
297 pm8916@0 {
298 compatible = "qcom,spmi-pmic";
299 reg = <0x0 0x1>;
300 #address-cells = <0x1>;
301 #size-cells = <0x1>;
302
303 spmi_gpios: gpios@c000 {
304 compatible = "qcom,pm8916-gpio";
305 reg = <0xc000 0x400>;
306 gpio-controller;
307 gpio-count = <4>;
308 #gpio-cells = <2>;
309 gpio-bank-name="spmi";
310 };
311 };
312 };
Simon Glass66c164b2014-02-26 15:59:14 -0700313};
Simon Glass73f220c2015-03-26 09:29:39 -0600314
315#include "cros-ec-keyboard.dtsi"
Przemyslaw Marczak77bee052015-05-13 13:38:35 +0200316#include "sandbox_pmic.dtsi"