soc/intel/cnl: Use the common code to set the PchPmPwrCycDur

This patch uses the common code to avoid violating the PCH EDS
recommendation for the PchPmPwrCycDur setting.

Change-Id: Id418480bc779d56ff5586516d9bd99ca15133203
Signed-off-by: V Sowmya <v.sowmya@intel.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/45029
Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
V Sowmya 2020-09-02 17:09:47 +05:30 committed by Patrick Georgi
parent d8a722cb61
commit 27413d3219

View file

@ -8,6 +8,7 @@
#include <fsp/util.h>
#include <intelblocks/lpss.h>
#include <intelblocks/power_limit.h>
#include <intelblocks/pmclib.h>
#include <intelblocks/xdci.h>
#include <intelpch/lockdown.h>
#include <soc/intel/common/vbt.h>
@ -32,39 +33,6 @@ static const pci_devfn_t serial_io_dev[] = {
PCH_DEVFN_UART2
};
/* List of Minimum Assertion durations in microseconds */
enum min_assrt_dur {
MinAssrtDur0s = 0,
MinAssrtDur60us = 60,
MinAssrtDur1ms = 1000,
MinAssrtDur50ms = 50000,
MinAssrtDur98ms = 98000,
MinAssrtDur500ms = 500000,
MinAssrtDur1s = 1000000,
MinAssrtDur2s = 2000000,
MinAssrtDur3s = 3000000,
MinAssrtDur4s = 4000000,
};
/* Signal Assertion duration values */
struct cfg_assrt_dur {
/* Minimum assertion duration of SLP_A signal */
enum min_assrt_dur slp_a;
/* Minimum assertion duration of SLP_4 signal */
enum min_assrt_dur slp_s4;
/* Minimum assertion duration of SLP_3 signal */
enum min_assrt_dur slp_s3;
/* PCH PM Power Cycle duration */
enum min_assrt_dur pm_pwr_cyc_dur;
};
/* Default value of PchPmPwrCycDur */
#define PCH_PM_PWR_CYC_DUR 4
/*
* Given an enum for PCH_SERIAL_IO_MODE, 1 needs to be subtracted to get the FSP
* UPD expected value for Serial IO since valid enum index starts from 1.
@ -90,93 +58,6 @@ static uint8_t get_param_value(const config_t *config, uint32_t dev_offset)
}
#if CONFIG(SOC_INTEL_COMETLAKE)
static enum min_assrt_dur get_high_asst_width(const struct cfg_assrt_dur *cfg_assrt_dur)
{
enum min_assrt_dur max_assert_dur = cfg_assrt_dur->slp_s4;
if (max_assert_dur < cfg_assrt_dur->slp_s3)
max_assert_dur = cfg_assrt_dur->slp_s3;
if (max_assert_dur < cfg_assrt_dur->slp_a)
max_assert_dur = cfg_assrt_dur->slp_a;
return max_assert_dur;
}
static void get_min_assrt_dur(uint8_t slp_s4_min_asst, uint8_t slp_s3_min_asst,
uint8_t slp_a_min_asst, uint8_t pm_pwr_cyc_dur,
struct cfg_assrt_dur *cfg_assrt_dur)
{
/*
* Ensure slp_x_dur_list[] elements are in sync with devicetree config to FSP encoded
* values.
* slp_s4_asst_dur_list : 1s, 1s, 2s, 3s, 4s(Default)
*/
const enum min_assrt_dur slp_s4_asst_dur_list[] = {
MinAssrtDur1s, MinAssrtDur1s, MinAssrtDur2s, MinAssrtDur3s, MinAssrtDur4s
};
/* slp_s3_asst_dur_list: 50ms, 60us, 50ms (Default), 2s */
const enum min_assrt_dur slp_s3_asst_dur_list[] = {
MinAssrtDur50ms, MinAssrtDur60us, MinAssrtDur50ms, MinAssrtDur2s
};
/* slp_a_asst_dur_list: 2s, 0s, 4s, 98ms, 2s(Default) */
const enum min_assrt_dur slp_a_asst_dur_list[] = {
MinAssrtDur2s, MinAssrtDur0s, MinAssrtDur4s, MinAssrtDur98ms, MinAssrtDur2s
};
/* pm_pwr_cyc_dur_list: 4s(Default), 1s, 2s, 3s, 4s */
const enum min_assrt_dur pm_pwr_cyc_dur_list[] = {
MinAssrtDur4s, MinAssrtDur1s, MinAssrtDur2s, MinAssrtDur3s, MinAssrtDur4s
};
/* Get signal assertion width */
if (slp_s4_min_asst < ARRAY_SIZE(slp_s4_asst_dur_list))
cfg_assrt_dur->slp_s4 = slp_s4_asst_dur_list[slp_s4_min_asst];
if (slp_s3_min_asst < ARRAY_SIZE(slp_s3_asst_dur_list))
cfg_assrt_dur->slp_s3 = slp_s3_asst_dur_list[slp_s3_min_asst];
if (slp_a_min_asst < ARRAY_SIZE(slp_a_asst_dur_list))
cfg_assrt_dur->slp_a = slp_a_asst_dur_list[slp_a_min_asst];
if (pm_pwr_cyc_dur < ARRAY_SIZE(pm_pwr_cyc_dur_list))
cfg_assrt_dur->pm_pwr_cyc_dur = pm_pwr_cyc_dur_list[pm_pwr_cyc_dur];
}
static uint8_t get_pm_pwr_cyc_dur(uint8_t slp_s4_min_asst, uint8_t slp_s3_min_asst,
uint8_t slp_a_min_asst, uint8_t pm_pwr_cyc_dur)
{
/* Sets default minimum asserton duration values */
struct cfg_assrt_dur cfg_assrt_dur = {
.slp_a = MinAssrtDur2s,
.slp_s4 = MinAssrtDur4s,
.slp_s3 = MinAssrtDur50ms,
.pm_pwr_cyc_dur = MinAssrtDur4s
};
enum min_assrt_dur high_asst_width;
/* Convert assertion durations from register-encoded to microseconds */
get_min_assrt_dur(slp_s4_min_asst, slp_s3_min_asst, slp_a_min_asst, pm_pwr_cyc_dur,
&cfg_assrt_dur);
/* Get the higher assertion duration among PCH EDS specified signals for pwr_cyc_dur */
high_asst_width = get_high_asst_width(&cfg_assrt_dur);
if (cfg_assrt_dur.pm_pwr_cyc_dur >= high_asst_width)
return pm_pwr_cyc_dur;
printk(BIOS_DEBUG,
"Set PmPwrCycDur to 4s as configured PmPwrCycDur(%d) violates PCH EDS "
"spec\n", pm_pwr_cyc_dur);
return PCH_PM_PWR_CYC_DUR;
}
static void parse_devicetree_param(const config_t *config, FSP_S_CONFIG *params)
{
uint32_t dev_offset = 0;