blob: b580f9263d0225036665312c1e46e5ea631a0a11 [file] [log] [blame]
Michal Simek090a2d72018-03-27 10:36:39 +02001// SPDX-License-Identifier: GPL-2.0+
Michal Simek5fc61c82016-04-07 15:58:23 +02002/*
Michal Simek0bfbb212017-11-02 10:21:08 +01003 * dts file for Xilinx ZynqMP ZCU102 RevA
Michal Simek5fc61c82016-04-07 15:58:23 +02004 *
Michal Simek090a2d72018-03-27 10:36:39 +02005 * (C) Copyright 2015 - 2018, Xilinx, Inc.
Michal Simek5fc61c82016-04-07 15:58:23 +02006 *
7 * Michal Simek <michal.simek@xilinx.com>
Michal Simek5fc61c82016-04-07 15:58:23 +02008 */
9
10/dts-v1/;
11
12#include "zynqmp.dtsi"
Michal Simeka6604b62017-12-08 14:50:42 +010013#include "zynqmp-clk-ccf.dtsi"
Michal Simekc87c7b22018-03-27 12:13:13 +020014#include <dt-bindings/input/input.h>
Michal Simek7df37832016-05-25 20:09:35 +020015#include <dt-bindings/gpio/gpio.h>
Michal Simekd5ba4f22017-12-01 15:50:31 +010016#include <dt-bindings/phy/phy.h>
Michal Simek5fc61c82016-04-07 15:58:23 +020017
18/ {
19 model = "ZynqMP ZCU102 RevA";
Michal Simek40d839a2017-07-20 12:38:27 +020020 compatible = "xlnx,zynqmp-zcu102-revA", "xlnx,zynqmp-zcu102", "xlnx,zynqmp";
Michal Simek5fc61c82016-04-07 15:58:23 +020021
22 aliases {
23 ethernet0 = &gem3;
24 gpio0 = &gpio;
25 i2c0 = &i2c0;
26 i2c1 = &i2c1;
27 mmc0 = &sdhci1;
28 rtc0 = &rtc;
29 serial0 = &uart0;
30 serial1 = &uart1;
Michal Simekde29d542016-09-09 08:46:39 +020031 serial2 = &dcc;
Michal Simek5fc61c82016-04-07 15:58:23 +020032 spi0 = &qspi;
33 usb0 = &usb0;
34 };
35
36 chosen {
37 bootargs = "earlycon";
38 stdout-path = "serial0:115200n8";
Michal Simek53b97e62019-01-18 09:10:39 +010039 xlnx,eeprom = &eeprom;
Michal Simek5fc61c82016-04-07 15:58:23 +020040 };
41
Michal Simek79c1cbf2016-11-11 13:21:04 +010042 memory@0 {
Michal Simek5fc61c82016-04-07 15:58:23 +020043 device_type = "memory";
44 reg = <0x0 0x0 0x0 0x80000000>, <0x8 0x00000000 0x0 0x80000000>;
45 };
Michal Simekbe3c95f2016-04-20 13:12:25 +020046
Michal Simek7df37832016-05-25 20:09:35 +020047 gpio-keys {
48 compatible = "gpio-keys";
Michal Simek7df37832016-05-25 20:09:35 +020049 autorepeat;
50 sw19 {
51 label = "sw19";
52 gpios = <&gpio 22 GPIO_ACTIVE_HIGH>;
Michal Simekc87c7b22018-03-27 12:13:13 +020053 linux,code = <KEY_DOWN>;
Sudeep Holla13104ce2018-10-24 12:45:40 +010054 wakeup-source;
Michal Simek7df37832016-05-25 20:09:35 +020055 autorepeat;
56 };
57 };
58
Michal Simekbe3c95f2016-04-20 13:12:25 +020059 leds {
60 compatible = "gpio-leds";
Michal Simek2ef53362018-11-08 10:06:53 +010061 heartbeat-led {
Michal Simekbe3c95f2016-04-20 13:12:25 +020062 label = "heartbeat";
Chirag Parekhcc406a62017-01-25 07:00:57 -080063 gpios = <&gpio 23 GPIO_ACTIVE_HIGH>;
Michal Simekbe3c95f2016-04-20 13:12:25 +020064 linux,default-trigger = "heartbeat";
65 };
66 };
Michal Simek41a41a42019-08-16 10:42:42 +020067
68 ina226-u76 {
69 compatible = "iio-hwmon";
70 io-channels = <&u76 0>, <&u76 1>, <&u76 2>, <&u76 3>;
71 };
72 ina226-u77 {
73 compatible = "iio-hwmon";
74 io-channels = <&u77 0>, <&u77 1>, <&u77 2>, <&u77 3>;
75 };
76 ina226-u78 {
77 compatible = "iio-hwmon";
78 io-channels = <&u78 0>, <&u78 1>, <&u78 2>, <&u78 3>;
79 };
80 ina226-u87 {
81 compatible = "iio-hwmon";
82 io-channels = <&u87 0>, <&u87 1>, <&u87 2>, <&u87 3>;
83 };
84 ina226-u85 {
85 compatible = "iio-hwmon";
86 io-channels = <&u85 0>, <&u85 1>, <&u85 2>, <&u85 3>;
87 };
88 ina226-u86 {
89 compatible = "iio-hwmon";
90 io-channels = <&u86 0>, <&u86 1>, <&u86 2>, <&u86 3>;
91 };
92 ina226-u93 {
93 compatible = "iio-hwmon";
94 io-channels = <&u93 0>, <&u93 1>, <&u93 2>, <&u93 3>;
95 };
96 ina226-u88 {
97 compatible = "iio-hwmon";
98 io-channels = <&u88 0>, <&u88 1>, <&u88 2>, <&u88 3>;
99 };
100 ina226-u15 {
101 compatible = "iio-hwmon";
102 io-channels = <&u15 0>, <&u15 1>, <&u15 2>, <&u15 3>;
103 };
104 ina226-u92 {
105 compatible = "iio-hwmon";
106 io-channels = <&u92 0>, <&u92 1>, <&u92 2>, <&u92 3>;
107 };
108 ina226-u79 {
109 compatible = "iio-hwmon";
110 io-channels = <&u79 0>, <&u79 1>, <&u79 2>, <&u79 3>;
111 };
112 ina226-u81 {
113 compatible = "iio-hwmon";
114 io-channels = <&u81 0>, <&u81 1>, <&u81 2>, <&u81 3>;
115 };
116 ina226-u80 {
117 compatible = "iio-hwmon";
118 io-channels = <&u80 0>, <&u80 1>, <&u80 2>, <&u80 3>;
119 };
120 ina226-u84 {
121 compatible = "iio-hwmon";
122 io-channels = <&u84 0>, <&u84 1>, <&u84 2>, <&u84 3>;
123 };
124 ina226-u16 {
125 compatible = "iio-hwmon";
126 io-channels = <&u16 0>, <&u16 1>, <&u16 2>, <&u16 3>;
127 };
128 ina226-u65 {
129 compatible = "iio-hwmon";
130 io-channels = <&u65 0>, <&u65 1>, <&u65 2>, <&u65 3>;
131 };
132 ina226-u74 {
133 compatible = "iio-hwmon";
134 io-channels = <&u74 0>, <&u74 1>, <&u74 2>, <&u74 3>;
135 };
136 ina226-u75 {
137 compatible = "iio-hwmon";
138 io-channels = <&u75 0>, <&u75 1>, <&u75 2>, <&u75 3>;
139 };
Michal Simek5fc61c82016-04-07 15:58:23 +0200140};
141
142&can1 {
143 status = "okay";
144};
145
Michal Simekde29d542016-09-09 08:46:39 +0200146&dcc {
147 status = "okay";
148};
149
Michal Simek5fc61c82016-04-07 15:58:23 +0200150&fpd_dma_chan1 {
151 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200152};
153
154&fpd_dma_chan2 {
155 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200156};
157
158&fpd_dma_chan3 {
159 status = "okay";
160};
161
162&fpd_dma_chan4 {
163 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200164};
165
166&fpd_dma_chan5 {
167 status = "okay";
168};
169
170&fpd_dma_chan6 {
171 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200172};
173
174&fpd_dma_chan7 {
175 status = "okay";
176};
177
178&fpd_dma_chan8 {
179 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200180};
181
182&gem3 {
183 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200184 phy-handle = <&phy0>;
185 phy-mode = "rgmii-id";
Michal Simek393decf2019-08-08 12:44:22 +0200186 phy0: ethernet-phy@21 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200187 reg = <21>;
188 ti,rx-internal-delay = <0x8>;
189 ti,tx-internal-delay = <0xa>;
190 ti,fifo-depth = <0x1>;
Harini Katakam991a1612019-02-13 17:02:21 +0530191 ti,dp83867-rxctrl-strap-quirk;
Harini Katakam4d367cd2019-03-13 19:41:19 +0530192 /* reset-gpios = <&tca6416_u97 6 GPIO_ACTIVE_LOW>; */
Michal Simek5fc61c82016-04-07 15:58:23 +0200193 };
194};
195
196&gpio {
197 status = "okay";
198};
199
200&gpu {
201 status = "okay";
202};
203
204&i2c0 {
205 status = "okay";
206 clock-frequency = <400000>;
207
208 tca6416_u97: gpio@20 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200209 compatible = "ti,tca6416";
210 reg = <0x20>;
Michal Simeka545f5f2019-03-12 10:15:27 +0100211 gpio-controller; /* IRQ not connected */
Michal Simek5fc61c82016-04-07 15:58:23 +0200212 #gpio-cells = <2>;
Michal Simeka545f5f2019-03-12 10:15:27 +0100213 gpio-line-names = "PS_GTR_LAN_SEL0", "PS_GTR_LAN_SEL1", "PS_GTR_LAN_SEL2", "PS_GTR_LAN_SEL3",
214 "PCI_CLK_DIR_SEL", "IIC_MUX_RESET_B", "GEM3_EXP_RESET_B",
215 "", "", "", "", "", "", "", "", "";
Michal Simek2ef53362018-11-08 10:06:53 +0100216 gtr-sel0 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200217 gpio-hog;
218 gpios = <0 0>;
Bharat Kumar Gogadae6464352017-01-30 12:06:02 +0530219 output-low; /* PCIE = 0, DP = 1 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200220 line-name = "sel0";
221 };
Michal Simek2ef53362018-11-08 10:06:53 +0100222 gtr-sel1 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200223 gpio-hog;
224 gpios = <1 0>;
225 output-high; /* PCIE = 0, DP = 1 */
226 line-name = "sel1";
227 };
Michal Simek2ef53362018-11-08 10:06:53 +0100228 gtr-sel2 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200229 gpio-hog;
230 gpios = <2 0>;
231 output-high; /* PCIE = 0, USB0 = 1 */
232 line-name = "sel2";
233 };
Michal Simek2ef53362018-11-08 10:06:53 +0100234 gtr-sel3 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200235 gpio-hog;
236 gpios = <3 0>;
237 output-high; /* PCIE = 0, SATA = 1 */
238 line-name = "sel3";
239 };
240 };
241
Michal Simekd45b4402018-03-27 10:47:26 +0200242 tca6416_u61: gpio@21 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200243 compatible = "ti,tca6416";
244 reg = <0x21>;
Michal Simeka545f5f2019-03-12 10:15:27 +0100245 gpio-controller; /* IRQ not connected */
Michal Simek5fc61c82016-04-07 15:58:23 +0200246 #gpio-cells = <2>;
Michal Simeka545f5f2019-03-12 10:15:27 +0100247 gpio-line-names = "VCCPSPLL_EN", "MGTRAVCC_EN", "MGTRAVTT_EN", "VCCPSDDRPLL_EN", "MIO26_PMU_INPUT_LS",
248 "PL_PMBUS_ALERT", "PS_PMBUS_ALERT", "MAXIM_PMBUS_ALERT", "PL_DDR4_VTERM_EN",
249 "PL_DDR4_VPP_2V5_EN", "PS_DIMM_VDDQ_TO_PSVCCO_ON", "PS_DIMM_SUSPEND_EN",
250 "PS_DDR4_VTERM_EN", "PS_DDR4_VPP_2V5_EN", "", "";
Michal Simek5fc61c82016-04-07 15:58:23 +0200251 };
252
Michal Simek2fde09e2018-03-27 10:38:08 +0200253 i2c-mux@75 { /* u60 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200254 compatible = "nxp,pca9544";
255 #address-cells = <1>;
256 #size-cells = <0>;
257 reg = <0x75>;
Michal Simekd45b4402018-03-27 10:47:26 +0200258 i2c@0 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200259 #address-cells = <1>;
260 #size-cells = <0>;
261 reg = <0>;
262 /* PS_PMBUS */
Michal Simek41a41a42019-08-16 10:42:42 +0200263 u76: ina226@40 { /* u76 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200264 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200265 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200266 label = "ina226-u76";
Michal Simek5fc61c82016-04-07 15:58:23 +0200267 reg = <0x40>;
268 shunt-resistor = <5000>;
269 };
Michal Simek41a41a42019-08-16 10:42:42 +0200270 u77: ina226@41 { /* u77 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200271 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200272 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200273 label = "ina226-u77";
Michal Simek5fc61c82016-04-07 15:58:23 +0200274 reg = <0x41>;
275 shunt-resistor = <5000>;
276 };
Michal Simek41a41a42019-08-16 10:42:42 +0200277 u78: ina226@42 { /* u78 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200278 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200279 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200280 label = "ina226-u78";
Michal Simek5fc61c82016-04-07 15:58:23 +0200281 reg = <0x42>;
282 shunt-resistor = <5000>;
283 };
Michal Simek41a41a42019-08-16 10:42:42 +0200284 u87: ina226@43 { /* u87 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200285 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200286 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200287 label = "ina226-u87";
Michal Simek5fc61c82016-04-07 15:58:23 +0200288 reg = <0x43>;
289 shunt-resistor = <5000>;
290 };
Michal Simek41a41a42019-08-16 10:42:42 +0200291 u85: ina226@44 { /* u85 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200292 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200293 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200294 label = "ina226-u85";
Michal Simek5fc61c82016-04-07 15:58:23 +0200295 reg = <0x44>;
296 shunt-resistor = <5000>;
297 };
Michal Simek41a41a42019-08-16 10:42:42 +0200298 u86: ina226@45 { /* u86 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200299 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200300 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200301 label = "ina226-u86";
Michal Simek5fc61c82016-04-07 15:58:23 +0200302 reg = <0x45>;
303 shunt-resistor = <5000>;
304 };
Michal Simek41a41a42019-08-16 10:42:42 +0200305 u93: ina226@46 { /* u93 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200306 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200307 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200308 label = "ina226-u93";
Michal Simek5fc61c82016-04-07 15:58:23 +0200309 reg = <0x46>;
310 shunt-resistor = <5000>;
311 };
Michal Simek41a41a42019-08-16 10:42:42 +0200312 u88: ina226@47 { /* u88 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200313 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200314 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200315 label = "ina226-u88";
Michal Simek5fc61c82016-04-07 15:58:23 +0200316 reg = <0x47>;
317 shunt-resistor = <5000>;
318 };
Michal Simek41a41a42019-08-16 10:42:42 +0200319 u15: ina226@4a { /* u15 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200320 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200321 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200322 label = "ina226-u15";
Michal Simek5fc61c82016-04-07 15:58:23 +0200323 reg = <0x4a>;
324 shunt-resistor = <5000>;
325 };
Michal Simek41a41a42019-08-16 10:42:42 +0200326 u92: ina226@4b { /* u92 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200327 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200328 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200329 label = "ina226-u92";
Michal Simek5fc61c82016-04-07 15:58:23 +0200330 reg = <0x4b>;
331 shunt-resistor = <5000>;
332 };
333 };
Michal Simekd45b4402018-03-27 10:47:26 +0200334 i2c@1 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200335 #address-cells = <1>;
336 #size-cells = <0>;
337 reg = <1>;
338 /* PL_PMBUS */
Michal Simek41a41a42019-08-16 10:42:42 +0200339 u79: ina226@40 { /* u79 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200340 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200341 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200342 label = "ina226-u79";
Michal Simek5fc61c82016-04-07 15:58:23 +0200343 reg = <0x40>;
344 shunt-resistor = <2000>;
345 };
Michal Simek41a41a42019-08-16 10:42:42 +0200346 u81: ina226@41 { /* u81 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200347 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200348 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200349 label = "ina226-u81";
Michal Simek5fc61c82016-04-07 15:58:23 +0200350 reg = <0x41>;
351 shunt-resistor = <5000>;
352 };
Michal Simek41a41a42019-08-16 10:42:42 +0200353 u80: ina226@42 { /* u80 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200354 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200355 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200356 label = "ina226-u80";
Michal Simek5fc61c82016-04-07 15:58:23 +0200357 reg = <0x42>;
358 shunt-resistor = <5000>;
359 };
Michal Simek41a41a42019-08-16 10:42:42 +0200360 u84: ina226@43 { /* u84 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200361 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200362 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200363 label = "ina226-u84";
Michal Simek5fc61c82016-04-07 15:58:23 +0200364 reg = <0x43>;
365 shunt-resistor = <5000>;
366 };
Michal Simek41a41a42019-08-16 10:42:42 +0200367 u16: ina226@44 { /* u16 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200368 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200369 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200370 label = "ina226-u16";
Michal Simek5fc61c82016-04-07 15:58:23 +0200371 reg = <0x44>;
372 shunt-resistor = <5000>;
373 };
Michal Simek41a41a42019-08-16 10:42:42 +0200374 u65: ina226@45 { /* u65 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200375 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200376 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200377 label = "ina226-u65";
Michal Simek5fc61c82016-04-07 15:58:23 +0200378 reg = <0x45>;
379 shunt-resistor = <5000>;
380 };
Michal Simek41a41a42019-08-16 10:42:42 +0200381 u74: ina226@46 { /* u74 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200382 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200383 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200384 label = "ina226-u74";
Michal Simek5fc61c82016-04-07 15:58:23 +0200385 reg = <0x46>;
386 shunt-resistor = <5000>;
387 };
Michal Simek41a41a42019-08-16 10:42:42 +0200388 u75: ina226@47 { /* u75 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200389 compatible = "ti,ina226";
Michal Simek41a41a42019-08-16 10:42:42 +0200390 #io-channel-cells = <1>;
Michal Simeka246bed2019-08-26 10:20:07 +0200391 label = "ina226-u75";
Michal Simek5fc61c82016-04-07 15:58:23 +0200392 reg = <0x47>;
393 shunt-resistor = <5000>;
394 };
395 };
Michal Simekd45b4402018-03-27 10:47:26 +0200396 i2c@2 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200397 #address-cells = <1>;
398 #size-cells = <0>;
399 reg = <2>;
400 /* MAXIM_PMBUS - 00 */
401 max15301@a { /* u46 */
Michal Simekcba5b322018-03-27 10:52:40 +0200402 compatible = "maxim,max15301";
Michal Simek5fc61c82016-04-07 15:58:23 +0200403 reg = <0xa>;
404 };
405 max15303@b { /* u4 */
Michal Simekcba5b322018-03-27 10:52:40 +0200406 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200407 reg = <0xb>;
408 };
409 max15303@10 { /* u13 */
Michal Simekcba5b322018-03-27 10:52:40 +0200410 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200411 reg = <0x10>;
412 };
413 max15301@13 { /* u47 */
Michal Simekcba5b322018-03-27 10:52:40 +0200414 compatible = "maxim,max15301";
Michal Simek5fc61c82016-04-07 15:58:23 +0200415 reg = <0x13>;
416 };
417 max15303@14 { /* u7 */
Michal Simekcba5b322018-03-27 10:52:40 +0200418 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200419 reg = <0x14>;
420 };
421 max15303@15 { /* u6 */
Michal Simekcba5b322018-03-27 10:52:40 +0200422 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200423 reg = <0x15>;
424 };
425 max15303@16 { /* u10 */
Michal Simekcba5b322018-03-27 10:52:40 +0200426 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200427 reg = <0x16>;
428 };
429 max15303@17 { /* u9 */
Michal Simekcba5b322018-03-27 10:52:40 +0200430 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200431 reg = <0x17>;
432 };
433 max15301@18 { /* u63 */
Michal Simekcba5b322018-03-27 10:52:40 +0200434 compatible = "maxim,max15301";
Michal Simek5fc61c82016-04-07 15:58:23 +0200435 reg = <0x18>;
436 };
437 max15303@1a { /* u49 */
Michal Simekcba5b322018-03-27 10:52:40 +0200438 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200439 reg = <0x1a>;
440 };
441 max15303@1d { /* u18 */
Michal Simekcba5b322018-03-27 10:52:40 +0200442 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200443 reg = <0x1d>;
444 };
445 max15303@20 { /* u8 */
Michal Simekcba5b322018-03-27 10:52:40 +0200446 compatible = "maxim,max15303";
Michal Simek5fc61c82016-04-07 15:58:23 +0200447 status = "disabled"; /* unreachable */
448 reg = <0x20>;
449 };
Michal Simek84dc3c02018-03-27 12:01:24 +0200450 max20751@72 { /* u95 */
Michal Simekcba5b322018-03-27 10:52:40 +0200451 compatible = "maxim,max20751";
Michal Simek5fc61c82016-04-07 15:58:23 +0200452 reg = <0x72>;
453 };
Michal Simek84dc3c02018-03-27 12:01:24 +0200454 max20751@73 { /* u96 */
Michal Simekcba5b322018-03-27 10:52:40 +0200455 compatible = "maxim,max20751";
Michal Simek5fc61c82016-04-07 15:58:23 +0200456 reg = <0x73>;
457 };
458 };
459 /* Bus 3 is not connected */
460 };
Michal Simek5fc61c82016-04-07 15:58:23 +0200461};
462
463&i2c1 {
464 status = "okay";
465 clock-frequency = <400000>;
Michal Simek6471f8e2017-11-02 11:51:59 +0100466
Michal Simek84dc3c02018-03-27 12:01:24 +0200467 /* PL i2c via PCA9306 - u45 */
Michal Simek2fde09e2018-03-27 10:38:08 +0200468 i2c-mux@74 { /* u34 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200469 compatible = "nxp,pca9548";
470 #address-cells = <1>;
471 #size-cells = <0>;
472 reg = <0x74>;
Michal Simekd45b4402018-03-27 10:47:26 +0200473 i2c@0 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200474 #address-cells = <1>;
475 #size-cells = <0>;
476 reg = <0>;
477 /*
478 * IIC_EEPROM 1kB memory which uses 256B blocks
479 * where every block has different address.
480 * 0 - 256B address 0x54
481 * 256B - 512B address 0x55
482 * 512B - 768B address 0x56
483 * 768B - 1024B address 0x57
484 */
Michal Simekc9ce08d2017-11-02 11:42:12 +0100485 eeprom: eeprom@54 { /* u23 */
Michal Simek28cf3ba2018-03-27 10:54:25 +0200486 compatible = "atmel,24c08";
Michal Simek5fc61c82016-04-07 15:58:23 +0200487 reg = <0x54>;
488 };
489 };
Michal Simekd45b4402018-03-27 10:47:26 +0200490 i2c@1 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200491 #address-cells = <1>;
492 #size-cells = <0>;
493 reg = <1>;
Michal Simek68ddc172018-03-27 10:39:53 +0200494 si5341: clock-generator@36 { /* SI5341 - u69 */
Michal Simek7b5a7a42018-03-27 12:48:30 +0200495 compatible = "silabs,si5341";
Michal Simek5fc61c82016-04-07 15:58:23 +0200496 reg = <0x36>;
497 };
498
499 };
Michal Simekd45b4402018-03-27 10:47:26 +0200500 i2c@2 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200501 #address-cells = <1>;
502 #size-cells = <0>;
503 reg = <2>;
Michal Simek68ddc172018-03-27 10:39:53 +0200504 si570_1: clock-generator@5d { /* USER SI570 - u42 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200505 #clock-cells = <0>;
506 compatible = "silabs,si570";
507 reg = <0x5d>;
508 temperature-stability = <50>;
509 factory-fout = <300000000>;
510 clock-frequency = <300000000>;
Michal Simek3cf07bf2018-07-18 12:10:02 +0200511 clock-output-names = "si570_user";
Michal Simek5fc61c82016-04-07 15:58:23 +0200512 };
513 };
Michal Simekd45b4402018-03-27 10:47:26 +0200514 i2c@3 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200515 #address-cells = <1>;
516 #size-cells = <0>;
517 reg = <3>;
Michal Simek68ddc172018-03-27 10:39:53 +0200518 si570_2: clock-generator@5d { /* USER MGT SI570 - u56 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200519 #clock-cells = <0>;
520 compatible = "silabs,si570";
521 reg = <0x5d>;
522 temperature-stability = <50>; /* copy from zc702 */
523 factory-fout = <156250000>;
524 clock-frequency = <148500000>;
Michal Simek3cf07bf2018-07-18 12:10:02 +0200525 clock-output-names = "si570_mgt";
Michal Simek5fc61c82016-04-07 15:58:23 +0200526 };
527 };
Michal Simekd45b4402018-03-27 10:47:26 +0200528 i2c@4 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200529 #address-cells = <1>;
530 #size-cells = <0>;
531 reg = <4>;
Michal Simek68ddc172018-03-27 10:39:53 +0200532 si5328: clock-generator@69 {/* SI5328 - u20 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200533 compatible = "silabs,si5328";
534 reg = <0x69>;
Michal Simek20c17792017-11-02 12:45:10 +0100535 /*
536 * Chip has interrupt present connected to PL
537 * interrupt-parent = <&>;
538 * interrupts = <>;
539 */
Michal Simek5fc61c82016-04-07 15:58:23 +0200540 };
541 };
542 /* 5 - 7 unconnected */
543 };
544
Michal Simek2fde09e2018-03-27 10:38:08 +0200545 i2c-mux@75 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200546 compatible = "nxp,pca9548"; /* u135 */
547 #address-cells = <1>;
548 #size-cells = <0>;
549 reg = <0x75>;
550
551 i2c@0 {
552 #address-cells = <1>;
553 #size-cells = <0>;
554 reg = <0>;
555 /* HPC0_IIC */
556 };
557 i2c@1 {
558 #address-cells = <1>;
559 #size-cells = <0>;
560 reg = <1>;
561 /* HPC1_IIC */
562 };
563 i2c@2 {
564 #address-cells = <1>;
565 #size-cells = <0>;
566 reg = <2>;
567 /* SYSMON */
568 };
Michal Simekd45b4402018-03-27 10:47:26 +0200569 i2c@3 {
Michal Simek5fc61c82016-04-07 15:58:23 +0200570 #address-cells = <1>;
571 #size-cells = <0>;
572 reg = <3>;
573 /* DDR4 SODIMM */
Michal Simek5fc61c82016-04-07 15:58:23 +0200574 };
575 i2c@4 {
576 #address-cells = <1>;
577 #size-cells = <0>;
578 reg = <4>;
579 /* SEP 3 */
580 };
581 i2c@5 {
582 #address-cells = <1>;
583 #size-cells = <0>;
584 reg = <5>;
585 /* SEP 2 */
586 };
587 i2c@6 {
588 #address-cells = <1>;
589 #size-cells = <0>;
590 reg = <6>;
591 /* SEP 1 */
592 };
593 i2c@7 {
594 #address-cells = <1>;
595 #size-cells = <0>;
596 reg = <7>;
597 /* SEP 0 */
598 };
599 };
600};
601
602&pcie {
Bharat Kumar Gogadae6464352017-01-30 12:06:02 +0530603 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200604};
605
606&qspi {
607 status = "okay";
608 is-dual = <1>;
609 flash@0 {
Neil Armstronga009fa72019-02-10 10:16:20 +0000610 compatible = "m25p80", "jedec,spi-nor"; /* 32MB */
Michal Simek5fc61c82016-04-07 15:58:23 +0200611 #address-cells = <1>;
612 #size-cells = <1>;
613 reg = <0x0>;
614 spi-tx-bus-width = <1>;
615 spi-rx-bus-width = <4>; /* FIXME also DUAL configuration possible */
616 spi-max-frequency = <108000000>; /* Based on DC1 spec */
617 partition@qspi-fsbl-uboot { /* for testing purpose */
618 label = "qspi-fsbl-uboot";
619 reg = <0x0 0x100000>;
620 };
621 partition@qspi-linux { /* for testing purpose */
622 label = "qspi-linux";
623 reg = <0x100000 0x500000>;
624 };
625 partition@qspi-device-tree { /* for testing purpose */
626 label = "qspi-device-tree";
627 reg = <0x600000 0x20000>;
628 };
629 partition@qspi-rootfs { /* for testing purpose */
630 label = "qspi-rootfs";
631 reg = <0x620000 0x5E0000>;
632 };
633 };
634};
635
636&rtc {
637 status = "okay";
638};
639
640&sata {
641 status = "okay";
642 /* SATA OOB timing settings */
643 ceva,p0-cominit-params = /bits/ 8 <0x18 0x40 0x18 0x28>;
644 ceva,p0-comwake-params = /bits/ 8 <0x06 0x14 0x08 0x0E>;
645 ceva,p0-burst-params = /bits/ 8 <0x13 0x08 0x4A 0x06>;
646 ceva,p0-retry-params = /bits/ 16 <0x96A4 0x3FFC>;
647 ceva,p1-cominit-params = /bits/ 8 <0x18 0x40 0x18 0x28>;
648 ceva,p1-comwake-params = /bits/ 8 <0x06 0x14 0x08 0x0E>;
649 ceva,p1-burst-params = /bits/ 8 <0x13 0x08 0x4A 0x06>;
650 ceva,p1-retry-params = /bits/ 16 <0x96A4 0x3FFC>;
Michal Simekd5ba4f22017-12-01 15:50:31 +0100651 phy-names = "sata-phy";
652 phys = <&lane3 PHY_TYPE_SATA 1 1 125000000>;
Michal Simek5fc61c82016-04-07 15:58:23 +0200653};
654
655/* SD1 with level shifter */
656&sdhci1 {
657 status = "okay";
658 no-1-8-v; /* for 1.0 silicon */
Sai Krishna Potthuri02550fb2016-08-16 14:41:35 +0530659 xlnx,mio_bank = <1>;
Michal Simek5fc61c82016-04-07 15:58:23 +0200660};
661
Michal Simekd5ba4f22017-12-01 15:50:31 +0100662&serdes {
663 status = "okay";
664};
665
Michal Simek5fc61c82016-04-07 15:58:23 +0200666&uart0 {
667 status = "okay";
668};
669
670&uart1 {
671 status = "okay";
672};
673
674/* ULPI SMSC USB3320 */
675&usb0 {
676 status = "okay";
Michal Simek5fc61c82016-04-07 15:58:23 +0200677};
678
679&dwc3_0 {
680 status = "okay";
681 dr_mode = "host";
Michal Simekd5ba4f22017-12-01 15:50:31 +0100682 snps,usb3_lpm_capable;
683 phy-names = "usb3-phy";
684 phys = <&lane2 PHY_TYPE_USB3 0 2 26000000>;
685 maximum-speed = "super-speed";
Michal Simek5fc61c82016-04-07 15:58:23 +0200686};
687
Shubhrajyoti Dattae036cd62017-04-06 12:28:14 +0530688&watchdog0 {
689 status = "okay";
690};
691
Michal Simek1bb4be32017-11-02 12:04:43 +0100692&xilinx_ams {
693 status = "okay";
694};
695
696&ams_ps {
697 status = "okay";
698};
699
700&ams_pl {
701 status = "okay";
702};
703
Michal Simek5fc61c82016-04-07 15:58:23 +0200704&xilinx_drm {
705 status = "okay";
706 clocks = <&si570_1>;
707};
708
709&xlnx_dp {
710 status = "okay";
711};
712
713&xlnx_dp_sub {
714 status = "okay";
715 xlnx,vid-clk-pl;
716};
717
718&xlnx_dp_snd_pcm0 {
719 status = "okay";
720};
721
722&xlnx_dp_snd_pcm1 {
723 status = "okay";
724};
725
726&xlnx_dp_snd_card {
727 status = "okay";
728};
729
730&xlnx_dp_snd_codec0 {
731 status = "okay";
732};
733
734&xlnx_dpdma {
735 status = "okay";
736};