coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
fsp_s_params.c
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #include <assert.h>
4 #include <amdblocks/ioapic.h>
5 #include <device/pci.h>
6 #include <soc/iomap.h>
7 #include <soc/pci_devs.h>
8 #include <soc/platform_descriptors.h>
9 #include <soc/soc_util.h>
10 #include <fsp/api.h>
11 #include "chip.h"
12 
14  const struct soc_amd_picasso_config *cfg)
15 {
16  int val = SD_DISABLE;
17 
18  switch (cfg->emmc_config.timing) {
19  case SD_EMMC_DISABLE:
20  val = SD_DISABLE;
21  break;
22  case SD_EMMC_SD_LOW_SPEED:
23  val = SD_LOW_SPEED;
24  break;
25  case SD_EMMC_SD_HIGH_SPEED:
27  break;
28  case SD_EMMC_SD_UHS_I_SDR_50:
30  break;
31  case SD_EMMC_SD_UHS_I_DDR_50:
33  break;
34  case SD_EMMC_SD_UHS_I_SDR_104:
36  break;
37  case SD_EMMC_EMMC_SDR_26:
38  val = EMMC_SDR_26;
39  break;
40  case SD_EMMC_EMMC_SDR_52:
41  val = EMMC_SDR_52;
42  break;
43  case SD_EMMC_EMMC_DDR_104:
44  val = EMMC_DDR_104;
45  break;
46  case SD_EMMC_EMMC_HS200:
47  val = EMMC_HS200;
48  break;
49  case SD_EMMC_EMMC_HS400:
50  val = EMMC_HS400;
51  break;
52  case SD_EMMC_EMMC_HS300:
53  val = EMMC_HS300;
54  break;
55  default:
56  break;
57  }
58 
59  scfg->emmc0_mode = val;
60  scfg->emmc0_sdr104_hs400_driver_strength =
62  scfg->emmc0_ddr50_driver_strength = cfg->emmc_config.ddr50_driver_strength;
63  scfg->emmc0_sdr50_driver_strength = cfg->emmc_config.sdr50_driver_strength;
64  scfg->emmc0_init_khz_preset = cfg->emmc_config.init_khz_preset;
65 }
66 
68  const fsp_dxio_descriptor *descs, size_t num)
69 {
70  size_t i;
71 
72  ASSERT_MSG(num <= FSPS_UPD_DXIO_DESCRIPTOR_COUNT,
73  "Too many DXIO descriptors provided.");
74 
75  for (i = 0; i < num; i++) {
76  memcpy(scfg->dxio_descriptor[i], &descs[i], sizeof(scfg->dxio_descriptor[0]));
77  }
78 }
79 
81  const fsp_ddi_descriptor *descs, size_t num)
82 {
83  size_t i;
84 
85  ASSERT_MSG(num <= FSPS_UPD_DDI_DESCRIPTOR_COUNT,
86  "Too many DDI descriptors provided.");
87 
88  for (i = 0; i < num; i++) {
89  memcpy(&scfg->ddi_descriptor[i], &descs[i], sizeof(scfg->ddi_descriptor[0]));
90  }
91 }
92 
94 {
95  const fsp_dxio_descriptor *fsp_dxio = NULL;
96  const fsp_ddi_descriptor *fsp_ddi = NULL;
97  size_t num_dxio = 0;
98  size_t num_ddi = 0;
99 
100  mainboard_get_dxio_ddi_descriptors(&fsp_dxio, &num_dxio,
101  &fsp_ddi, &num_ddi);
102  fill_dxio_descriptors(scfg, fsp_dxio, num_dxio);
103  fill_ddi_descriptors(scfg, fsp_ddi, num_ddi);
104 }
105 
107  const struct soc_amd_picasso_config *cfg)
108 {
109  size_t i;
110 
111  ASSERT(FSPS_UPD_USB2_PORT_COUNT == USB_PORT_COUNT);
112  /* each OC mapping in xhci_oc_pin_select is 4 bit per USB port */
113  ASSERT(2 * sizeof(scfg->xhci_oc_pin_select) >= USB_PORT_COUNT);
114 
115  scfg->fch_usb_3_port_force_gen1 = cfg->usb3_port_force_gen1.usb3_port_force_gen1_en;
116 
117  if (cfg->has_usb2_phy_tune_params) {
118  for (i = 0; i < FSPS_UPD_USB2_PORT_COUNT; i++) {
119  memcpy(scfg->fch_usb_2_port_phy_tune[i],
120  &cfg->usb_2_port_tune_params[i],
121  sizeof(scfg->fch_usb_2_port_phy_tune[0]));
122  }
123  }
124 
125  /* lowest nibble of xhci_oc_pin_select corresponds to OC mapping of first USB port */
126  for (i = 0; i < USB_PORT_COUNT; i++) {
127  scfg->xhci_oc_pin_select &= ~(0xf << (i * 4));
128  scfg->xhci_oc_pin_select |=
129  (cfg->usb_port_overcurrent_pin[i] & 0xf) << (i * 4);
130  }
131 
132  if ((get_silicon_type() == SILICON_RV2) && cfg->usb3_phy_override) {
133  scfg->usb_3_phy_enable = cfg->usb3_phy_override;
134  for (i = 0; i < FSPS_UPD_RV2_USB3_PORT_COUNT; i++) {
135  memcpy(scfg->usb_3_port_phy_tune[i],
136  &cfg->usb3_phy_tune_params[i],
137  sizeof(scfg->usb_3_port_phy_tune[0]));
138  }
139  scfg->usb_3_rx_vref_ctrl = cfg->usb3_rx_vref_ctrl;
140  scfg->usb_3_rx_vref_ctrl_en = cfg->usb3_rx_vref_ctrl_en;
141  scfg->usb_3_tx_vboost_lvl = cfg->usb_3_tx_vboost_lvl;
142  scfg->usb_3_tx_vboost_lvl_en = cfg->usb_3_tx_vboost_lvl_en;
143  scfg->usb_3_rx_vref_ctrl_x = cfg->usb_3_rx_vref_ctrl_x;
144  scfg->usb_3_rx_vref_ctrl_en_x = cfg->usb_3_rx_vref_ctrl_en_x;
145  scfg->usb_3_tx_vboost_lvl_x = cfg->usb_3_tx_vboost_lvl_x;
146  scfg->usb_3_tx_vboost_lvl_en_x = cfg->usb_3_tx_vboost_lvl_en_x;
147  }
148 }
149 
151 {
152  scfg->gnb_ioapic_base = GNB_IO_APIC_ADDR;
153  scfg->gnb_ioapic_id = GNB_IOAPIC_ID;
154  scfg->fch_ioapic_id = FCH_IOAPIC_ID;
155 }
156 
158  const struct soc_amd_picasso_config *cfg)
159 {
161  scfg->edp_phy_override = cfg->edp_phy_override;
162  scfg->edp_physel = cfg->edp_physel;
163  scfg->edp_dp_vs_pemph_level = cfg->edp_tuningset.dp_vs_pemph_level;
164  scfg->edp_margin_deemph = cfg->edp_tuningset.margin_deemph;
165  scfg->edp_deemph_6db_4 = cfg->edp_tuningset.deemph_6db4;
166  scfg->edp_boost_adj = cfg->edp_tuningset.boostadj;
167  }
168  if (cfg->edp_pwr_adjust_enable) {
169  scfg->pwron_digon_to_de = cfg->pwron_digon_to_de;
170  scfg->pwron_de_to_varybl = cfg->pwron_de_to_varybl;
171  scfg->pwrdown_varybloff_to_de = cfg->pwrdown_varybloff_to_de;
172  scfg->pwrdown_de_to_digoff = cfg->pwrdown_de_to_digoff;
173  scfg->pwroff_delay = cfg->pwroff_delay;
174  scfg->pwron_varybl_to_blon = cfg->pwron_varybl_to_blon;
175  scfg->pwrdown_bloff_to_varybloff = cfg->pwrdown_bloff_to_varybloff;
176  scfg->min_allowed_bl_level = cfg->min_allowed_bl_level;
177  }
178 }
179 
181 {
182  scfg->vbios_buffer_addr = CONFIG(RUN_FSP_GOP) ? PCI_VGA_RAM_IMAGE_START : 0;
183 }
184 
186 {
187  const struct soc_amd_picasso_config *cfg;
188  FSP_S_CONFIG *scfg = &supd->FspsConfig;
189 
190  cfg = config_of_soc();
191  fsps_update_emmc_config(scfg, cfg);
194  fsp_usb_oem_customization(scfg, cfg);
195  fsp_edp_tuning_upds(scfg, cfg);
196  fsp_assign_vbios_upds(scfg);
197 }
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)
@ SILICON_RV2
Definition: soc_util.h:17
enum silicon_type get_silicon_type(void)
Definition: soc_util.c:124
void * memcpy(void *dest, const void *src, size_t n)
Definition: memcpy.c:7
#define ASSERT(x)
Definition: assert.h:44
#define ASSERT_MSG(x, msg)
Definition: assert.h:54
void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
Definition: fsp_s_params.c:14
@ CONFIG
Definition: dsi_common.h:201
#define FSP_S_CONFIG
Definition: fsp_upd.h:9
#define config_of_soc()
Definition: device.h:394
#define PCI_VGA_RAM_IMAGE_START
Definition: pci_rom.h:12
static void fsp_assign_ioapic_upds(FSP_S_CONFIG *scfg)
Definition: fsp_s_params.c:150
static void fsp_fill_pcie_ddi_descriptors(FSP_S_CONFIG *scfg)
Definition: fsp_s_params.c:93
static void fsp_usb_oem_customization(FSP_S_CONFIG *scfg, const struct soc_amd_picasso_config *cfg)
Definition: fsp_s_params.c:106
static void fsps_update_emmc_config(FSP_S_CONFIG *scfg, const struct soc_amd_picasso_config *cfg)
Definition: fsp_s_params.c:13
static void fsp_assign_vbios_upds(FSP_S_CONFIG *scfg)
Definition: fsp_s_params.c:180
static void fill_dxio_descriptors(FSP_S_CONFIG *scfg, const fsp_dxio_descriptor *descs, size_t num)
Definition: fsp_s_params.c:67
static void fsp_edp_tuning_upds(FSP_S_CONFIG *scfg, const struct soc_amd_picasso_config *cfg)
Definition: fsp_s_params.c:157
static void fill_ddi_descriptors(FSP_S_CONFIG *scfg, const fsp_ddi_descriptor *descs, size_t num)
Definition: fsp_s_params.c:80
#define SD_UHS_I_DDR_50
#define SD_HIGH_SPEED
#define EMMC_SDR_52
#define SD_LOW_SPEED
#define EMMC_DDR_104
#define SD_UHS_I_SDR_50
#define EMMC_HS200
#define SD_UHS_I_SDR_104
#define EMMC_HS300
#define EMMC_HS400
#define SD_DISABLE
#define EMMC_SDR_26
#define FCH_IOAPIC_ID
Definition: ioapic.h:7
#define GNB_IOAPIC_ID
Definition: ioapic.h:8
@ ENABLE_EDP_TUNINGSET
Definition: chip.h:94
#define USB_PORT_COUNT
Definition: chip.h:68
#define NULL
Definition: stddef.h:19
uint8_t usb3_rx_vref_ctrl
Definition: chip.h:243
uint8_t edp_physel
Definition: chip.h:281
uint8_t usb_3_rx_vref_ctrl_en_x
Definition: chip.h:253
uint8_t usb3_phy_override
Definition: chip.h:236
struct usb3_phy_tune usb3_phy_tune_params[RV2_USB3_PORT_COUNT]
Definition: chip.h:241
union usb3_force_gen1 usb3_port_force_gen1
Definition: chip.h:221
struct usb2_phy_tune usb_2_port_tune_params[USB_PORT_COUNT]
Definition: chip.h:224
struct soc_amd_picasso_config::@417 emmc_config
uint8_t pwrdown_bloff_to_varybloff
Definition: chip.h:301
uint16_t edp_phy_override
Definition: chip.h:279
struct soc_amd_picasso_config::@421 edp_tuningset
uint8_t pwron_digon_to_de
Definition: chip.h:295
uint8_t usb_3_rx_vref_ctrl_x
Definition: chip.h:251
uint8_t has_usb2_phy_tune_params
Definition: chip.h:223
uint8_t edp_pwr_adjust_enable
Definition: chip.h:294
uint16_t margin_deemph
Definition: chip.h:287
uint8_t pwroff_delay
Definition: chip.h:299
uint8_t deemph_6db4
Definition: chip.h:285
uint8_t pwron_varybl_to_blon
Definition: chip.h:300
enum sd_emmc_driver_strength sdr104_hs400_driver_strength
Definition: chip.h:206
enum sd_emmc_driver_strength ddr50_driver_strength
Definition: chip.h:207
uint8_t usb_3_tx_vboost_lvl
Definition: chip.h:247
uint8_t min_allowed_bl_level
Definition: chip.h:302
uint8_t usb_3_tx_vboost_lvl_en_x
Definition: chip.h:257
uint8_t pwron_de_to_varybl
Definition: chip.h:296
enum soc_amd_picasso_config::@418 usb_port_overcurrent_pin[USB_PORT_COUNT]
uint8_t pwrdown_de_to_digoff
Definition: chip.h:298
uint8_t usb3_rx_vref_ctrl_en
Definition: chip.h:245
uint8_t usb_3_tx_vboost_lvl_en
Definition: chip.h:249
enum soc_amd_picasso_config::@417::@422 timing
uint16_t init_khz_preset
Definition: chip.h:217
uint8_t boostadj
Definition: chip.h:286
uint8_t usb_3_tx_vboost_lvl_x
Definition: chip.h:255
uint8_t dp_vs_pemph_level
Definition: chip.h:284
uint8_t pwrdown_varybloff_to_de
Definition: chip.h:297
enum sd_emmc_driver_strength sdr50_driver_strength
Definition: chip.h:208
u8 val
Definition: sys.c:300
uint8_t usb3_port_force_gen1_en
Definition: chip.h:48