1/*
2 * Copyright (c) 2020 Intel Corporation.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#include "skeleton.dtsi"
8#include <zephyr/dt-bindings/interrupt-controller/intel-ioapic.h>
9#include <zephyr/dt-bindings/i2c/i2c.h>
10#include <zephyr/dt-bindings/pcie/pcie.h>
11
12/ {
13	cpus {
14		#address-cells = <1>;
15		#size-cells = <0>;
16
17		cpu@0 {
18			device_type = "cpu";
19			compatible = "intel,elkhart-lake", "intel,x86_64";
20			d-cache-line-size = <64>;
21			reg = <0>;
22		};
23
24	};
25
26	dram0: memory@0 {
27		device_type = "memory";
28		reg = <0x0 DT_DRAM_SIZE>;
29	};
30
31	ibecc: ibecc {
32		compatible = "intel,ibecc";
33		status = "okay";
34	};
35
36	intc: ioapic@fec00000  {
37		compatible = "intel,ioapic";
38		#address-cells = <1>;
39		#interrupt-cells = <3>;
40		reg = <0xfec00000 0x1000>;
41		interrupt-controller;
42	};
43
44	intc_loapic: loapic@fee00000  {
45		compatible = "intel,loapic";
46		reg = <0xfee00000 0x1000>;
47		interrupt-controller;
48		#interrupt-cells = <3>;
49		#address-cells = <1>;
50	};
51
52	pcie0: pcie0 {
53		#address-cells = <1>;
54		#size-cells = <1>;
55		compatible = "pcie-controller";
56		acpi-hid = "PNP0A08";
57		ranges;
58
59		ptm_root0: ptm_root0 {
60			compatible = "ptm-root";
61
62			vendor-id = <0x8086>;
63			device-id = <0x4b38>;
64
65			status = "okay";
66		};
67
68		uart0: uart0 {
69			compatible = "ns16550";
70
71			vendor-id = <0x8086>;
72			device-id = <0x4b28>;
73
74			reg-shift = <2>;
75			clock-frequency = <1843200>;
76			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
77			interrupt-parent = <&intc>;
78			status = "okay";
79			current-speed = <115200>;
80		};
81
82		uart1: uart1 {
83			compatible = "ns16550";
84
85			vendor-id = <0x8086>;
86			device-id = <0x4b29>;
87
88			reg-shift = <2>;
89			clock-frequency = <1843200>;
90			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
91			interrupt-parent = <&intc>;
92
93			status = "okay";
94			current-speed = <115200>;
95		};
96
97		uart2: uart2 {
98			compatible = "ns16550";
99
100			vendor-id = <0x8086>;
101			device-id = <0x4b4d>;
102
103			reg-shift = <2>;
104			clock-frequency = <1843200>;
105			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
106			interrupt-parent = <&intc>;
107
108			status = "okay";
109			current-speed = <115200>;
110		};
111
112		uart_pse_0: uart_pse_0 {
113			compatible = "ns16550";
114
115			vendor-id = <0x8086>;
116			device-id = <0x4b96>;
117
118			reg-shift = <2>;
119			clock-frequency = <1843200>;
120			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
121			interrupt-parent = <&intc>;
122
123			status = "disabled";
124			current-speed = <115200>;
125		};
126
127		uart_pse_1: uart_pse_1 {
128			compatible = "ns16550";
129
130			vendor-id = <0x8086>;
131			device-id = <0x4b97>;
132
133			reg-shift = <2>;
134			clock-frequency = <1843200>;
135			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
136			interrupt-parent = <&intc>;
137
138			status = "disabled";
139			current-speed = <115200>;
140		};
141
142		uart_pse_2: uart_pse_2 {
143			compatible = "ns16550";
144
145			vendor-id = <0x8086>;
146			device-id = <0x4b98>;
147
148			reg-shift = <2>;
149			clock-frequency = <1843200>;
150			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
151			interrupt-parent = <&intc>;
152
153			status = "disabled";
154			current-speed = <115200>;
155		};
156
157		uart_pse_3: uart_pse_3 {
158			compatible = "ns16550";
159
160			vendor-id = <0x8086>;
161			device-id = <0x4b99>;
162
163			reg-shift = <2>;
164			clock-frequency = <1843200>;
165			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
166			interrupt-parent = <&intc>;
167
168			status = "disabled";
169			current-speed = <115200>;
170		};
171
172		uart_pse_4: uart_pse_4 {
173			compatible = "ns16550";
174
175			vendor-id = <0x8086>;
176			device-id = <0x4b9a>;
177
178			reg-shift = <2>;
179			clock-frequency = <1843200>;
180			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
181			interrupt-parent = <&intc>;
182
183			status = "disabled";
184			current-speed = <115200>;
185		};
186
187		uart_pse_5: uart_pse_5 {
188			compatible = "ns16550";
189
190			vendor-id = <0x8086>;
191			device-id = <0x4b9b>;
192
193			reg-shift = <2>;
194			clock-frequency = <1843200>;
195			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
196			interrupt-parent = <&intc>;
197
198			status = "disabled";
199			current-speed = <115200>;
200		};
201
202		smbus0: smbus0 {
203			compatible = "intel,pch-smbus";
204			#address-cells = <1>;
205			#size-cells = <0>;
206			vendor-id = <0x8086>;
207			device-id = <0x4b23>;
208			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
209			interrupt-parent = <&intc>;
210
211			status = "okay";
212		};
213
214		i2c0: i2c0 {
215			compatible = "snps,designware-i2c";
216			clock-frequency = <I2C_BITRATE_STANDARD>;
217			#address-cells = <1>;
218			#size-cells = <0>;
219			vendor-id = <0x8086>;
220			device-id = <0x4b78>;
221			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
222			interrupt-parent = <&intc>;
223
224			status = "okay";
225		};
226
227		i2c1: i2c1 {
228			compatible = "snps,designware-i2c";
229			clock-frequency = <I2C_BITRATE_STANDARD>;
230			#address-cells = <1>;
231			#size-cells = <0>;
232			vendor-id = <0x8086>;
233			device-id = <0x4b79>;
234			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
235			interrupt-parent = <&intc>;
236
237			status = "okay";
238		};
239
240		i2c2: i2c2 {
241			compatible = "snps,designware-i2c";
242			clock-frequency = <I2C_BITRATE_STANDARD>;
243			#address-cells = <1>;
244			#size-cells = <0>;
245			vendor-id = <0x8086>;
246			device-id = <0x4b7a>;
247			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
248			interrupt-parent = <&intc>;
249
250			status = "okay";
251		};
252
253		i2c3: i2c3 {
254			compatible = "snps,designware-i2c";
255			clock-frequency = <I2C_BITRATE_STANDARD>;
256			#address-cells = <1>;
257			#size-cells = <0>;
258			vendor-id = <0x8086>;
259			device-id = <0x4b7b>;
260			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
261			interrupt-parent = <&intc>;
262
263			status = "okay";
264		};
265
266		i2c4: i2c4 {
267			compatible = "snps,designware-i2c";
268			clock-frequency = <I2C_BITRATE_STANDARD>;
269			#address-cells = <1>;
270			#size-cells = <0>;
271			vendor-id = <0x8086>;
272			device-id = <0x4b4b>;
273			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
274			interrupt-parent = <&intc>;
275
276			status = "okay";
277		};
278
279		i2c5: i2c5 {
280			compatible = "snps,designware-i2c";
281			clock-frequency = <I2C_BITRATE_STANDARD>;
282			#address-cells = <1>;
283			#size-cells = <0>;
284			vendor-id = <0x8086>;
285			device-id = <0x4b4c>;
286			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
287			interrupt-parent = <&intc>;
288
289			status = "okay";
290		};
291
292		i2c6: i2c6 {
293			compatible = "snps,designware-i2c";
294			clock-frequency = <I2C_BITRATE_STANDARD>;
295			#address-cells = <1>;
296			#size-cells = <0>;
297			vendor-id = <0x8086>;
298			device-id = <0x4b44>;
299			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
300			interrupt-parent = <&intc>;
301
302			status = "okay";
303		};
304
305		i2c7: i2c7 {
306			compatible = "snps,designware-i2c";
307			clock-frequency = <I2C_BITRATE_STANDARD>;
308			#address-cells = <1>;
309			#size-cells = <0>;
310			vendor-id = <0x8086>;
311			device-id = <0x4b45>;
312			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
313			interrupt-parent = <&intc>;
314
315			status = "okay";
316		};
317
318		i2c_pse_0: i2c_pse_0 {
319			compatible = "snps,designware-i2c";
320			clock-frequency = <I2C_BITRATE_STANDARD>;
321			#address-cells = <1>;
322			#size-cells = <0>;
323			vendor-id = <0x8086>;
324			device-id = <0x4bb9>;
325			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
326			interrupt-parent = <&intc>;
327
328			status = "okay";
329		};
330
331		i2c_pse_1: i2c_pse_1 {
332			compatible = "snps,designware-i2c";
333			clock-frequency = <I2C_BITRATE_STANDARD>;
334			#address-cells = <1>;
335			#size-cells = <0>;
336			vendor-id = <0x8086>;
337			device-id = <0x4bba>;
338			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
339			interrupt-parent = <&intc>;
340
341			status = "okay";
342		};
343
344		i2c_pse_2: i2c_pse_2 {
345			compatible = "snps,designware-i2c";
346			clock-frequency = <I2C_BITRATE_STANDARD>;
347			#address-cells = <1>;
348			#size-cells = <0>;
349			vendor-id = <0x8086>;
350			device-id = <0x4bbb>;
351			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
352			interrupt-parent = <&intc>;
353
354			status = "okay";
355		};
356
357		i2c_pse_3: i2c_pse_3 {
358			compatible = "snps,designware-i2c";
359			clock-frequency = <I2C_BITRATE_STANDARD>;
360			#address-cells = <1>;
361			#size-cells = <0>;
362			vendor-id = <0x8086>;
363			device-id = <0x4bbc>;
364			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
365			interrupt-parent = <&intc>;
366
367			status = "okay";
368		};
369
370		i2c_pse_4: i2c_pse_4 {
371			compatible = "snps,designware-i2c";
372			clock-frequency = <I2C_BITRATE_STANDARD>;
373			#address-cells = <1>;
374			#size-cells = <0>;
375			vendor-id = <0x8086>;
376			device-id = <0x4bbd>;
377			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
378			interrupt-parent = <&intc>;
379
380			status = "okay";
381		};
382
383		i2c_pse_5: i2c_pse_5 {
384			compatible = "snps,designware-i2c";
385			clock-frequency = <I2C_BITRATE_STANDARD>;
386			#address-cells = <1>;
387			#size-cells = <0>;
388			vendor-id = <0x8086>;
389			device-id = <0x4bbe>;
390			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
391			interrupt-parent = <&intc>;
392
393			status = "okay";
394		};
395
396		i2c_pse_6: i2c_pse_6 {
397			compatible = "snps,designware-i2c";
398			clock-frequency = <I2C_BITRATE_STANDARD>;
399			#address-cells = <1>;
400			#size-cells = <0>;
401			vendor-id = <0x8086>;
402			device-id = <0x4bbf>;
403			interrupts = <PCIE_IRQ_DETECT IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
404			interrupt-parent = <&intc>;
405
406			status = "okay";
407		};
408	};
409
410	soc {
411		#address-cells = <1>;
412		#size-cells = <1>;
413		compatible = "simple-bus";
414		ranges;
415
416		vtd: vtd@fed91000 {
417			compatible = "intel,vt-d";
418
419			reg = <0xfed91000 0x1000>;
420
421			status = "okay";
422		};
423
424
425		uart1_fixed: uart@fe040000 {
426			compatible = "ns16550";
427
428			reg = <0xfe040000 0x1000>;
429			reg-shift = <0>;
430
431			clock-frequency = <1843200>;
432			interrupts = <3 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
433			interrupt-parent = <&intc>;
434
435			status = "disabled";
436			current-speed = <115200>;
437		};
438
439		uart2_fixed: uart@fe042000 {
440			compatible = "ns16550";
441
442			reg = <0xfe042000 0x1000>;
443			reg-shift = <0>;
444
445			clock-frequency = <1843200>;
446			interrupts = <4 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
447			interrupt-parent = <&intc>;
448
449			status = "disabled";
450			current-speed = <115200>;
451		};
452
453		gpio_0_b: gpio@fd6e0700 {
454			compatible = "intel,gpio";
455			reg = <0xfd6e0700 0x1000>;
456			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
457			interrupt-parent = <&intc>;
458
459			group-index = <0x0>;
460			gpio-controller;
461			#gpio-cells = <2>;
462
463			ngpios = <24>;
464			pin-offset = <0>;
465
466			status = "okay";
467		};
468
469		gpio_0_t: gpio@fd6e08a0 {
470			compatible = "intel,gpio";
471			reg = <0xfd6e08a0 0x1000>;
472			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
473			interrupt-parent = <&intc>;
474
475			group-index = <0x1>;
476			gpio-controller;
477			#gpio-cells = <2>;
478
479			ngpios = <16>;
480			pin-offset = <26>;
481
482			status = "okay";
483		};
484
485		gpio_0_g: gpio@fd6e09a0 {
486			compatible = "intel,gpio";
487			reg = <0xfd6e09a0 0x1000>;
488			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
489			interrupt-parent = <&intc>;
490
491			group-index = <0x2>;
492			gpio-controller;
493			#gpio-cells = <2>;
494
495			ngpios = <24>;
496			pin-offset = <42>;
497
498			status = "okay";
499		};
500
501		gpio_1_v: gpio@fd6d0700 {
502			compatible = "intel,gpio";
503			reg = <0xfd6d0700 0x1000>;
504			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
505			interrupt-parent = <&intc>;
506
507			group-index = <0x0>;
508			gpio-controller;
509			#gpio-cells = <2>;
510
511			ngpios = <16>;
512			pin-offset = <0>;
513
514			status = "okay";
515		};
516
517		gpio_1_h: gpio@fd6d0800 {
518			compatible = "intel,gpio";
519			reg = <0xfd6d0800 0x1000>;
520			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
521			interrupt-parent = <&intc>;
522
523			group-index = <0x1>;
524			gpio-controller;
525			#gpio-cells = <2>;
526
527			ngpios = <24>;
528			pin-offset = <16>;
529
530			status = "okay";
531		};
532
533		gpio_1_d: gpio@fd6d0980 {
534			compatible = "intel,gpio";
535			reg = <0xfd6d0980 0x1000>;
536			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
537			interrupt-parent = <&intc>;
538
539			group-index = <0x2>;
540			gpio-controller;
541			#gpio-cells = <2>;
542
543			ngpios = <20>;
544			pin-offset = <40>;
545
546			status = "okay";
547		};
548
549		gpio_1_u: gpio@fd6d0ad0 {
550			compatible = "intel,gpio";
551			reg = <0xfd6d0ad0 0x1000>;
552			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
553			interrupt-parent = <&intc>;
554
555			group-index = <0x3>;
556			gpio-controller;
557			#gpio-cells = <2>;
558
559			ngpios = <20>;
560			pin-offset = <61>;
561
562			status = "okay";
563		};
564
565		gpio_1_vG: gpio@fd6d0c50 {
566			compatible = "intel,gpio";
567			reg = <0xfd6d0c50 0x1000>;
568			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
569			interrupt-parent = <&intc>;
570
571			group-index = <0x4>;
572			gpio-controller;
573			#gpio-cells = <2>;
574
575			ngpios = <28>;
576			pin-offset = <85>;
577
578			status = "okay";
579		};
580
581		gpio_3_s: gpio@fd6b0810 {
582			compatible = "intel,gpio";
583			reg = <0xfd6b0810 0x1000>;
584			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
585			interrupt-parent = <&intc>;
586
587			group-index = <0x1>;
588			gpio-controller;
589			#gpio-cells = <2>;
590
591			ngpios = <2>;
592			pin-offset = <17>;
593
594			status = "okay";
595		};
596
597		gpio_3_a: gpio@fd6b0830 {
598			compatible = "intel,gpio";
599			reg = <0xfd6b0830 0x1000>;
600			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
601			interrupt-parent = <&intc>;
602
603			group-index = <0x2>;
604			gpio-controller;
605			#gpio-cells = <2>;
606
607			ngpios = <24>;
608			pin-offset = <25>;
609
610			status = "okay";
611		};
612
613		gpio_3_vG: gpio@fd6b09b0 {
614			compatible = "intel,gpio";
615			reg = <0xfd6b09b0 0x1000>;
616			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
617			interrupt-parent = <&intc>;
618
619			group-index = <0x3>;
620			gpio-controller;
621			#gpio-cells = <2>;
622
623			ngpios = <4>;
624			pin-offset = <49>;
625
626			status = "okay";
627		};
628
629		gpio_4_c: gpio@fd6a0700 {
630			compatible = "intel,gpio";
631			reg = <0xfd6a0700 0x1000>;
632			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
633			interrupt-parent = <&intc>;
634
635			group-index = <0x0>;
636			gpio-controller;
637			#gpio-cells = <2>;
638
639			ngpios = <24>;
640			pin-offset = <0>;
641
642			status = "okay";
643		};
644
645		gpio_4_f: gpio@fd6a0880 {
646			compatible = "intel,gpio";
647			reg = <0xfd6a0880 0x1000>;
648			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
649			interrupt-parent = <&intc>;
650
651			group-index = <0x1>;
652			gpio-controller;
653			#gpio-cells = <2>;
654
655			ngpios = <24>;
656			pin-offset = <24>;
657
658			status = "okay";
659		};
660
661		gpio_4_e: gpio@fd6a0a70 {
662			compatible = "intel,gpio";
663			reg = <0xfd6a0a70 0x1000>;
664			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
665			interrupt-parent = <&intc>;
666
667			group-index = <0x3>;
668			gpio-controller;
669			#gpio-cells = <2>;
670
671			ngpios = <24>;
672			pin-offset = <57>;
673
674			status = "okay";
675		};
676
677		gpio_5_r: gpio@fd690700 {
678			compatible = "intel,gpio";
679			reg = <0xfd690700 0x1000>;
680			interrupts = <14 IRQ_TYPE_LOWEST_LEVEL_LOW 3>;
681			interrupt-parent = <&intc>;
682
683			group-index = <0x0>;
684			gpio-controller;
685			#gpio-cells = <2>;
686
687			ngpios = <8>;
688			pin-offset = <0>;
689
690			status = "okay";
691		};
692
693		hpet: hpet@fed00000 {
694			compatible = "intel,hpet";
695			reg = <0xfed00000 0x400>;
696			interrupts = <2 IRQ_TYPE_FIXED_EDGE_RISING 4>;
697			interrupt-parent = <&intc>;
698
699			status = "okay";
700		};
701
702		tco_wdt: tco_wdt@400 {
703			compatible = "intel,tco-wdt";
704			reg = <0x0400 0x20>;
705
706			status = "disabled";
707		};
708
709		rtc: counter: rtc@70 {
710			compatible = "motorola,mc146818";
711			reg = <0x70 0x0D 0x71 0x0D>;
712			interrupts = <8 IRQ_TYPE_LOWEST_EDGE_RISING 3>;
713			interrupt-parent = <&intc>;
714			alarms-count = <1>;
715
716			status = "okay";
717		};
718
719	};
720};
721