soc/apl: add options to override USB port config
Allows to override the PortUsb20Enable and PortUsb30Enable FSP options (which are set to 1 by default) to enable/disable USB ports if the usb_config_override flag is set to "1". Therefore, these changes will not affect other boards with an Apollo Lake processor. Change-Id: Ia94a2be1647f7743ef0c918ae3b34437a179261c Signed-off-by: Maxim Polyakov <max.senia.poliak@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/38815 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Angel Pons <th3fanbus@gmail.com>
This commit is contained in:
committed by
Patrick Georgi
parent
44fc40e091
commit
6704049fc9
@@ -558,11 +558,18 @@ static void parse_devicetree(FSP_S_CONFIG *silconfig)
|
||||
static void apl_fsp_silicon_init_params_cb(struct soc_intel_apollolake_config
|
||||
*cfg, FSP_S_CONFIG *silconfig)
|
||||
{
|
||||
#if !CONFIG(SOC_INTEL_GLK) /* GLK FSP does not have these
|
||||
fields in FspsUpd.h yet */
|
||||
#if !CONFIG(SOC_INTEL_GLK) /* GLK FSP does not have these fields in FspsUpd.h yet */
|
||||
uint8_t port;
|
||||
|
||||
for (port = 0; port < APOLLOLAKE_USB2_PORT_MAX; port++) {
|
||||
if (cfg->usb_config_override) {
|
||||
if (!cfg->usb2_port[port].enable)
|
||||
continue;
|
||||
|
||||
silconfig->PortUsb20Enable[port] = 1;
|
||||
silconfig->PortUs20bOverCurrentPin[port] = cfg->usb2_port[port].oc_pin;
|
||||
}
|
||||
|
||||
if (cfg->usb2eye[port].Usb20PerPortTxPeHalf != 0)
|
||||
silconfig->PortUsb20PerPortTxPeHalf[port] =
|
||||
cfg->usb2eye[port].Usb20PerPortTxPeHalf;
|
||||
@@ -591,6 +598,16 @@ static void apl_fsp_silicon_init_params_cb(struct soc_intel_apollolake_config
|
||||
silconfig->PortUsb20HsNpreDrvSel[port] =
|
||||
cfg->usb2eye[port].Usb20HsNpreDrvSel;
|
||||
}
|
||||
|
||||
if (cfg->usb_config_override) {
|
||||
for (port = 0; port < APOLLOLAKE_USB3_PORT_MAX; port++) {
|
||||
if (!cfg->usb3_port[port].enable)
|
||||
continue;
|
||||
|
||||
silconfig->PortUsb30Enable[port] = 1;
|
||||
silconfig->PortUs30bOverCurrentPin[port] = cfg->usb3_port[port].oc_pin;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user