| /* SPDX-License-Identifier: GPL-2.0-only */ |
| |
| #include <baseboard/variants.h> |
| #include <device/device.h> |
| #include <device/pci_def.h> |
| #include <gpio.h> |
| #include <soc/platform_descriptors.h> |
| #include <types.h> |
| |
| /* All PCIe Resets are handled in coreboot */ |
| static fsp_dxio_descriptor guybrush_czn_dxio_descriptors[] = { |
| { /* WLAN */ |
| .engine_type = PCIE_ENGINE, |
| .port_present = true, |
| .start_logical_lane = 0, |
| .end_logical_lane = 0, |
| .link_speed_capability = GEN3, |
| .device_number = PCI_SLOT(WLAN_DEVFN), |
| .function_number = PCI_FUNC(WLAN_DEVFN), |
| .link_aspm = ASPM_L1, |
| .link_aspm_L1_1 = false, |
| .link_aspm_L1_2 = false, |
| .turn_off_unused_lanes = true, |
| .clk_req = CLK_REQ0, |
| .port_params = {PP_PSPP_AC, 0x133, PP_PSPP_DC, 0x122} |
| }, |
| { /* SD */ |
| .engine_type = PCIE_ENGINE, |
| .port_present = true, |
| .start_logical_lane = 1, |
| .end_logical_lane = 1, |
| .link_speed_capability = GEN3, |
| .device_number = PCI_SLOT(SD_DEVFN), |
| .function_number = PCI_FUNC(SD_DEVFN), |
| .link_aspm = ASPM_L1, |
| .link_aspm_L1_1 = false, |
| .link_aspm_L1_2 = false, |
| .turn_off_unused_lanes = true, |
| .clk_req = CLK_REQ1, |
| .gpio_group_id = GPIO_69, |
| .port_params = {PP_PSPP_AC, 0x133, PP_PSPP_DC, 0x122} |
| }, |
| { /* WWAN */ |
| .engine_type = UNUSED_ENGINE, |
| .port_present = true, |
| .start_logical_lane = 2, |
| .end_logical_lane = 2, |
| .link_speed_capability = GEN3, |
| .device_number = PCI_SLOT(WWAN_DEVFN), |
| .function_number = PCI_FUNC(WWAN_DEVFN), |
| .link_aspm = ASPM_L1, |
| .link_aspm_L1_1 = true, |
| .link_aspm_L1_2 = true, |
| .turn_off_unused_lanes = true, |
| .clk_req = CLK_REQ2, |
| .port_params = {PP_PSPP_AC, 0x133, PP_PSPP_DC, 0x122} |
| }, |
| { /* NVME */ |
| .engine_type = PCIE_ENGINE, |
| .port_present = true, |
| .start_logical_lane = 4, |
| .end_logical_lane = 7, |
| .link_speed_capability = GEN3, |
| .device_number = PCI_SLOT(NVME_DEVFN), |
| .function_number = PCI_FUNC(NVME_DEVFN), |
| .link_aspm = ASPM_L1, |
| .link_aspm_L1_1 = true, |
| .link_aspm_L1_2 = true, |
| .turn_off_unused_lanes = true, |
| .clk_req = CLK_REQ3, |
| .port_params = {PP_PSPP_AC, 0x133, PP_PSPP_DC, 0x122} |
| }, |
| { /* Dummy Device */ |
| .engine_type = PCIE_ENGINE, |
| .port_present = true, |
| .start_logical_lane = 8, |
| .end_logical_lane = 11, |
| .device_number = PCIE_GPP_BRIDGE_2_DEV, |
| .function_number = PCIE_GPP_2_4_FUNC, |
| .turn_off_unused_lanes = true, |
| .clk_req = CLK_REQ5, |
| .port_params = {PP_PSPP_AC, 0x133, PP_PSPP_DC, 0x122} |
| }, |
| { /* Dummy Device */ |
| .engine_type = PCIE_ENGINE, |
| .port_present = true, |
| .start_logical_lane = 16, |
| .end_logical_lane = 23, |
| .device_number = PCIE_GPP_BRIDGE_1_DEV, |
| .function_number = PCIE_GPP_1_0_FUNC, |
| .turn_off_unused_lanes = true, |
| .clk_req = CLK_REQ6, |
| .port_params = {PP_PSPP_AC, 0x133, PP_PSPP_DC, 0x122} |
| } |
| }; |
| |
| static fsp_ddi_descriptor guybrush_czn_ddi_descriptors[] = { |
| { /* DDI0 - eDP */ |
| .connector_type = DDI_EDP, |
| .aux_index = DDI_AUX1, |
| .hdp_index = DDI_HDP1 |
| }, |
| { /* DDI1 - HDMI */ |
| .connector_type = DDI_HDMI, |
| .aux_index = DDI_AUX2, |
| .hdp_index = DDI_HDP2 |
| }, |
| { /* DDI2 */ |
| .connector_type = DDI_UNUSED_TYPE, |
| .aux_index = DDI_AUX3, |
| .hdp_index = DDI_HDP3, |
| }, |
| { /* DDI3 - DP (type C) */ |
| .connector_type = DDI_DP, |
| .aux_index = DDI_AUX3, |
| .hdp_index = DDI_HDP3, |
| }, |
| { /* DDI4 - DP (type C) */ |
| .connector_type = DDI_DP, |
| .aux_index = DDI_AUX4, |
| .hdp_index = DDI_HDP4, |
| } |
| }; |
| |
| void __weak variant_update_dxio_descriptors(fsp_dxio_descriptor *dxio_descriptors) |
| { |
| } |
| |
| void __weak variant_update_ddi_descriptors(fsp_ddi_descriptor *ddi_descriptors) |
| { |
| } |
| |
| void mainboard_get_dxio_ddi_descriptors( |
| const fsp_dxio_descriptor **dxio_descs, size_t *dxio_num, |
| const fsp_ddi_descriptor **ddi_descs, size_t *ddi_num) |
| { |
| /* Get Variant specific SD AUX Reset GPIO */ |
| guybrush_czn_dxio_descriptors[SD].gpio_group_id = variant_sd_aux_reset_gpio(); |
| |
| /* gpp_bridge_2 is used either for WWAN or NVME bridge. Mark it as PCIE_ENGINE when it |
| is enabled. */ |
| if (is_dev_enabled(DEV_PTR(gpp_bridge_2))) |
| guybrush_czn_dxio_descriptors[WWAN_NVME].engine_type = PCIE_ENGINE; |
| |
| if (variant_has_pcie_wwan()) |
| guybrush_czn_dxio_descriptors[WWAN_NVME].gpio_group_id = GPIO_18; |
| |
| variant_update_dxio_descriptors(guybrush_czn_dxio_descriptors); |
| variant_update_ddi_descriptors(guybrush_czn_ddi_descriptors); |
| |
| *dxio_descs = guybrush_czn_dxio_descriptors; |
| *dxio_num = ARRAY_SIZE(guybrush_czn_dxio_descriptors); |
| |
| *ddi_descs = guybrush_czn_ddi_descriptors; |
| *ddi_num = ARRAY_SIZE(guybrush_czn_ddi_descriptors); |
| } |