treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / arch / arm / boot / dts / aspeed-bmc-opp-zaius.dts
blobbc60ec29168114669f4d4483c1b5df74fdd06163
1 // SPDX-License-Identifier: GPL-2.0
2 /dts-v1/;
3 #include "aspeed-g5.dtsi"
4 #include <dt-bindings/gpio/aspeed-gpio.h>
6 / {
7         model = "Zaius BMC";
8         compatible = "ingrasys,zaius-bmc", "aspeed,ast2500";
10         aliases {
11                 i2c15 = &i2cpcie0;
12                 i2c16 = &i2cpcie1;
13                 i2c17 = &i2cpcie2;
14                 i2c19 = &i2cpcie3;
15                 i2c20 = &i2cpcie4;
16         };
18         chosen {
19                 stdout-path = &uart5;
20                 bootargs = "console=ttyS4,115200 earlyprintk";
21         };
23         memory@80000000 {
24                 reg = <0x80000000 0x40000000>;
25         };
27         reserved-memory {
28                 #address-cells = <1>;
29                 #size-cells = <1>;
30                 ranges;
32                 flash_memory: region@98000000 {
33                         no-map;
34                         reg = <0x98000000 0x04000000>; /* 64M */
35                 };
36         };
38         onewire0 {
39                 compatible = "w1-gpio";
40                 gpios = <&gpio ASPEED_GPIO(H, 0) GPIO_ACTIVE_HIGH>;
41         };
43         onewire1 {
44                 compatible = "w1-gpio";
45                 gpios = <&gpio ASPEED_GPIO(H, 1) GPIO_ACTIVE_HIGH>;
46         };
48         onewire2 {
49                 compatible = "w1-gpio";
50                 gpios = <&gpio ASPEED_GPIO(H, 2) GPIO_ACTIVE_HIGH>;
51         };
53         onewire3 {
54                 compatible = "w1-gpio";
55                 gpios = <&gpio ASPEED_GPIO(H, 3) GPIO_ACTIVE_HIGH>;
56         };
58         gpio-keys {
59                 compatible = "gpio-keys";
61                 checkstop {
62                         label = "checkstop";
63                         gpios = <&gpio ASPEED_GPIO(F, 7) GPIO_ACTIVE_LOW>;
64                         linux,code = <ASPEED_GPIO(F, 7)>;
65                 };
67                 pcie-e2b-present{
68                         label = "pcie-e2b-present";
69                         gpios = <&gpio ASPEED_GPIO(E, 7) GPIO_ACTIVE_LOW>;
70                         linux,code = <ASPEED_GPIO(E, 7)>;
71                 };
72         };
74         leds {
75                 compatible = "gpio-leds";
77                 sys_boot_status {
78                         label = "System boot status";
79                         gpios = <&gpio ASPEED_GPIO(D, 5) GPIO_ACTIVE_LOW>;
80                 };
82                 attention {
83                         label = "Attention";
84                         gpios = <&gpio ASPEED_GPIO(D, 6) GPIO_ACTIVE_LOW>;
85                 };
87                 plt_fault {
88                         label = "Platform fault";
89                         gpios = <&gpio ASPEED_GPIO(D, 7) GPIO_ACTIVE_LOW>;
90                 };
92                 hdd_fault {
93                         label = "Onboard drive fault";
94                         gpios = <&gpio ASPEED_GPIO(AA, 2) GPIO_ACTIVE_LOW>;
95                 };
96         };
98         fsi: gpio-fsi {
99                 compatible = "fsi-master-gpio", "fsi-master";
100                 #address-cells = <2>;
101                 #size-cells = <0>;
102                 no-gpio-delays;
104                 trans-gpios = <&gpio ASPEED_GPIO(O, 6) GPIO_ACTIVE_HIGH>;
105                 enable-gpios = <&gpio ASPEED_GPIO(D, 0) GPIO_ACTIVE_HIGH>;
106                 clock-gpios = <&gpio ASPEED_GPIO(G, 0) GPIO_ACTIVE_HIGH>;
107                 data-gpios = <&gpio ASPEED_GPIO(G, 1) GPIO_ACTIVE_HIGH>;
108                 mux-gpios = <&gpio ASPEED_GPIO(P, 6) GPIO_ACTIVE_HIGH>;
109         };
111         iio-hwmon {
112                 compatible = "iio-hwmon";
113                 io-channels = <&adc 0>, <&adc 1>, <&adc 2>, <&adc 3>,
114                         <&adc 4>, <&adc 5>, <&adc 6>, <&adc 7>,
115                         <&adc 8>, <&adc 9>, <&adc 10>, <&adc 11>,
116                         <&adc 13>, <&adc 14>, <&adc 15>;
117         };
119         iio-hwmon-battery {
120                 compatible = "iio-hwmon";
121                 io-channels = <&adc 12>;
122         };
126 &fmc {
127         status = "okay";
129         flash@0 {
130                 status = "okay";
131                 label = "bmc";
132                 m25p,fast-read;
133                 spi-max-frequency = <50000000>;
134 #include "openbmc-flash-layout.dtsi"
135         };
138 &spi1 {
139         status = "okay";
140         pinctrl-names = "default";
141         pinctrl-0 = <&pinctrl_spi1_default>;
143         flash@0 {
144                 status = "okay";
145                 label = "pnor";
146                 m25p,fast-read;
147                 spi-max-frequency = <100000000>;
148         };
151 &spi2 {
152         status = "okay";
153         pinctrl-names = "default";
154         pinctrl-0 = <&pinctrl_spi2ck_default
155                      &pinctrl_spi2cs0_default
156                      &pinctrl_spi2cs1_default
157                      &pinctrl_spi2miso_default
158                      &pinctrl_spi2mosi_default>;
160         flash@0 {
161                 status = "okay";
162         };
165 &uart1 {
166         status = "okay";
167         pinctrl-names = "default";
168         pinctrl-0 = <&pinctrl_txd1_default
169                      &pinctrl_rxd1_default>;
172 &lpc_ctrl {
173         status = "okay";
174         memory-region = <&flash_memory>;
175         flash = <&spi1>;
178 &lpc_snoop {
179         status = "okay";
180         snoop-ports = <0x80>;
184 &uart5 {
185         status = "okay";
188 &mac0 {
189         status = "okay";
190         pinctrl-names = "default";
191         pinctrl-0 = <&pinctrl_rmii1_default>;
192         clocks = <&syscon ASPEED_CLK_GATE_MAC1CLK>,
193                  <&syscon ASPEED_CLK_MAC1RCLK>;
194         clock-names = "MACCLK", "RCLK";
195         use-ncsi;
198 &mac1 {
199         status = "okay";
201         pinctrl-names = "default";
202         pinctrl-0 = <&pinctrl_rgmii2_default &pinctrl_mdio2_default>;
205 &i2c0 {
206         status = "okay";
208         eeprom@50 {
209                 compatible = "atmel,24c64";
210                 reg = <0x50>;
211                 pagesize = <32>;
212         };
214         rtc@68 {
215                 compatible = "nxp,pcf8523";
216                 reg = <0x68>;
217         };
219         ucd90160@64 {
220                 compatible = "ti,ucd90160";
221                 reg = <0x64>;
222         };
224         /* Power sequencer UCD90160 PMBUS @64h
225          * FRU AT24C64D @50h
226          * RTC PCF8523 @68h
227          * Clock buffer 9DBL04 @6dh
228          */
231 &i2c1 {
232         status = "okay";
234         i2c-switch@71 {
235                 compatible = "nxp,pca9546";
236                 reg = <0x71>;
237                 #address-cells = <1>;
238                 #size-cells = <0>;
240                 i2cpcie0: i2c@0 {
241                         #address-cells = <1>;
242                         #size-cells = <0>;
243                         reg = <0>;
244                 };
245                 i2cpcie1: i2c@1 {
246                         #address-cells = <1>;
247                         #size-cells = <0>;
248                         reg = <1>;
249                 };
250                 i2cpcie2: i2c@2 {
251                         #address-cells = <1>;
252                         #size-cells = <0>;
253                         reg = <2>;
254                 };
255                 i2ctpm: i2c@3 {
256                         #address-cells = <1>;
257                         #size-cells = <0>;
258                         reg = <3>;
259                 };
260         };
262         /* MUX1 PCA9546A @71h
263          *   PCIe 0
264          *   PCIe 1
265          *   PCIe 2
266          *   TPM header
267          */
270 &i2c2 {
271         status = "disabled";
273         /* OCP Mezz Connector A (OOB SMBUS) */
276 &i2c3 {
277         status = "disabled";
279         /* OCP Mezz Connector A (PCIe slot SMBUS) */
282 &i2c4 {
283         status = "okay";
285         i2c-switch@71 {
286                 compatible = "nxp,pca9546";
287                 reg = <0x71>;
288                 #address-cells = <1>;
289                 #size-cells = <0>;
291                 i2cpcie3: i2c@0 {
292                         #address-cells = <1>;
293                         #size-cells = <0>;
294                         reg = <0>;
295                 };
296                 i2cpcie4: i2c@1 {
297                         #address-cells = <1>;
298                         #size-cells = <0>;
299                         reg = <1>;
300                 };
301         };
303         /* MUX1 PCA9546A @71h
304          *   PCIe 3
305          *   PCIe 4
306          */
310 &i2c5 {
311         status = "disabled";
313         /* CPU0 PRM 0.7V */
314         /* CPU0 PRM 1.2V CH03 */
315         /* CPU0 PRM 0.8V */
316         /* CPU0 PRM 1.2V CH47 */
319 &i2c6 {
320         status = "disabled";
322         /* CPU1 PRM 0.7V */
323         /* CPU1 PRM 1.2V CH03 */
324         /* CPU1 PRM 0.8V */
325         /* CPU1 PRM 1.2V CH47 */
328 &i2c7 {
329         status = "okay";
331         pca9541a@70 {
332                 compatible = "nxp,pca9541";
333                 reg = <0x70>;
335                 i2c-arb {
336                         #address-cells = <1>;
337                         #size-cells = <0>;
339                         hotswap@54 {
340                                 compatible = "ti,lm5066i";
341                                 reg = <0x54>;
342                         };
343                 };
345         };
347         vrm@64 {
348                 compatible = "isil,isl68137";
349                 reg = <0x64>;
350         };
352         vrm@40 {
353                 compatible = "isil,isl68137";
354                 reg = <0x40>;
355         };
357         vrm@60 {
358                 compatible = "isil,isl68137";
359                 reg = <0x60>;
360         };
362         vrm@43 {
363                 compatible = "infineon,ir38064";
364                 reg = <0x43>;
365         };
367         vrm@41 {
368                 compatible = "isil,isl68137";
369                 reg = <0x41>;
370         };
372         /* Master selector PCA9541A @70h (other master: CPU0)
373          *   LM5066I PMBUS @10h
374          */
376         /*
377          * Brick will be one of these types/addresses.  Depending
378          * on the board SKU only one is actually present and will successfully
379          * instantiate while the others will fail the probe operation.
380          * These are the PVT (and presumably beyond) addresses:
381          *    12V Quarter Brick DC/DC Converter Q54SJ12050 @6Ah
382          *    12V Quarter Brick DC/DC Converter Q54SH12050 @30h
383          */
384         power-brick@6a {
385                 compatible = "delta,dps800";
386                 reg = <0x6a>;
387         };
388         power-brick@30 {
389                 compatible = "delta,dps800";
390                 reg = <0x30>;
391         };
393         /* CPU0 VR ISL68137 0.7V, 0.96V PMBUS @64h */
394         /* CPU0 VR ISL68137 1.2V CH03 PMBUS @40h */
395         /* CPU0 VR ISL68137 0.8V PMBUS @60h */
396         /* CPU0 VR 1.0V IR38064 I2C @11h, PMBUS @43h */
397         /* CPU0 VR ISL68137 1.2V CH47 PMBUS @41h */
398         /* Master selector PCA9541A @70h (other master: CPU0)
399          *   LM5066I PMBUS @10h
400          */
403 &i2c8 {
404         status = "okay";
406         vrm@64 {
407                 compatible = "isil,isl68137";
408                 reg = <0x64>;
409         };
411         vrm@40 {
412                 compatible = "isil,isl68137";
413                 reg = <0x40>;
414         };
416         vrm@41 {
417                 compatible = "isil,isl68137";
418                 reg = <0x41>;
419         };
421         vrm@42 {
422                 compatible = "infineon,ir38064";
423                 reg = <0x42>;
424         };
426         vrm@60 {
427                 compatible = "isil,isl68137";
428                 reg = <0x60>;
429         };
431         /* CPU1 VR ISL68137 0.7V, 0.96V PMBUS @64h */
432         /* CPU1 VR ISL68137 1.2V CH03 PMBUS @40h */
433         /* CPU1 VR ISL68137 1.2V CH47 PMBUS @41h */
434         /* CPU1 VR 1.0V IR38064 I2C @12h, PMBUS @42h */
435         /* CPU1 VR ISL68137 0.8V PMBUS @60h */
439 &i2c9 {
440         status = "disabled";
442         /* Fan board */
445 &i2c10 {
446         status = "disabled";
449 &i2c11 {
450         status = "disabled";
452         /* GPU sideband */
455 &i2c12 {
456         status = "disabled";
459 &i2c13 {
460         status = "disabled";
462         /* MUX PI3USB102
463          *   CPU0 debug
464          *   CPU1 debug
465          */
468 &pinctrl {
469         aspeed,external-nodes = <&gfx &lhc>;
471         pinctrl_gpioh_unbiased: gpioi_unbiased {
472                 pins = "A8", "C7", "B7", "A7", "D7", "B6", "A6", "E7";
473                 bias-disable;
474         };
477 &gpio {
478         pinctrl-names = "default";
479         pinctrl-0 = <&pinctrl_gpioh_unbiased>;
481         line_iso_u146_en {
482                 gpio-hog;
483                 gpios = <ASPEED_GPIO(O, 4) GPIO_ACTIVE_HIGH>;
484                 output-high;
485                 line-name = "iso_u164_en";
486         };
488         ncsi_mux_en_n {
489                 gpio-hog;
490                 gpios = <ASPEED_GPIO(P, 0) GPIO_ACTIVE_HIGH>;
491                 output-low;
492                 line-name = "ncsi_mux_en_n";
493         };
495         line_bmc_i2c2_sw_rst_n {
496                 gpio-hog;
497                 gpios = <ASPEED_GPIO(P, 1) GPIO_ACTIVE_HIGH>;
498                 output-high;
499                 line-name = "bmc_i2c2_sw_rst_n";
500         };
502         line_bmc_i2c5_sw_rst_n {
503                 gpio-hog;
504                 gpios = <ASPEED_GPIO(P, 3) GPIO_ACTIVE_HIGH>;
505                 output-high;
506                 line-name = "bmc_i2c5_sw_rst_n";
507         };
510 &vuart {
511         status = "okay";
514 &gfx {
515         status = "okay";
518 &pwm_tacho {
519         status = "okay";
520         pinctrl-names = "default";
521         pinctrl-0 = <&pinctrl_pwm0_default &pinctrl_pwm1_default
522                 &pinctrl_pwm2_default &pinctrl_pwm3_default>;
524         fan@0 {
525                 reg = <0x00>;
526                 aspeed,fan-tach-ch = /bits/ 8 <0x00>;
527         };
529         fan@1 {
530                 reg = <0x01>;
531                 aspeed,fan-tach-ch = /bits/ 8 <0x01>;
532         };
534         fan@2 {
535                 reg = <0x02>;
536                 aspeed,fan-tach-ch = /bits/ 8 <0x02>;
537         };
539         fan@3 {
540                 reg = <0x03>;
541                 aspeed,fan-tach-ch = /bits/ 8 <0x03>;
542         };
545 &ibt {
546         status = "okay";
549 #include "ibm-power9-dual.dtsi"