239566b032
Most of the aspeed boards have copied the 'earlyprink' string in the bootargs. However, there's no earlyprink driver configured in the defconfigs, so this does nothing. A combination of setting stdout in the chosen node and adding earlycon to bootargs causes early serial output to appear early. This changes all boards to use this option. The console=ttyS4,115200 option is still required, as this is used by the run time uart driver. Signed-off-by: Joel Stanley <joel@jms.id.au> Acked-by: Andrew Jeffery <andrew@aj.id.au> Acked-by: Alexander Filippov <a.filippov@yadro.com> Link: https://lore.kernel.org/r/20210526051220.136432-1-joel@jms.id.au Signed-off-by: Joel Stanley <joel@jms.id.au>
550 lines
9.9 KiB
Plaintext
550 lines
9.9 KiB
Plaintext
// SPDX-License-Identifier: GPL-2.0+
|
|
// Copyright (c) 2018 Facebook Inc.
|
|
// Author: Vijay Khemka <vijaykhemka@fb.com>
|
|
/dts-v1/;
|
|
|
|
#include "aspeed-g5.dtsi"
|
|
#include <dt-bindings/gpio/aspeed-gpio.h>
|
|
#include <dt-bindings/i2c/i2c.h>
|
|
|
|
/ {
|
|
model = "Facebook TiogaPass BMC";
|
|
compatible = "facebook,tiogapass-bmc", "aspeed,ast2500";
|
|
aliases {
|
|
serial0 = &uart1;
|
|
serial4 = &uart5;
|
|
|
|
/*
|
|
* Hardcode the bus number of i2c switches' channels to
|
|
* avoid breaking the legacy applications.
|
|
*/
|
|
i2c16 = &imux16;
|
|
i2c17 = &imux17;
|
|
i2c18 = &imux18;
|
|
i2c19 = &imux19;
|
|
i2c20 = &imux20;
|
|
i2c21 = &imux21;
|
|
i2c22 = &imux22;
|
|
i2c23 = &imux23;
|
|
i2c24 = &imux24;
|
|
i2c25 = &imux25;
|
|
i2c26 = &imux26;
|
|
i2c27 = &imux27;
|
|
i2c28 = &imux28;
|
|
i2c29 = &imux29;
|
|
i2c30 = &imux30;
|
|
i2c31 = &imux31;
|
|
};
|
|
chosen {
|
|
stdout-path = &uart5;
|
|
bootargs = "console=ttyS4,115200 earlycon";
|
|
};
|
|
|
|
memory@80000000 {
|
|
reg = <0x80000000 0x20000000>;
|
|
};
|
|
|
|
iio-hwmon {
|
|
compatible = "iio-hwmon";
|
|
io-channels = <&adc 0>, <&adc 1>, <&adc 2>, <&adc 3>,
|
|
<&adc 4>, <&adc 5>, <&adc 6>, <&adc 7>;
|
|
};
|
|
|
|
};
|
|
|
|
&fmc {
|
|
status = "okay";
|
|
flash@0 {
|
|
status = "okay";
|
|
m25p,fast-read;
|
|
#include "openbmc-flash-layout.dtsi"
|
|
};
|
|
};
|
|
|
|
&spi1 {
|
|
status = "okay";
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_spi1_default>;
|
|
flash@0 {
|
|
status = "okay";
|
|
m25p,fast-read;
|
|
label = "pnor";
|
|
};
|
|
};
|
|
|
|
&lpc_snoop {
|
|
status = "okay";
|
|
snoop-ports = <0x80>;
|
|
};
|
|
|
|
&lpc_ctrl {
|
|
// Enable lpc clock
|
|
status = "okay";
|
|
};
|
|
|
|
&uart1 {
|
|
// Host Console
|
|
status = "okay";
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_txd1_default
|
|
&pinctrl_rxd1_default>;
|
|
};
|
|
|
|
&uart2 {
|
|
// SoL Host Console
|
|
status = "okay";
|
|
};
|
|
|
|
&uart3 {
|
|
// SoL BMC Console
|
|
status = "okay";
|
|
};
|
|
|
|
&uart5 {
|
|
// BMC Console
|
|
status = "okay";
|
|
};
|
|
|
|
&kcs2 {
|
|
// BMC KCS channel 2
|
|
status = "okay";
|
|
aspeed,lpc-io-reg = <0xca8>;
|
|
};
|
|
|
|
&kcs3 {
|
|
// BMC KCS channel 3
|
|
status = "okay";
|
|
aspeed,lpc-io-reg = <0xca2>;
|
|
};
|
|
|
|
&gpio {
|
|
status = "okay";
|
|
gpio-line-names =
|
|
/*A0-A7*/ "BMC_CPLD_FPGA_SEL","","","","","","","",
|
|
/*B0-B7*/ "","BMC_DEBUG_EN","","","","BMC_PPIN","PS_PWROK",
|
|
"IRQ_PVDDQ_GHJ_VRHOT_LVT3",
|
|
/*C0-C7*/ "","","","","","","","",
|
|
/*D0-D7*/ "BIOS_MRC_DEBUG_MSG_DIS","BOARD_REV_ID0","",
|
|
"BOARD_REV_ID1","IRQ_DIMM_SAVE_LVT3","BOARD_REV_ID2",
|
|
"CPU_ERR0_LVT3_BMC","CPU_ERR1_LVT3_BMC",
|
|
/*E0-E7*/ "RESET_BUTTON","RESET_OUT","POWER_BUTTON",
|
|
"POWER_OUT","NMI_BUTTON","","CPU0_PROCHOT_LVT3_ BMC",
|
|
"CPU1_PROCHOT_LVT3_ BMC",
|
|
/*F0-F7*/ "IRQ_PVDDQ_ABC_VRHOT_LVT3","",
|
|
"IRQ_PVCCIN_CPU0_VRHOT_LVC3",
|
|
"IRQ_PVCCIN_CPU1_VRHOT_LVC3",
|
|
"IRQ_PVDDQ_KLM_VRHOT_LVT3","","P3VBAT_BRIDGE_EN","",
|
|
/*G0-G7*/ "CPU_ERR2_LVT3","CPU_CATERR_LVT3","PCH_BMC_THERMTRIP",
|
|
"CPU0_SKTOCC_LVT3","","","","BIOS_SMI_ACTIVE",
|
|
/*H0-H7*/ "LED_POST_CODE_0","LED_POST_CODE_1","LED_POST_CODE_2",
|
|
"LED_POST_CODE_3","LED_POST_CODE_4","LED_POST_CODE_5",
|
|
"LED_POST_CODE_6","LED_POST_CODE_7",
|
|
/*I0-I7*/ "CPU0_FIVR_FAULT_LVT3","CPU1_FIVR_FAULT_LVT3",
|
|
"FORCE_ADR","UV_ADR_TRIGGER_EN","","","","",
|
|
/*J0-J7*/ "","","","","","","","",
|
|
/*K0-K7*/ "","","","","","","","",
|
|
/*L0-L7*/ "IRQ_UV_DETECT","IRQ_OC_DETECT","HSC_TIMER_EXP","",
|
|
"MEM_THERM_EVENT_PCH","PMBUS_ALERT_BUF_EN","","",
|
|
/*M0-M7*/ "CPU0_RC_ERROR","CPU1_RC_ERROR","","OC_DETECT_EN",
|
|
"CPU0_THERMTRIP_LATCH_LVT3",
|
|
"CPU1_THERMTRIP_LATCH_LVT3","","",
|
|
/*N0-N7*/ "","","","CPU_MSMI_LVT3","","BIOS_SPI_BMC_CTRL","","",
|
|
/*O0-O7*/ "","","","","","","","",
|
|
/*P0-P7*/ "BOARD_SKU_ID0","BOARD_SKU_ID1","BOARD_SKU_ID2",
|
|
"BOARD_SKU_ID3","BOARD_SKU_ID4","BMC_PREQ",
|
|
"BMC_PWR_DEBUG","RST_RSMRST",
|
|
/*Q0-Q7*/ "","","","","UARTSW_LSB","UARTSW_MSB",
|
|
"POST_CARD_PRES_BMC","PE_BMC_WAKE",
|
|
/*R0-R7*/ "","","BMC_TCK_MUX_SEL","BMC_PRDY",
|
|
"BMC_XDP_PRSNT_IN","RST_BMC_PLTRST_BUF","SLT_CFG0",
|
|
"SLT_CFG1",
|
|
/*S0-S7*/ "THROTTLE","BMC_READY","","HSC_SMBUS_SWITCH_EN","",
|
|
"","","",
|
|
/*T0-T7*/ "","","","","","","","",
|
|
/*U0-U7*/ "","","","","","BMC_FAULT","","",
|
|
/*V0-V7*/ "","","","FAST_PROCHOT_EN","","","","",
|
|
/*W0-W7*/ "","","","","","","","",
|
|
/*X0-X7*/ "","","","GLOBAL_RST_WARN",
|
|
"CPU0_MEMABC_MEMHOT_LVT3_BMC",
|
|
"CPU0_MEMDEF_MEMHOT_LVT3_BMC",
|
|
"CPU1_MEMGHJ_MEMHOT_LVT3_BMC",
|
|
"CPU1_MEMKLM_MEMHOT_LVT3_BMC",
|
|
/*Y0-Y7*/ "SIO_S3","SIO_S5","BMC_JTAG_SEL","SIO_ONCONTROL","",
|
|
"","","",
|
|
/*Z0-Z7*/ "","SIO_POWER_GOOD","IRQ_PVDDQ_DEF_VRHOT_LVT3","",
|
|
"","","","",
|
|
/*AA0-AA7*/ "CPU1_SKTOCC_LVT3","IRQ_SML1_PMBUS_ALERT",
|
|
"SERVER_POWER_LED","","PECI_MUX_SELECT","UV_HIGH_SET",
|
|
"","POST_COMPLETE",
|
|
/*AB0-AB7*/ "IRQ_HSC_FAULT","OCP_MEZZA_PRES","","","","","","",
|
|
/*AC0-AC7*/ "","","","","","","","";
|
|
};
|
|
|
|
&mac0 {
|
|
status = "okay";
|
|
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_rmii1_default>;
|
|
clocks = <&syscon ASPEED_CLK_GATE_MAC1CLK>,
|
|
<&syscon ASPEED_CLK_MAC1RCLK>;
|
|
clock-names = "MACCLK", "RCLK";
|
|
use-ncsi;
|
|
};
|
|
|
|
&mac1 {
|
|
status = "okay";
|
|
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_rmii2_default>;
|
|
use-ncsi;
|
|
};
|
|
|
|
&adc {
|
|
status = "okay";
|
|
};
|
|
|
|
&i2c0 {
|
|
status = "okay";
|
|
//Airmax Conn B, CPU0 PIROM, CPU1 PIROM
|
|
};
|
|
|
|
&i2c1 {
|
|
status = "okay";
|
|
//X24 Riser
|
|
i2c-switch@71 {
|
|
compatible = "nxp,pca9544";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x71>;
|
|
|
|
imux16: i2c@0 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0>;
|
|
|
|
ina230@45 {
|
|
compatible = "ti,ina230";
|
|
reg = <0x45>;
|
|
};
|
|
|
|
tmp75@48 {
|
|
compatible = "ti,tmp75";
|
|
reg = <0x48>;
|
|
};
|
|
|
|
tmp421@49 {
|
|
compatible = "ti,tmp75";
|
|
reg = <0x49>;
|
|
};
|
|
|
|
eeprom@50 {
|
|
compatible = "atmel,24c64";
|
|
reg = <0x50>;
|
|
pagesize = <32>;
|
|
};
|
|
|
|
i2c-switch@73 {
|
|
compatible = "nxp,pca9546";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x73>;
|
|
|
|
imux20: i2c@0 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0>;
|
|
};
|
|
|
|
imux21: i2c@1 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <1>;
|
|
};
|
|
|
|
imux22: i2c@2 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <2>;
|
|
};
|
|
|
|
imux23: i2c@3 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <3>;
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
imux17: i2c@1 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <1>;
|
|
|
|
ina230@45 {
|
|
compatible = "ti,ina230";
|
|
reg = <0x45>;
|
|
};
|
|
|
|
tmp421@48 {
|
|
compatible = "ti,tmp75";
|
|
reg = <0x48>;
|
|
};
|
|
|
|
tmp421@49 {
|
|
compatible = "ti,tmp75";
|
|
reg = <0x49>;
|
|
};
|
|
|
|
eeprom@50 {
|
|
compatible = "atmel,24c64";
|
|
reg = <0x50>;
|
|
pagesize = <32>;
|
|
};
|
|
|
|
i2c-switch@73 {
|
|
compatible = "nxp,pca9546";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x73>;
|
|
|
|
imux24: i2c@0 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0>;
|
|
};
|
|
|
|
imux25: i2c@1 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <1>;
|
|
};
|
|
|
|
imux26: i2c@2 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <2>;
|
|
};
|
|
|
|
imux27: i2c@3 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <3>;
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
imux18: i2c@2 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <2>;
|
|
|
|
ina230@45 {
|
|
compatible = "ti,ina230";
|
|
reg = <0x45>;
|
|
};
|
|
|
|
tmp421@48 {
|
|
compatible = "ti,tmp75";
|
|
reg = <0x48>;
|
|
};
|
|
|
|
tmp421@49 {
|
|
compatible = "ti,tmp75";
|
|
reg = <0x49>;
|
|
};
|
|
|
|
eeprom@50 {
|
|
compatible = "atmel,24c64";
|
|
reg = <0x50>;
|
|
pagesize = <32>;
|
|
};
|
|
|
|
i2c-switch@73 {
|
|
compatible = "nxp,pca9546";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x73>;
|
|
|
|
imux28: i2c@0 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0>;
|
|
};
|
|
|
|
imux29: i2c@1 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <1>;
|
|
};
|
|
|
|
imux30: i2c@2 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <2>;
|
|
};
|
|
|
|
imux31: i2c@3 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <3>;
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
imux19: i2c@3 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <3>;
|
|
|
|
i2c-switch@40 {
|
|
compatible = "ti,ina230";
|
|
reg = <0x40>;
|
|
};
|
|
|
|
i2c-switch@41 {
|
|
compatible = "ti,ina230";
|
|
reg = <0x41>;
|
|
};
|
|
|
|
i2c-switch@45 {
|
|
compatible = "ti,ina230";
|
|
reg = <0x45>;
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
};
|
|
|
|
&i2c2 {
|
|
status = "okay";
|
|
// Mezz Management SMBus
|
|
};
|
|
|
|
&i2c3 {
|
|
status = "okay";
|
|
// SMBus to Board ID EEPROM
|
|
};
|
|
|
|
&i2c4 {
|
|
status = "okay";
|
|
// BMC Debug Header
|
|
ipmb0@10 {
|
|
compatible = "ipmb-dev";
|
|
reg = <(0x10 | I2C_OWN_SLAVE_ADDRESS)>;
|
|
i2c-protocol;
|
|
};
|
|
};
|
|
|
|
&i2c5 {
|
|
status = "okay";
|
|
// CPU Voltage regulators
|
|
regulator@48 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x48>;
|
|
};
|
|
regulator@4a {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x4a>;
|
|
};
|
|
regulator@50 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x50>;
|
|
};
|
|
regulator@52 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x52>;
|
|
};
|
|
regulator@58 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x58>;
|
|
};
|
|
regulator@5a {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x5a>;
|
|
};
|
|
regulator@68 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x68>;
|
|
};
|
|
regulator@70 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x70>;
|
|
};
|
|
regulator@72 {
|
|
compatible = "infineon,pxe1610";
|
|
reg = <0x72>;
|
|
};
|
|
};
|
|
|
|
&i2c6 {
|
|
status = "okay";
|
|
tpm@20 {
|
|
compatible = "infineon,slb9645tt";
|
|
reg = <0x20>;
|
|
};
|
|
tmp421@4e {
|
|
compatible = "ti,tmp421";
|
|
reg = <0x4e>;
|
|
};
|
|
tmp421@4f {
|
|
compatible = "ti,tmp421";
|
|
reg = <0x4f>;
|
|
};
|
|
eeprom@54 {
|
|
compatible = "atmel,24c64";
|
|
reg = <0x54>;
|
|
pagesize = <32>;
|
|
};
|
|
};
|
|
|
|
&i2c7 {
|
|
status = "okay";
|
|
//HSC, AirMax Conn A
|
|
adm1278@45 {
|
|
compatible = "adm1275";
|
|
reg = <0x45>;
|
|
shunt-resistor-micro-ohms = <250>;
|
|
};
|
|
};
|
|
|
|
&i2c8 {
|
|
status = "okay";
|
|
tmp421@1f {
|
|
compatible = "ti,tmp421";
|
|
reg = <0x1f>;
|
|
};
|
|
//Mezz Sensor SMBus
|
|
};
|
|
|
|
&i2c9 {
|
|
status = "okay";
|
|
//USB Debug Connector
|
|
ipmb0@10 {
|
|
compatible = "ipmb-dev";
|
|
reg = <(0x10 | I2C_OWN_SLAVE_ADDRESS)>;
|
|
i2c-protocol;
|
|
};
|
|
};
|
|
|
|
&pwm_tacho {
|
|
status = "okay";
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_pwm0_default &pinctrl_pwm1_default>;
|
|
fan@0 {
|
|
reg = <0x00>;
|
|
aspeed,fan-tach-ch = /bits/ 8 <0x00>;
|
|
};
|
|
|
|
fan@1 {
|
|
reg = <0x01>;
|
|
aspeed,fan-tach-ch = /bits/ 8 <0x02>;
|
|
};
|
|
};
|