-
Notifications
You must be signed in to change notification settings - Fork 19
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
mb/system76/rpl: Add bonw15-b variant
The Bonobo has been updated with a Thunderbolt 5 controller (Barlow Ridge). Identified chip changes from the schematics: - JHL8540_MP -> JHL9580_QS - TPS65994BF -> TPS65994BH - IT5570E-128 -> IT5570E-256 Change-Id: I784e489cdd034febeaaac0182ab5b4fe672381ec Signed-off-by: Tim Crawford <tcrawford@system76.com>
- Loading branch information
Showing
12 changed files
with
777 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
FLASH 32M { | ||
SI_DESC 4K | ||
SI_ME 3944K | ||
SI_BIOS@16M 16M { | ||
RW_MRC_CACHE 64K | ||
SMMSTORE(PRESERVE) 256K | ||
WP_RO { | ||
FMAP 4K | ||
COREBOOT(CBFS) | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
Board name: bonw15-b | ||
Release year: 2024 |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,294 @@ | ||
/* SPDX-License-Identifier: GPL-2.0-only */ | ||
|
||
#include <mainboard/gpio.h> | ||
#include <soc/gpio.h> | ||
|
||
static const struct pad_config gpio_table[] = { | ||
/* ------- GPIO Group GPD ------- */ | ||
PAD_NC(GPD0, NONE), | ||
PAD_CFG_NF(GPD1, NATIVE, PWROK, NF1), // AC_PRESENT | ||
_PAD_CFG_STRUCT(GPD2, 0x42880100, 0x0000), // PCH_LAN_WAKE# | ||
PAD_CFG_NF(GPD3, UP_20K, PWROK, NF1), // PWR_BTN# | ||
PAD_CFG_NF(GPD4, NONE, PWROK, NF1), // SUSB#_PCH | ||
PAD_CFG_NF(GPD5, NONE, PWROK, NF1), // SUSC#_PCH | ||
PAD_NC(GPD6, NONE), | ||
PAD_CFG_GPI(GPD7, NONE, PWROK), // GPD_7 | ||
PAD_CFG_NF(GPD8, NONE, PWROK, NF1), // CNVI_SUSCLK | ||
PAD_CFG_GPO(GPD9, 0, PWROK), // SLP_WLAN_N | ||
PAD_NC(GPD10, NONE), | ||
PAD_CFG_GPO(GPD11, 0, DEEP), // LANPHYPC | ||
PAD_NC(GPD12, NONE), | ||
|
||
/* ------- GPIO Group GPP_A ------- */ | ||
PAD_CFG_NF(GPP_A0, UP_20K, DEEP, NF1), // ESPI_IO0_EC | ||
PAD_CFG_NF(GPP_A1, UP_20K, DEEP, NF1), // ESPI_IO1_EC | ||
PAD_CFG_NF(GPP_A2, UP_20K, DEEP, NF1), // ESPI_IO2_EC | ||
PAD_CFG_NF(GPP_A3, UP_20K, DEEP, NF1), // ESPI_IO3_EC | ||
PAD_CFG_NF(GPP_A4, UP_20K, DEEP, NF1), // ESPI_CS_EC# | ||
PAD_CFG_NF(GPP_A5, DN_20K, DEEP, NF1), // ESPI_CLK_EC | ||
PAD_CFG_NF(GPP_A6, NONE, DEEP, NF1), // ESPI_RESET_N | ||
PAD_NC(GPP_A7, NONE), | ||
PAD_NC(GPP_A8, NONE), | ||
PAD_NC(GPP_A9, NONE), | ||
PAD_CFG_NF(GPP_A10, NONE, DEEP, NF1), // ESPI_ALERT0# | ||
PAD_NC(GPP_A11, NONE), | ||
PAD_NC(GPP_A12, NONE), | ||
PAD_NC(GPP_A13, NONE), | ||
PAD_NC(GPP_A14, NONE), | ||
|
||
/* ------- GPIO Group GPP_B ------- */ | ||
_PAD_CFG_STRUCT(GPP_B0, 0x82900100, 0x0000), // TPM_PIRQ# | ||
PAD_NC(GPP_B1, NONE), | ||
PAD_CFG_GPI(GPP_B2, NONE, DEEP), // CNVI_WAKE# | ||
PAD_CFG_GPO(GPP_B3, 1, DEEP), // PCH_BT_EN | ||
PAD_NC(GPP_B4, NONE), | ||
PAD_NC(GPP_B5, NONE), | ||
PAD_NC(GPP_B6, NONE), | ||
PAD_NC(GPP_B7, NONE), | ||
PAD_NC(GPP_B8, NONE), | ||
PAD_NC(GPP_B9, NONE), | ||
PAD_NC(GPP_B10, NONE), | ||
PAD_NC(GPP_B11, NONE), | ||
PAD_NC(GPP_B12, NONE), | ||
PAD_CFG_NF(GPP_B13, NONE, DEEP, NF1), // PLT_RST# | ||
PAD_CFG_NF(GPP_B14, NONE, DEEP, NF1), // HDA_SPKR | ||
PAD_NC(GPP_B15, NONE), // PS8461_SW | ||
PAD_NC(GPP_B16, NONE), | ||
PAD_NC(GPP_B17, NONE), // 2.5G_LAN_EN | ||
PAD_CFG_NF(GPP_B18, NONE, RSMRST, NF1), // PMCALERT# (tied high) | ||
PAD_CFG_GPO(GPP_B19, 1, DEEP), // PCH_WLAN_EN | ||
PAD_NC(GPP_B20, NONE), | ||
PAD_NC(GPP_B21, NONE), | ||
PAD_CFG_GPO(GPP_B22, 1, DEEP), // LAN_RST# | ||
PAD_CFG_GPI(GPP_B23, NONE, RSMRST), // GPP_B23 (XTAL FREQ SEL1) | ||
|
||
/* ------- GPIO Group GPP_C ------- */ | ||
PAD_CFG_NF(GPP_C0, NONE, DEEP, NF1), // SMB_CLK | ||
PAD_CFG_NF(GPP_C1, NONE, DEEP, NF1), // SMB_DATA | ||
PAD_CFG_GPI(GPP_C2, NONE, PLTRST), // TLS confidentiality strap | ||
PAD_CFG_GPO(GPP_C3, 0, DEEP), // GPPC_I2C2_SDA (Pantone) | ||
PAD_CFG_GPO(GPP_C4, 0, DEEP), // GPPC_I2C2_SCL (Pantone) | ||
PAD_NC(GPP_C5, NONE), // eSPI disable strap | ||
PAD_NC(GPP_C6, NONE), | ||
PAD_NC(GPP_C7, NONE), | ||
PAD_CFG_GPI(GPP_C8, NONE, DEEP), // TPM_DET | ||
PAD_NC(GPP_C9, NONE), | ||
PAD_NC(GPP_C10, NONE), | ||
PAD_NC(GPP_C11, NONE), | ||
PAD_NC(GPP_C12, NONE), | ||
PAD_NC(GPP_C13, NONE), | ||
PAD_NC(GPP_C14, NONE), | ||
PAD_NC(GPP_C15, NONE), | ||
PAD_CFG_NF(GPP_C16, NONE, DEEP, NF1), // I2C_SDA_TP | ||
PAD_CFG_NF(GPP_C17, NONE, DEEP, NF1), // I2C_SCL_TP | ||
PAD_CFG_NF(GPP_C18, NONE, DEEP, NF1), // PCH_I2C_SDA (TPS65994) | ||
PAD_CFG_NF(GPP_C19, NONE, DEEP, NF1), // PCH_I2C_SCL (TPS65994) | ||
// GPP_C20 (UART2_RXD) configured in bootblock | ||
// GPP_C21 (UART2_TXD) configured in bootblock | ||
PAD_CFG_GPO(GPP_C22, 0, DEEP), // ROM_I2C_EN (TPS65994) | ||
PAD_NC(GPP_C23, NONE), | ||
|
||
/* ------- GPIO Group GPP_D ------- */ | ||
PAD_NC(GPP_D0, NONE), | ||
PAD_NC(GPP_D1, NONE), | ||
PAD_NC(GPP_D2, NONE), | ||
PAD_NC(GPP_D3, NONE), // GFX_DETECT_STRAP | ||
PAD_NC(GPP_D4, NONE), | ||
PAD_CFG_GPO(GPP_D5, 1, DEEP), // M.2_BT_PCMFRM_CRF_RST_N | ||
// GPP_D6 (M.2_BT_PCMOUT_CLKREQ0) configured by FSP | ||
PAD_NC(GPP_D7, NONE), | ||
PAD_NC(GPP_D8, NONE), | ||
PAD_NC(GPP_D9, NONE), | ||
PAD_NC(GPP_D10, NONE), | ||
PAD_NC(GPP_D11, NONE), | ||
PAD_NC(GPP_D12, NONE), | ||
PAD_NC(GPP_D13, NONE), | ||
PAD_NC(GPP_D14, NONE), | ||
PAD_NC(GPP_D15, NONE), | ||
PAD_NC(GPP_D16, NONE), | ||
PAD_NC(GPP_D17, NONE), | ||
PAD_NC(GPP_D18, NONE), | ||
PAD_NC(GPP_D19, NONE), | ||
PAD_NC(GPP_D20, NONE), | ||
PAD_NC(GPP_D21, NONE), | ||
PAD_NC(GPP_D22, NONE), | ||
PAD_NC(GPP_D23, NONE), | ||
|
||
/* ------- GPIO Group GPP_E ------- */ | ||
PAD_CFG_GPO(GPP_E0, 1, DEEP), // GPP_E0_TBT_RST# | ||
PAD_NC(GPP_E1, NONE), | ||
PAD_NC(GPP_E2, NONE), | ||
PAD_NC(GPP_E3, NONE), | ||
PAD_NC(GPP_E4, NONE), | ||
PAD_NC(GPP_E5, NONE), | ||
PAD_NC(GPP_E6, NONE), | ||
PAD_CFG_GPI_INT(GPP_E7, NONE, PLTRST, LEVEL), // TP_ATTN# | ||
PAD_CFG_NF(GPP_E8, NONE, DEEP, NF1), // SATA_LED# | ||
PAD_CFG_NF(GPP_E9, NONE, DEEP, NF1), // GPP_E_9_USB_OC0_N | ||
PAD_CFG_NF(GPP_E10, NONE, DEEP, NF1), // GPP_E_10_USB_OC1_N | ||
PAD_CFG_NF(GPP_E11, NONE, DEEP, NF1), // GPP_E_11_USB_OC2_N | ||
PAD_CFG_NF(GPP_E12, NONE, DEEP, NF1), // GPP_E_12_USB_OC3_N | ||
PAD_NC(GPP_E13, NONE), | ||
PAD_NC(GPP_E14, NONE), | ||
PAD_NC(GPP_E15, NONE), | ||
PAD_NC(GPP_E16, NONE), | ||
PAD_NC(GPP_E17, NONE), | ||
PAD_CFG_GPO(GPP_E18, 1, DEEP), // SB_BLON | ||
_PAD_CFG_STRUCT(GPP_E19, 0x42880100, 0x0000), // GPP_E19_TBT_WAKE# | ||
PAD_NC(GPP_E20, NONE), | ||
PAD_NC(GPP_E21, NONE), | ||
|
||
/* ------- GPIO Group GPP_F ------- */ | ||
PAD_NC(GPP_F0, NONE), | ||
PAD_NC(GPP_F1, NONE), | ||
PAD_NC(GPP_F2, NONE), | ||
PAD_NC(GPP_F3, NONE), | ||
PAD_NC(GPP_F4, NONE), | ||
PAD_NC(GPP_F5, NONE), | ||
PAD_NC(GPP_F6, NONE), | ||
PAD_NC(GPP_F7, NONE), | ||
PAD_CFG_GPI(GPP_F8, NONE, DEEP), // GC6_FB_EN_PCH | ||
PAD_NC(GPP_F9, NONE), | ||
PAD_NC(GPP_F10, NONE), | ||
PAD_NC(GPP_F11, NONE), | ||
PAD_NC(GPP_F12, NONE), | ||
PAD_NC(GPP_F13, NONE), | ||
PAD_CFG_GPI(GPP_F14, NONE, DEEP), // TBT5 strap | ||
PAD_CFG_GPI(GPP_F15, NONE, DEEP), // H_SKTOCC_N | ||
PAD_NC(GPP_F16, NONE), | ||
PAD_NC(GPP_F17, NONE), | ||
PAD_CFG_GPO(GPP_F18, 0, DEEP), // CCD_FW_WP# | ||
PAD_CFG_NF(GPP_F19, NONE, DEEP, NF1), // NB_ENAVDD | ||
PAD_CFG_NF(GPP_F20, NONE, DEEP, NF1), // BLON | ||
PAD_CFG_NF(GPP_F21, NONE, DEEP, NF1), // EDP_BRIGHTNESS | ||
// GPP_F22 (DGPU_PWR_EN) configured in bootblock | ||
PAD_NC(GPP_F23, NONE), | ||
|
||
/* ------- GPIO Group GPP_G ------- */ | ||
PAD_NC(GPP_G0, NONE), | ||
PAD_CFG_GPI(GPP_G1, NONE, DEEP), // GPU SKU strap (L: X9, H: X11) | ||
PAD_NC(GPP_G2, NONE), | ||
PAD_CFG_GPI(GPP_G3, NONE, DEEP), // DDS strap (L: Non-DDS, H: DDS) | ||
PAD_CFG_GPI(GPP_G4, NONE, DEEP), // Smart AMP strap (L: TI, H: Realtek) | ||
PAD_CFG_NF(GPP_G5, NONE, DEEP, NF1), // SLP_DRAM_N | ||
PAD_CFG_GPI(GPP_G6, NONE, DEEP), // Pantone (L: W/O, H: W) | ||
PAD_NC(GPP_G7, NONE), | ||
|
||
/* ------- GPIO Group GPP_H ------- */ | ||
PAD_CFG_GPI(GPP_H0, NONE, DEEP), // VAL_SV_ADVANCE_STRAP | ||
PAD_NC(GPP_H1, NONE), | ||
PAD_NC(GPP_H2, NONE), // WLAN_WAKE_N | ||
// GPP_H3 (WLAN_CLKREQ9#) configured by FSP | ||
// GPP_H4 (SSD1_CLKREQ10#) configured by FSP | ||
// GPP_H5 (SSD2_CLKREQ11#) configured by FSP | ||
// GPP_H6 (SSD3_CLKREQ12#) configured by FSP | ||
// GPP_H7 (TBT_CLKREQ13#) configured by FSP | ||
// GPP_H8 (GPU_PCIE_CLKREQ14#) configured by FSP | ||
// GPP_H9 (GLAN_CLKREQ15#) configured by FSP | ||
PAD_NC(GPP_H10, NONE), | ||
PAD_NC(GPP_H11, NONE), | ||
PAD_CFG_GPI(GPP_H12, NONE, RSMRST), // eSPI flash sharing mode strap (L: MAF, H: SAF) | ||
PAD_NC(GPP_H13, NONE), | ||
PAD_NC(GPP_H14, NONE), | ||
PAD_CFG_GPI(GPP_H15, NONE, RSMRST), // JTAG ODT disable strap (L: Disable, H: Enable) | ||
PAD_NC(GPP_H16, NONE), | ||
PAD_CFG_GPO(GPP_H17, 1, DEEP), // M.2_PLT_RST_CNTRL3# | ||
PAD_CFG_GPI(GPP_H18, NONE, RSMRST), // VCCPSPI strap (L: 3.3V, H: 1.8V) | ||
PAD_NC(GPP_H19, NONE), | ||
PAD_NC(GPP_H20, NONE), | ||
PAD_NC(GPP_H21, NONE), // TBT_MRESET_PCH | ||
PAD_NC(GPP_H22, NONE), | ||
PAD_NC(GPP_H23, NONE), | ||
|
||
/* ------- GPIO Group GPP_I ------- */ | ||
PAD_NC(GPP_I0, NONE), | ||
_PAD_CFG_STRUCT(GPP_I1, 0x86880100, 0x0000), // G_DP_DHPD_E | ||
_PAD_CFG_STRUCT(GPP_I2, 0x86880100, 0x0000), // DP_D_HPD | ||
_PAD_CFG_STRUCT(GPP_I3, 0x86880100, 0x0000), // HDMI_HPD | ||
_PAD_CFG_STRUCT(GPP_I4, 0x86880100, 0x0000), // DP_A_HPD | ||
PAD_NC(GPP_I5, NONE), | ||
PAD_NC(GPP_I6, NONE), | ||
PAD_NC(GPP_I7, NONE), | ||
PAD_NC(GPP_I8, NONE), | ||
PAD_NC(GPP_I9, NONE), | ||
PAD_NC(GPP_I10, NONE), | ||
PAD_CFG_NF(GPP_I11, NONE, DEEP, NF1), // GPP_I_11_USB_OC4_N | ||
PAD_CFG_NF(GPP_I12, NONE, DEEP, NF1), // GPP_I_12_USB_OC5_N | ||
PAD_CFG_NF(GPP_I13, NONE, DEEP, NF1), // GPP_I_13_USB_OC6_N | ||
PAD_CFG_NF(GPP_I14, NONE, DEEP, NF1), // GPP_I_14_USB_OC7_N | ||
PAD_NC(GPP_I15, NONE), | ||
PAD_NC(GPP_I16, NONE), | ||
PAD_NC(GPP_I17, NONE), | ||
PAD_CFG_GPI(GPP_I18, NONE, PWROK), // No reboot strap (L: Disable, H: Enable) | ||
PAD_NC(GPP_I19, NONE), | ||
PAD_NC(GPP_I20, NONE), | ||
PAD_NC(GPP_I21, NONE), | ||
PAD_CFG_GPI(GPP_I22, NONE, PWROK), // Boot BIOS strap (L: MAF or SAF, H: eSPI) | ||
|
||
/* ------- GPIO Group GPP_J ------- */ | ||
PAD_CFG_NF(GPP_J0, NONE, DEEP, NF1), // CNVI_GNSS_PA_BLANKING | ||
PAD_CFG_NF(GPP_J1, NONE, DEEP, NF1), // CPU_C10_GATE# | ||
PAD_CFG_NF(GPP_J2, NONE, DEEP, NF1), // CNVI_BRI_DT_R | ||
PAD_CFG_NF(GPP_J3, UP_20K, DEEP, NF1), // CNVI_BRI_RSP | ||
PAD_CFG_NF(GPP_J4, NONE, DEEP, NF1), // CNVI_RGI_DT_R | ||
PAD_CFG_NF(GPP_J5, UP_20K, DEEP, NF1), // CNVI_RGI_RSP | ||
PAD_CFG_NF(GPP_J6, NONE, DEEP, NF1), // CNVI_MFUART2_RXD | ||
PAD_CFG_NF(GPP_J7, NONE, DEEP, NF1), // CNVI_MFUART2_TXD | ||
PAD_CFG_GPI(GPP_J8, NONE, DEEP), // VAL_TEST_SETUP_MENU | ||
PAD_NC(GPP_J9, NONE), | ||
PAD_NC(GPP_J10, NONE), | ||
PAD_NC(GPP_J11, NONE), | ||
|
||
/* ------- GPIO Group GPP_K ------- */ | ||
PAD_NC(GPP_K0, NONE), | ||
PAD_NC(GPP_K1, NONE), | ||
PAD_NC(GPP_K2, NONE), | ||
PAD_NC(GPP_K3, NONE), | ||
PAD_NC(GPP_K4, NONE), | ||
PAD_NC(GPP_K5, NONE), | ||
// GPP_K6 missing | ||
// GPP_K7 missing | ||
PAD_CFG_NF(GPP_K8, NONE, DEEP, NF1), // GPP_K_8_CORE_VID_0 | ||
PAD_CFG_NF(GPP_K9, NONE, DEEP, NF1), // GPP_K_9_CORE_VID_1 | ||
PAD_CFG_NF(GPP_K10, NONE, DEEP, NF2), | ||
PAD_NC(GPP_K11, NONE), | ||
|
||
/* ------- GPIO Group GPP_R ------- */ | ||
PAD_CFG_NF(GPP_R0, NONE, DEEP, NF1), // HDA_BITCLK | ||
PAD_CFG_NF(GPP_R1, NATIVE, DEEP, NF1), // HDA_SYNC | ||
PAD_CFG_NF(GPP_R2, NATIVE, DEEP, NF1), // HDA_SDOUT | ||
PAD_CFG_NF(GPP_R3, NATIVE, DEEP, NF1), // HDA_SDIN0 | ||
PAD_CFG_NF(GPP_R4, NONE, DEEP, NF1), // HDA_RST# | ||
PAD_NC(GPP_R5, NONE), | ||
PAD_NC(GPP_R6, NONE), | ||
PAD_CFG_GPO(GPP_R7, 1, DEEP), // GPP_R7_TBT_RTD3 | ||
PAD_CFG_GPI(GPP_R8, NONE, DEEP), // DGPU_PWRGD | ||
PAD_CFG_NF(GPP_R9, NONE, DEEP, NF1), // EDP_HPD | ||
PAD_NC(GPP_R10, NONE), | ||
PAD_NC(GPP_R11, NONE), | ||
PAD_NC(GPP_R12, NONE), | ||
PAD_NC(GPP_R13, NONE), | ||
PAD_NC(GPP_R14, NONE), | ||
PAD_NC(GPP_R15, NONE), | ||
// GPP_R16 (DGPU_RST#_PCH) configured in bootblock | ||
PAD_NC(GPP_R17, NONE), | ||
PAD_NC(GPP_R18, NONE), | ||
PAD_NC(GPP_R19, NONE), | ||
PAD_NC(GPP_R20, NONE), | ||
PAD_NC(GPP_R21, NONE), | ||
|
||
/* ------- GPIO Group GPP_S ------- */ | ||
PAD_NC(GPP_S0, NONE), | ||
PAD_NC(GPP_S1, NONE), | ||
PAD_NC(GPP_S2, NONE), | ||
PAD_NC(GPP_S3, NONE), | ||
PAD_NC(GPP_S4, NONE), // GPPS_DMIC_CLK | ||
PAD_NC(GPP_S5, NONE), // GPPS_DMIC_DATA | ||
PAD_NC(GPP_S6, NONE), | ||
PAD_NC(GPP_S7, NONE), | ||
}; | ||
|
||
void mainboard_configure_gpios(void) | ||
{ | ||
gpio_configure_pads(gpio_table, ARRAY_SIZE(gpio_table)); | ||
} |
Oops, something went wrong.