1// SPDX-License-Identifier: GPL-2.0 2/dts-v1/; 3#include "aspeed-g5.dtsi" 4#include <dt-bindings/gpio/aspeed-gpio.h> 5 6/ { 7 model = "Zaius BMC"; 8 compatible = "ingrasys,zaius-bmc", "aspeed,ast2500"; 9 10 aliases { 11 i2c15 = &i2cpcie0; 12 i2c16 = &i2cpcie1; 13 i2c17 = &i2cpcie2; 14 i2c19 = &i2cpcie3; 15 i2c20 = &i2cpcie4; 16 }; 17 18 chosen { 19 stdout-path = &uart5; 20 bootargs = "console=ttyS4,115200 earlycon"; 21 }; 22 23 memory@80000000 { 24 reg = <0x80000000 0x40000000>; 25 }; 26 27 reserved-memory { 28 #address-cells = <1>; 29 #size-cells = <1>; 30 ranges; 31 32 flash_memory: region@98000000 { 33 no-map; 34 reg = <0x98000000 0x04000000>; /* 64M */ 35 }; 36 }; 37 38 onewire0 { 39 compatible = "w1-gpio"; 40 gpios = <&gpio ASPEED_GPIO(H, 0) GPIO_ACTIVE_HIGH>; 41 }; 42 43 onewire1 { 44 compatible = "w1-gpio"; 45 gpios = <&gpio ASPEED_GPIO(H, 1) GPIO_ACTIVE_HIGH>; 46 }; 47 48 onewire2 { 49 compatible = "w1-gpio"; 50 gpios = <&gpio ASPEED_GPIO(H, 2) GPIO_ACTIVE_HIGH>; 51 }; 52 53 onewire3 { 54 compatible = "w1-gpio"; 55 gpios = <&gpio ASPEED_GPIO(H, 3) GPIO_ACTIVE_HIGH>; 56 }; 57 58 gpio-keys { 59 compatible = "gpio-keys"; 60 61 checkstop { 62 label = "checkstop"; 63 gpios = <&gpio ASPEED_GPIO(F, 7) GPIO_ACTIVE_LOW>; 64 linux,code = <ASPEED_GPIO(F, 7)>; 65 }; 66 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 }; 73 74 leds { 75 compatible = "gpio-leds"; 76 77 sys_boot_status { 78 label = "System boot status"; 79 gpios = <&gpio ASPEED_GPIO(D, 5) GPIO_ACTIVE_LOW>; 80 }; 81 82 attention { 83 label = "Attention"; 84 gpios = <&gpio ASPEED_GPIO(D, 6) GPIO_ACTIVE_LOW>; 85 }; 86 87 plt_fault { 88 label = "Platform fault"; 89 gpios = <&gpio ASPEED_GPIO(D, 7) GPIO_ACTIVE_LOW>; 90 }; 91 92 hdd_fault { 93 label = "Onboard drive fault"; 94 gpios = <&gpio ASPEED_GPIO(AA, 2) GPIO_ACTIVE_LOW>; 95 }; 96 }; 97 98 fsi: gpio-fsi { 99 compatible = "fsi-master-gpio", "fsi-master"; 100 #address-cells = <2>; 101 #size-cells = <0>; 102 no-gpio-delays; 103 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 }; 110 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 }; 118 119 iio-hwmon-battery { 120 compatible = "iio-hwmon"; 121 io-channels = <&adc 12>; 122 }; 123 124}; 125 126&fmc { 127 status = "okay"; 128 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 }; 136}; 137 138&spi1 { 139 status = "okay"; 140 pinctrl-names = "default"; 141 pinctrl-0 = <&pinctrl_spi1_default>; 142 143 flash@0 { 144 status = "okay"; 145 label = "pnor"; 146 m25p,fast-read; 147 spi-max-frequency = <100000000>; 148 }; 149}; 150 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>; 159 160 flash@0 { 161 status = "okay"; 162 }; 163}; 164 165&uart1 { 166 status = "okay"; 167 pinctrl-names = "default"; 168 pinctrl-0 = <&pinctrl_txd1_default 169 &pinctrl_rxd1_default>; 170}; 171 172&lpc_ctrl { 173 status = "okay"; 174 memory-region = <&flash_memory>; 175 flash = <&spi1>; 176}; 177 178&lpc_snoop { 179 status = "okay"; 180 snoop-ports = <0x80>; 181}; 182 183 184&uart5 { 185 status = "okay"; 186}; 187 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; 196}; 197 198&mac1 { 199 status = "okay"; 200 201 pinctrl-names = "default"; 202 pinctrl-0 = <&pinctrl_rgmii2_default &pinctrl_mdio2_default>; 203}; 204 205&i2c0 { 206 status = "okay"; 207 208 eeprom@50 { 209 compatible = "atmel,24c64"; 210 reg = <0x50>; 211 pagesize = <32>; 212 }; 213 214 rtc@68 { 215 compatible = "nxp,pcf8523"; 216 reg = <0x68>; 217 }; 218 219 ucd90160@64 { 220 compatible = "ti,ucd90160"; 221 reg = <0x64>; 222 }; 223 224 /* Power sequencer UCD90160 PMBUS @64h 225 * FRU AT24C64D @50h 226 * RTC PCF8523 @68h 227 * Clock buffer 9DBL04 @6dh 228 */ 229}; 230 231&i2c1 { 232 status = "okay"; 233 234 i2c-switch@71 { 235 compatible = "nxp,pca9546"; 236 reg = <0x71>; 237 #address-cells = <1>; 238 #size-cells = <0>; 239 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 }; 261 262 /* MUX1 PCA9546A @71h 263 * PCIe 0 264 * PCIe 1 265 * PCIe 2 266 * TPM header 267 */ 268}; 269 270&i2c2 { 271 status = "disabled"; 272 273 /* OCP Mezz Connector A (OOB SMBUS) */ 274}; 275 276&i2c3 { 277 status = "disabled"; 278 279 /* OCP Mezz Connector A (PCIe slot SMBUS) */ 280}; 281 282&i2c4 { 283 status = "okay"; 284 285 i2c-switch@71 { 286 compatible = "nxp,pca9546"; 287 reg = <0x71>; 288 #address-cells = <1>; 289 #size-cells = <0>; 290 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 }; 302 303 /* MUX1 PCA9546A @71h 304 * PCIe 3 305 * PCIe 4 306 */ 307}; 308 309 310&i2c5 { 311 status = "disabled"; 312 313 /* CPU0 PRM 0.7V */ 314 /* CPU0 PRM 1.2V CH03 */ 315 /* CPU0 PRM 0.8V */ 316 /* CPU0 PRM 1.2V CH47 */ 317}; 318 319&i2c6 { 320 status = "disabled"; 321 322 /* CPU1 PRM 0.7V */ 323 /* CPU1 PRM 1.2V CH03 */ 324 /* CPU1 PRM 0.8V */ 325 /* CPU1 PRM 1.2V CH47 */ 326}; 327 328&i2c7 { 329 status = "okay"; 330 331 pca9541a@70 { 332 compatible = "nxp,pca9541"; 333 reg = <0x70>; 334 335 i2c-arb { 336 #address-cells = <1>; 337 #size-cells = <0>; 338 339 hotswap@54 { 340 compatible = "ti,lm5066i"; 341 reg = <0x54>; 342 }; 343 }; 344 345 }; 346 347 vrm@64 { 348 compatible = "isil,isl68137"; 349 reg = <0x64>; 350 }; 351 352 vrm@40 { 353 compatible = "isil,isl68137"; 354 reg = <0x40>; 355 }; 356 357 vrm@60 { 358 compatible = "isil,isl68137"; 359 reg = <0x60>; 360 }; 361 362 vrm@43 { 363 compatible = "infineon,ir38064"; 364 reg = <0x43>; 365 }; 366 367 vrm@41 { 368 compatible = "isil,isl68137"; 369 reg = <0x41>; 370 }; 371 372 /* Master selector PCA9541A @70h (other master: CPU0) 373 * LM5066I PMBUS @10h 374 */ 375 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 }; 392 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 */ 401}; 402 403&i2c8 { 404 status = "okay"; 405 406 vrm@64 { 407 compatible = "isil,isl68137"; 408 reg = <0x64>; 409 }; 410 411 vrm@40 { 412 compatible = "isil,isl68137"; 413 reg = <0x40>; 414 }; 415 416 vrm@41 { 417 compatible = "isil,isl68137"; 418 reg = <0x41>; 419 }; 420 421 vrm@42 { 422 compatible = "infineon,ir38064"; 423 reg = <0x42>; 424 }; 425 426 vrm@60 { 427 compatible = "isil,isl68137"; 428 reg = <0x60>; 429 }; 430 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 */ 436}; 437 438 439&i2c9 { 440 status = "disabled"; 441 442 /* Fan board */ 443}; 444 445&i2c10 { 446 status = "disabled"; 447}; 448 449&i2c11 { 450 status = "disabled"; 451 452 /* GPU sideband */ 453}; 454 455&i2c12 { 456 status = "disabled"; 457}; 458 459&i2c13 { 460 status = "disabled"; 461 462 /* MUX PI3USB102 463 * CPU0 debug 464 * CPU1 debug 465 */ 466}; 467 468&pinctrl { 469 aspeed,external-nodes = <&gfx &lhc>; 470 471 pinctrl_gpioh_unbiased: gpioi_unbiased { 472 pins = "A8", "C7", "B7", "A7", "D7", "B6", "A6", "E7"; 473 bias-disable; 474 }; 475}; 476 477&gpio { 478 pinctrl-names = "default"; 479 pinctrl-0 = <&pinctrl_gpioh_unbiased>; 480 481 gpio-line-names = 482 /*A0-A7*/ "","cfam-reset","","","","","","", 483 /*B0-B7*/ "","","","","","","","", 484 /*C0-C7*/ "","","","","","","","", 485 /*D0-D7*/ "fsi-enable","","","","","led-sys-boot-status","led-attention", 486 "led-fault", 487 /*E0-E7*/ "","","","","","","","presence-pcie-e2b", 488 /*F0-F7*/ "","","","","","","","checkstop", 489 /*G0-G7*/ "fsi-clock","fsi-data","","","","","","", 490 /*H0-H7*/ "onewire0","onewire1","onewire2","onewire3","","","","", 491 /*I0-I7*/ "","","","power-button","","","","", 492 /*J0-J7*/ "","","","","","","","", 493 /*K0-K7*/ "","","","","","","","", 494 /*L0-L7*/ "","","","","","","","", 495 /*M0-M7*/ "","","","","","","","", 496 /*N0-N7*/ "","","","","","","","", 497 /*O0-O7*/ "","","","","iso_u164_en","","fsi-trans","", 498 /*P0-P7*/ "ncsi_mux_en_n","bmc_i2c2_sw_rst_n","","bmc_i2c5_sw_rst_n","", 499 "","fsi-mux","", 500 /*Q0-Q7*/ "","","","","","","","", 501 /*R0-R7*/ "","","","","","","","", 502 /*S0-S7*/ "","","","","","","","", 503 /*T0-T7*/ "","","","","","","","", 504 /*U0-U7*/ "","","","","","","","", 505 /*V0-V7*/ "","","","","","","","", 506 /*W0-W7*/ "","","","","","","","", 507 /*X0-X7*/ "","","","","","","","", 508 /*Y0-Y7*/ "","","","","","","","", 509 /*Z0-Z7*/ "","","","","","","","", 510 /*AA0-AA7*/ "","","led-hdd-fault","","","","","", 511 /*AB0-AB7*/ "","","","","","","","", 512 /*AC0-AC7*/ "","","","","","","",""; 513 514 line_iso_u146_en { 515 gpio-hog; 516 gpios = <ASPEED_GPIO(O, 4) GPIO_ACTIVE_HIGH>; 517 output-high; 518 }; 519 520 ncsi_mux_en_n { 521 gpio-hog; 522 gpios = <ASPEED_GPIO(P, 0) GPIO_ACTIVE_HIGH>; 523 output-low; 524 }; 525 526 line_bmc_i2c2_sw_rst_n { 527 gpio-hog; 528 gpios = <ASPEED_GPIO(P, 1) GPIO_ACTIVE_HIGH>; 529 output-high; 530 }; 531 532 line_bmc_i2c5_sw_rst_n { 533 gpio-hog; 534 gpios = <ASPEED_GPIO(P, 3) GPIO_ACTIVE_HIGH>; 535 output-high; 536 }; 537}; 538 539&vuart { 540 status = "okay"; 541}; 542 543&gfx { 544 status = "okay"; 545}; 546 547&pwm_tacho { 548 status = "okay"; 549 pinctrl-names = "default"; 550 pinctrl-0 = <&pinctrl_pwm0_default &pinctrl_pwm1_default 551 &pinctrl_pwm2_default &pinctrl_pwm3_default>; 552 553 fan@0 { 554 reg = <0x00>; 555 aspeed,fan-tach-ch = /bits/ 8 <0x00>; 556 }; 557 558 fan@1 { 559 reg = <0x01>; 560 aspeed,fan-tach-ch = /bits/ 8 <0x01>; 561 }; 562 563 fan@2 { 564 reg = <0x02>; 565 aspeed,fan-tach-ch = /bits/ 8 <0x02>; 566 }; 567 568 fan@3 { 569 reg = <0x03>; 570 aspeed,fan-tach-ch = /bits/ 8 <0x03>; 571 }; 572}; 573 574&ibt { 575 status = "okay"; 576}; 577 578#include "ibm-power9-dual.dtsi" 579