blob: 9f444c96a9ecead08d1745d2e82089e19eea3498 [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 Glass00c34d5b2017-06-15 21:37:53 -06008 model = "sandbox";
Simon Glassfd91fc92014-10-13 23:41:48 -06009
Simon Glass70778bc2015-03-05 12:25:26 -070010 aliases {
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
Joe Hershberger89590c82018-07-02 14:47:54 -050049 ethrawbus {
50 compatible = "sandbox,eth-raw-bus";
51 skip-localhost = <0>;
52 };
53
Simon Glass45ab0082015-05-22 15:42:16 -060054 eth@10002000 {
55 compatible = "sandbox,eth";
56 reg = <0x10002000 0x1000>;
57 fake-host-hwaddr = [00 00 66 44 22 00];
58 };
59
Simon Glass120834d2015-01-05 20:05:31 -070060 gpio_a: gpios@0 {
Simon Glass093f3a72014-08-11 09:24:03 -060061 gpio-controller;
62 compatible = "sandbox,gpio";
63 #gpio-cells = <1>;
64 gpio-bank-name = "a";
Simon Glass9e7ab232018-02-03 10:36:59 -070065 sandbox,gpio-count = <20>;
Simon Glass093f3a72014-08-11 09:24:03 -060066 };
67
Simon Glass120834d2015-01-05 20:05:31 -070068 gpio_b: gpios@1 {
69 gpio-controller;
70 compatible = "sandbox,gpio";
71 #gpio-cells = <2>;
72 gpio-bank-name = "b";
Simon Glass9e7ab232018-02-03 10:36:59 -070073 sandbox,gpio-count = <10>;
Simon Glass120834d2015-01-05 20:05:31 -070074 };
75
Simon Glass45ab0082015-05-22 15:42:16 -060076 hexagon {
77 compatible = "demo-simple";
78 colour = "white";
79 sides = <6>;
80 };
81
Simon Glass72138b92015-04-20 12:37:28 -060082 i2c_0: i2c@0 {
Simon Glass4f46a592014-12-10 08:55:53 -070083 #address-cells = <1>;
84 #size-cells = <0>;
Simon Glassf905be82015-03-05 12:25:13 -070085 reg = <0 0>;
Simon Glass4f46a592014-12-10 08:55:53 -070086 compatible = "sandbox,i2c";
87 clock-frequency = <400000>;
Masahiro Yamada0b53a752015-08-27 12:44:30 +090088 pinctrl-names = "default";
89 pinctrl-0 = <&pinctrl_i2c0>;
Simon Glass4f46a592014-12-10 08:55:53 -070090 eeprom@2c {
91 reg = <0x2c>;
92 compatible = "i2c-eeprom";
93 emul {
94 compatible = "sandbox,i2c-eeprom";
95 sandbox,filename = "i2c.bin";
96 sandbox,size = <128>;
97 };
98 };
Simon Glass72138b92015-04-20 12:37:28 -060099
100 rtc_0: rtc@43 {
101 reg = <0x43>;
102 compatible = "sandbox-rtc";
103 emul {
104 compatible = "sandbox,i2c-rtc";
105 };
106 };
Przemyslaw Marczak77bee052015-05-13 13:38:35 +0200107 sandbox_pmic: sandbox_pmic {
108 reg = <0x40>;
109 };
Lukasz Majewskia4d82972018-05-15 16:26:40 +0200110
111 mc34708: pmic@41 {
112 reg = <0x41>;
113 };
Simon Glass4f46a592014-12-10 08:55:53 -0700114 };
115
Simon Glass45ab0082015-05-22 15:42:16 -0600116 lcd {
Simon Glass38a2ae22016-01-18 19:52:25 -0700117 u-boot,dm-pre-reloc;
Simon Glass45ab0082015-05-22 15:42:16 -0600118 compatible = "sandbox,lcd-sdl";
119 xres = <1366>;
120 yres = <768>;
Simon Glassfd91fc92014-10-13 23:41:48 -0600121 };
122
Simon Glassfefc7ba2017-04-10 11:34:51 -0600123 leds {
124 compatible = "gpio-leds";
125
126 iracibble {
127 gpios = <&gpio_a 1 0>;
128 label = "sandbox:red";
129 };
130
131 martinet {
132 gpios = <&gpio_a 2 0>;
133 label = "sandbox:green";
134 };
135 };
136
Simon Glass70778bc2015-03-05 12:25:26 -0700137 pci: pci-controller {
138 compatible = "sandbox,pci";
139 device_type = "pci";
140 #address-cells = <3>;
141 #size-cells = <2>;
142 ranges = <0x02000000 0 0x10000000 0x10000000 0 0x2000
143 0x01000000 0 0x20000000 0x20000000 0 0x2000>;
144 pci@1f,0 {
145 compatible = "pci-generic";
146 reg = <0xf800 0 0 0 0>;
147 emul@1f,0 {
148 compatible = "sandbox,swap-case";
149 };
150 };
151 };
152
Masahiro Yamada0b53a752015-08-27 12:44:30 +0900153 pinctrl {
154 compatible = "sandbox,pinctrl";
155
156 pinctrl_i2c0: i2c0 {
157 groups = "i2c";
158 function = "i2c";
159 bias-pull-up;
160 };
161
162 pinctrl_serial0: uart0 {
163 groups = "serial_a";
164 function = "serial";
165 };
166 };
167
Simon Glass68a3d492015-10-03 11:21:16 -0600168 reset@1 {
169 compatible = "sandbox,reset";
170 };
171
Simon Glass45ab0082015-05-22 15:42:16 -0600172 spi@0 {
173 #address-cells = <1>;
174 #size-cells = <0>;
175 reg = <0 0>;
176 compatible = "sandbox,spi";
177 cs-gpios = <0>, <&gpio_a 0>;
178 firmware_storage_spi: flash@0 {
179 reg = <0>;
180 compatible = "spansion,m25p16", "sandbox,spi-flash";
181 spi-max-frequency = <40000000>;
182 sandbox,filename = "spi.bin";
183 };
Joe Hershberger6ab76992015-03-22 17:09:13 -0500184 };
Joe Hershberger586cbd12015-03-22 17:09:21 -0500185
Simon Glass4e9c1312016-07-04 11:57:55 -0600186 spl-test {
187 u-boot,dm-pre-reloc;
188 compatible = "sandbox,spl-test";
189 boolval;
190 intval = <1>;
191 intarray = <2 3 4>;
192 byteval = [05];
193 bytearray = [06];
194 longbytearray = [09 0a 0b 0c 0d 0e 0f 10 11];
195 stringval = "message";
196 stringarray = "multi-word", "message";
197 };
198
199 spl-test2 {
200 u-boot,dm-pre-reloc;
201 compatible = "sandbox,spl-test";
202 intval = <3>;
203 intarray = <5>;
204 byteval = [08];
205 bytearray = [01 23 34];
206 longbytearray = [09 0a 0b 0c];
207 stringval = "message2";
208 stringarray = "another", "multi-word", "message";
209 };
210
211 spl-test3 {
212 u-boot,dm-pre-reloc;
213 compatible = "sandbox,spl-test";
214 stringarray = "one";
215 };
216
Simon Glassb17ab152017-01-15 21:09:08 -0700217 spl-test4 {
218 u-boot,dm-pre-reloc;
219 compatible = "sandbox,spl-test.2";
220 };
221
Simon Glass45ab0082015-05-22 15:42:16 -0600222 square {
223 compatible = "demo-shape";
224 colour = "blue";
225 sides = <4>;
Joe Hershberger586cbd12015-03-22 17:09:21 -0500226 };
Joe Hershbergera8921922015-03-22 17:09:23 -0500227
Thomas Chou7b059dc2015-10-30 15:35:52 +0800228 timer {
229 compatible = "sandbox,timer";
Bin Mengd041c422015-11-13 00:11:17 -0800230 clock-frequency = <1000000>;
Thomas Chou7b059dc2015-10-30 15:35:52 +0800231 };
232
Simon Glassa425f762015-08-22 18:31:35 -0600233 tpm {
234 compatible = "google,sandbox-tpm";
235 };
236
Miquel Raynal80938c12018-05-15 11:57:27 +0200237 tpm2 {
238 compatible = "sandbox,tpm2";
239 };
240
Simon Glass45ab0082015-05-22 15:42:16 -0600241 triangle {
242 compatible = "demo-shape";
243 colour = "cyan";
244 sides = <3>;
245 character = <83>;
246 light-gpios = <&gpio_a 2>, <&gpio_b 6 0>;
247 };
248
249 /* Needs to be available prior to relocation */
250 uart0: serial {
251 compatible = "sandbox,serial";
252 sandbox,text-colour = "cyan";
Masahiro Yamada0b53a752015-08-27 12:44:30 +0900253 pinctrl-names = "default";
254 pinctrl-0 = <&pinctrl_serial0>;
Joe Hershbergera8921922015-03-22 17:09:23 -0500255 };
Simon Glassce3ca2e2015-03-25 12:22:42 -0600256
257 usb@0 {
258 compatible = "sandbox,usb";
259 status = "disabled";
260 hub {
261 compatible = "sandbox,usb-hub";
262 #address-cells = <1>;
263 #size-cells = <0>;
264 flash-stick {
265 reg = <0>;
266 compatible = "sandbox,usb-flash";
267 };
268 };
269 };
270
271 usb@1 {
272 compatible = "sandbox,usb";
273 hub {
274 compatible = "usb-hub";
275 usb,device-class = <USB_CLASS_HUB>;
276 hub-emul {
277 compatible = "sandbox,usb-hub";
278 #address-cells = <1>;
279 #size-cells = <0>;
280 flash-stick {
281 reg = <0>;
282 compatible = "sandbox,usb-flash";
283 sandbox,filepath = "flash.bin";
284 };
285 };
286 };
287 };
288
289 usb@2 {
290 compatible = "sandbox,usb";
291 status = "disabled";
292 };
293
Mateusz Kulikowskic7e4fbb2016-03-31 23:12:28 +0200294 spmi: spmi@0 {
295 compatible = "sandbox,spmi";
296 #address-cells = <0x1>;
297 #size-cells = <0x1>;
298 pm8916@0 {
299 compatible = "qcom,spmi-pmic";
300 reg = <0x0 0x1>;
301 #address-cells = <0x1>;
302 #size-cells = <0x1>;
303
304 spmi_gpios: gpios@c000 {
305 compatible = "qcom,pm8916-gpio";
306 reg = <0xc000 0x400>;
307 gpio-controller;
308 gpio-count = <4>;
309 #gpio-cells = <2>;
310 gpio-bank-name="spmi";
311 };
312 };
313 };
Simon Glass66c164b2014-02-26 15:59:14 -0700314};
Simon Glass73f220c2015-03-26 09:29:39 -0600315
316#include "cros-ec-keyboard.dtsi"
Przemyslaw Marczak77bee052015-05-13 13:38:35 +0200317#include "sandbox_pmic.dtsi"