]> git.ipfire.org Git - thirdparty/u-boot.git/blob - src/arm/aspeed/aspeed-bmc-tyan-s7106.dts
Squashed 'dts/upstream/' content from commit aaba2d45dc2a
[thirdparty/u-boot.git] / src / arm / aspeed / aspeed-bmc-tyan-s7106.dts
1 // SPDX-License-Identifier: GPL-2.0+
2 /dts-v1/;
3
4 #include "aspeed-g5.dtsi"
5 #include <dt-bindings/gpio/aspeed-gpio.h>
6 #include <dt-bindings/interrupt-controller/irq.h>
7
8 / {
9 model = "Tyan S7106 BMC";
10 compatible = "tyan,s7106-bmc", "aspeed,ast2500";
11
12 chosen {
13 stdout-path = &uart5;
14 bootargs = "console=ttyS4,115200 earlycon";
15 };
16
17 memory@80000000 {
18 device_type = "memory";
19 reg = <0x80000000 0x20000000>;
20 };
21
22 reserved-memory {
23 #address-cells = <1>;
24 #size-cells = <1>;
25 ranges;
26
27 p2a_memory: region@987f0000 {
28 no-map;
29 reg = <0x987f0000 0x00010000>; /* 64KB */
30 };
31
32 vga_memory: framebuffer@9f000000 {
33 no-map;
34 reg = <0x9f000000 0x01000000>; /* 16M */
35 };
36
37 gfx_memory: framebuffer {
38 size = <0x01000000>; /* 16M */
39 alignment = <0x01000000>;
40 compatible = "shared-dma-pool";
41 reusable;
42 };
43 };
44
45 leds {
46 compatible = "gpio-leds";
47
48 identify {
49 gpios = <&gpio ASPEED_GPIO(A, 2) GPIO_ACTIVE_LOW>;
50 };
51
52 heartbeat {
53 gpios = <&gpio ASPEED_GPIO(E, 7) GPIO_ACTIVE_LOW>;
54 };
55 };
56
57 iio-hwmon {
58 compatible = "iio-hwmon";
59 io-channels = <&adc 0>, <&adc 1>, <&adc 2>, <&adc 3>,
60 <&adc 4>, <&adc 5>, <&adc 6>, <&adc 7>,
61 <&adc 8>, <&adc 9>, <&adc 10>, <&adc 11>,
62 <&adc 12>, <&adc 13>, <&adc 14>;
63 };
64
65 iio-hwmon-battery {
66 compatible = "iio-hwmon";
67 io-channels = <&adc 15>;
68 };
69 };
70
71 &fmc {
72 status = "okay";
73 flash@0 {
74 label = "bmc";
75 status = "okay";
76 m25p,fast-read;
77 #include "openbmc-flash-layout.dtsi"
78 };
79 };
80
81 &spi1 {
82 status = "okay";
83 pinctrl-names = "default";
84 pinctrl-0 = <&pinctrl_spi1_default>;
85
86 flash@0 {
87 status = "okay";
88 label = "pnor";
89 m25p,fast-read;
90 };
91 };
92
93 &uart1 {
94 /* Rear RS-232 connector */
95 status = "okay";
96 pinctrl-names = "default";
97 pinctrl-0 = <&pinctrl_txd1_default
98 &pinctrl_rxd1_default>;
99 };
100
101 &uart2 {
102 /* RS-232 connector on header */
103 status = "okay";
104 pinctrl-names = "default";
105 pinctrl-0 = <&pinctrl_txd2_default
106 &pinctrl_rxd2_default>;
107 };
108
109 &uart3 {
110 /* Alternative to vuart to internally connect (route) to uart1
111 * when vuart cannot be used due to BIOS limitations.
112 */
113 status = "okay";
114 };
115
116 &uart4 {
117 /* Alternative to vuart to internally connect (route) to the
118 * external port usually used by uart1 when vuart cannot be
119 * used due to BIOS limitations.
120 */
121 status = "okay";
122 };
123
124 &uart5 {
125 /* BMC "debug" (console) UART; connected to RS-232 connector
126 * on header; selectable via jumpers as alternative to uart2
127 */
128 status = "okay";
129 };
130
131 &uart_routing {
132 status = "okay";
133 };
134
135 &vuart {
136 status = "okay";
137
138 /* We enable the VUART here, but leave it in a state that does
139 * not interfere with the SuperIO. The goal is to have both the
140 * VUART and the SuperIO available and decide at runtime whether
141 * the VUART should actually be used. For that reason, configure
142 * an "invalid" IO address and an IRQ that is not used by the
143 * BMC.
144 */
145
146 aspeed,lpc-io-reg = <0xffff>;
147 aspeed,lpc-interrupts = <15 IRQ_TYPE_LEVEL_HIGH>;
148 };
149
150 &lpc_ctrl {
151 status = "okay";
152 };
153
154 &p2a {
155 status = "okay";
156 memory-region = <&p2a_memory>;
157 };
158
159 &lpc_snoop {
160 status = "okay";
161 snoop-ports = <0x80>;
162 };
163
164 &adc {
165 status = "okay";
166 };
167
168 &vhub {
169 status = "okay";
170 };
171
172 &pwm_tacho {
173 status = "okay";
174 pinctrl-names = "default";
175 pinctrl-0 = <&pinctrl_pwm0_default
176 &pinctrl_pwm1_default
177 &pinctrl_pwm3_default
178 &pinctrl_pwm4_default>;
179
180 /* CPU fan #0 */
181 fan@0 {
182 reg = <0x00>;
183 aspeed,fan-tach-ch = /bits/ 8 <0x00>;
184 };
185
186 /* CPU fan #1 */
187 fan@1 {
188 reg = <0x01>;
189 aspeed,fan-tach-ch = /bits/ 8 <0x01>;
190 };
191
192 /* PWM group for chassis fans #1, #2, #3 and #4 */
193 fan@2 {
194 reg = <0x03>;
195 aspeed,fan-tach-ch = /bits/ 8 <0x02>;
196 };
197
198 fan@3 {
199 reg = <0x03>;
200 aspeed,fan-tach-ch = /bits/ 8 <0x03>;
201 };
202
203 fan@4 {
204 reg = <0x03>;
205 aspeed,fan-tach-ch = /bits/ 8 <0x04>;
206 };
207
208 fan@5 {
209 reg = <0x03>;
210 aspeed,fan-tach-ch = /bits/ 8 <0x05>;
211 };
212
213 /* PWM group for chassis fans #5 and #6 */
214 fan@6 {
215 reg = <0x04>;
216 aspeed,fan-tach-ch = /bits/ 8 <0x06>;
217 };
218
219 fan@7 {
220 reg = <0x04>;
221 aspeed,fan-tach-ch = /bits/ 8 <0x07>;
222 };
223 };
224
225 &i2c0 {
226 status = "okay";
227
228 /* Hardware monitor with temperature sensors */
229 nct7802@28 {
230 compatible = "nuvoton,nct7802";
231 reg = <0x28>;
232
233 #address-cells = <1>;
234 #size-cells = <0>;
235
236 channel@0 { /* LTD */
237 reg = <0>;
238 };
239
240 channel@1 { /* RTD1 */
241 reg = <1>;
242 sensor-type = "temperature";
243 temperature-mode = "thermistor";
244 };
245
246 channel@2 { /* RTD2 */
247 reg = <2>;
248 sensor-type = "temperature";
249 temperature-mode = "thermistor";
250 };
251
252 channel@3 { /* RTD3 */
253 reg = <3>;
254 sensor-type = "temperature";
255 };
256 };
257
258 /* Also connected to:
259 * - IPMB pin header
260 * - CPU #0 memory error LED @ 0x3A
261 * - CPU #1 memory error LED @ 0x3C
262 */
263 };
264
265 &i2c1 {
266 /* Directly connected to PCH SMBUS #0 */
267 status = "okay";
268 };
269
270 &i2c2 {
271 status = "okay";
272
273 /* BMC EEPROM, incl. mainboard FRU */
274 eeprom@50 {
275 compatible = "atmel,24c256";
276 reg = <0x50>;
277 };
278
279 /* Also connected to:
280 * - fan header
281 * - mini-SAS HD connector
282 * - SSATA SGPIO
283 * - via switch (BMC_SMB3_PCH_IE_SML3_EN, active low)
284 * to PCH SMBUS #3
285 */
286 };
287
288 &i2c3 {
289 status = "okay";
290
291 /* PSU1 FRU @ 0xA0 */
292 eeprom@50 {
293 compatible = "atmel,24c02";
294 reg = <0x50>;
295 };
296
297 /* PSU2 FRU @ 0xA2 */
298 eeprom@51 {
299 compatible = "atmel,24c02";
300 reg = <0x51>;
301 };
302
303 /* PSU1 @ 0xB0 */
304 power-supply@58 {
305 compatible = "pmbus";
306 reg = <0x58>;
307 };
308
309 /* PSU2 @ 0xB2 */
310 power-supply@59 {
311 compatible = "pmbus";
312 reg = <0x59>;
313 };
314
315 /* Also connected to:
316 * - PCH SMBUS #1
317 */
318 };
319
320 &i2c4 {
321 status = "okay";
322
323 /* Connected to:
324 * - PCH SMBUS #2
325 */
326
327 /* Connected via switch to:
328 * - CPU #0 channels ABC VDDQ @ 0x80
329 * - CPU #0 channels DEF VDDQ @ 0x81
330 * - CPU #1 channels ABC VDDQ @ 0x82
331 * - CPU #1 channels DEF VDDQ @ 0x83
332 * - CPU #0 VCCIO & VMCP @ 0x52
333 * - CPU #1 VCCIO & VMCP @ 0x53
334 * - CPU #0 VCCIN @ 0xC0
335 * - CPU #0 VSA @ 0xC2
336 * - CPU #1 VCCIN @ 0xC4
337 * - CPU #1 VSA @ 0xC6
338 * - J110
339 */
340 };
341
342 &i2c5 {
343 status = "okay";
344
345 /* Connected via switch (PCH_BMC_SMB_SW_P) to:
346 * - mainboard FRU @ 0xAE
347 * - XDP connector
348 * - ME debug header
349 * - clock buffer @ 0xD8
350 * - i2c4 via switch (PCH_VR_SMBUS_SW_P; controlled by PCH)
351 * - PCH SMBUS
352 */
353 };
354
355 &i2c6 {
356 status = "okay";
357
358 /* Connected via switch (BMC_PE_SMB_EN_1_N) to
359 * bus mux (selector BMC_PE_SMB_SW_BIT[1..0]) to:
360 * - 0,0: PCIE slot 1, SMB #1
361 * - 0,1: PCIE slot 1, SMB #2
362 * - 1,0: PCIE slot 2, SMB #1
363 * - 1,1: PCIE slot 2, SMB #2
364 */
365
366 /* Connected via switch (BMC_PE_SMB_EN_2_N) to
367 * bus mux (selector BMC_PE_SMB_SW_BIT[1..0]) to:
368 * - 0,0: OCP0 (A) SMB
369 * - 0,1: OCP0 (C) SMB
370 * - 1,0: OCP1 (A) SMB
371 * - 1,1: NC
372 */
373 };
374
375 &i2c7 {
376 status = "okay";
377
378 /* Connected to:
379 * - PCH SMBUS #4
380 */
381 };
382
383 &i2c8 {
384 status = "okay";
385
386 /* Not connected */
387 };
388
389 &mac0 {
390 status = "okay";
391 use-ncsi;
392 pinctrl-names = "default";
393 pinctrl-0 = <&pinctrl_rmii1_default>;
394 };
395
396 &mac1 {
397 status = "okay";
398 pinctrl-names = "default";
399 pinctrl-0 = <&pinctrl_rgmii2_default &pinctrl_mdio2_default>;
400 };
401
402 &ibt {
403 status = "okay";
404 };
405
406 &kcs1 {
407 status = "okay";
408 aspeed,lpc-io-reg = <0xca8>;
409 };
410
411 &kcs3 {
412 status = "okay";
413 aspeed,lpc-io-reg = <0xca2>;
414 };
415
416 /* Enable BMC VGA output to show an early (pre-BIOS) boot screen */
417 &gfx {
418 status = "okay";
419 memory-region = <&gfx_memory>;
420 };
421
422 /* We're following the GPIO naming as defined at
423 * https://github.com/openbmc/docs/blob/master/designs/device-tree-gpio-naming.md.
424 *
425 * Notes on led-identify and id-button:
426 * - A physical button is connected to id-button which
427 * triggers the clock on a D flip-flop. The /Q output of the
428 * flip-flop drives its D input.
429 * - The flip-flop's Q output drives led-identify which is
430 * connected to LEDs.
431 * - With that, every button press toggles the LED between on and off.
432 *
433 * Notes on power-, reset- and nmi- button and control:
434 * - The -button signals can be used to monitor physical buttons.
435 * - The -control signals can be used to actuate the specific
436 * operation.
437 * - In hardware, the -button signals are connected to the -control
438 * signals through drivers with the -control signals being
439 * protected through diodes.
440 */
441 &gpio {
442 status = "okay";
443 gpio-line-names =
444 /*A0*/ "",
445 /*A1*/ "",
446 /*A2*/ "led-identify", /* in/out: BMC_IDLED_ON_N */
447 /*A3*/ "",
448 /*A4*/ "",
449 /*A5*/ "",
450 /*A6*/ "",
451 /*A7*/ "",
452 /*B0-B7*/ "","","","","","","","",
453 /*C0*/ "",
454 /*C1*/ "",
455 /*C2*/ "",
456 /*C3*/ "",
457 /*C4*/ "id-button", /* in/out: BMC_IDBTN_IN_OUT_N */
458 /*C5*/ "post-complete", /* in: FM_BIOS_POST_CMPLT_N */
459 /*C6*/ "",
460 /*C7*/ "",
461 /*D0*/ "",
462 /*D1*/ "",
463 /*D2*/ "power-chassis-good", /* in: SYS_PWROK_BUF */
464 /*D3*/ "platform-reset", /* in: SYS_PLTRST_N */
465 /*D4*/ "",
466 /*D5*/ "",
467 /*D6*/ "",
468 /*D7*/ "",
469 /*E0*/ "power-button", /* in: BMC_PWBTN_IN_N */
470 /*E1*/ "power-chassis-control", /* out: BMC_PWRBTN_OUT_N */
471 /*E2*/ "reset-button", /* in: BMC_RSTBTN_IN_N */
472 /*E3*/ "reset-control", /* out: BMC_RSTBTN_OUT_N */
473 /*E4*/ "nmi-button", /* in: BMC_NMIBTN_IN_N */
474 /*E5*/ "nmi-control", /* out: BMC_NMIBTN_OUT_N */
475 /*E6*/ "",
476 /*E7*/ "led-heartbeat", /* out: BMC_HEARTBRAT_LED_N */
477 /*F0*/ "",
478 /*F1*/ "clear-cmos-control", /* out: BMC_CLR_CMOS_N */
479 /*F2*/ "",
480 /*F3*/ "",
481 /*F4*/ "led-fault", /* out: AST_HW_FAULT_N */
482 /*F5*/ "",
483 /*F6*/ "",
484 /*F7*/ "",
485 /*G0*/ "BMC_PE_SMB_EN_1_N", /* out */
486 /*G1*/ "BMC_PE_SMB_EN_2_N", /* out */
487 /*G2*/ "",
488 /*G3*/ "",
489 /*G4*/ "",
490 /*G5*/ "",
491 /*G6*/ "",
492 /*G7*/ "",
493 /*H0-H7*/ "","","","","","","","",
494 /*I0-I7*/ "","","","","","","","",
495 /*J0-J7*/ "","","","","","","","",
496 /*K0-K7*/ "","","","","","","","",
497 /*L0-L7*/ "","","","","","","","",
498 /*M0-M7*/ "","","","","","","","",
499 /*N0-N7*/ "","","","","","","","",
500 /*O0-O7*/ "","","","","","","","",
501 /*P0-P7*/ "","","","","","","","",
502 /*Q0*/ "",
503 /*Q1*/ "",
504 /*Q2*/ "",
505 /*Q3*/ "",
506 /*Q4*/ "BMC_PE_SMB_SW_BIT0", /* out */
507 /*Q5*/ "BMC_PE_SMB_SW_BIT1", /* out */
508 /*Q6*/ "",
509 /*Q7*/ "",
510 /*R0-R7*/ "","","","","","","","",
511 /*S0-S7*/ "","","","","","","","",
512 /*T0-T7*/ "","","","","","","","",
513 /*U0-U7*/ "","","","","","","","",
514 /*V0-V7*/ "","","","","","","","",
515 /*W0-W7*/ "","","","","","","","",
516 /*X0-X7*/ "","","","","","","","",
517 /*Y0-Y7*/ "","","","","","","","",
518 /*Z0-Z7*/ "","","","","","","","",
519 /*AA0*/ "",
520 /*AA1*/ "",
521 /*AA2*/ "",
522 /*AA3*/ "BMC_SMB3_PCH_IE_SML3_EN", /* out */
523 /*AA4*/ "",
524 /*AA5*/ "",
525 /*AA6*/ "",
526 /*AA7*/ "",
527 /*AB0-AB7*/ "","","","","","","","";
528 };