soc/intel: Fix chip_info for PCH_DEV_PMC
Since PCH_DEVFN_PMC device is a PCI device that may be hidden from enumeration, use SA_DEVFN_ROOT instead to locate the SOC configuration. Change-Id: I4b5195827fb32ec1dbd0bd6c9e243f4f9a4775ca Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/34327 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Duncan Laurie <dlaurie@chromium.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
3a82e9b8a3
commit
e1559eb84f
4 changed files with 4 additions and 21 deletions
|
@ -56,7 +56,6 @@ static void pch_handle_sideband(config_t *config)
|
||||||
|
|
||||||
static void pch_finalize(void)
|
static void pch_finalize(void)
|
||||||
{
|
{
|
||||||
struct device *dev;
|
|
||||||
uint32_t reg32;
|
uint32_t reg32;
|
||||||
uint8_t *pmcbase;
|
uint8_t *pmcbase;
|
||||||
config_t *config;
|
config_t *config;
|
||||||
|
@ -74,8 +73,7 @@ static void pch_finalize(void)
|
||||||
* point and hence removed from the root bus. pcidev_path_on_root thus
|
* point and hence removed from the root bus. pcidev_path_on_root thus
|
||||||
* returns NULL for PCH_DEV_PMC device.
|
* returns NULL for PCH_DEV_PMC device.
|
||||||
*/
|
*/
|
||||||
dev = SA_DEV_ROOT;
|
config = config_of_path(SA_DEVFN_ROOT);
|
||||||
config = dev->chip_info;
|
|
||||||
pmcbase = pmc_mmio_regs();
|
pmcbase = pmc_mmio_regs();
|
||||||
if (config->PmTimerDisabled) {
|
if (config->PmTimerDisabled) {
|
||||||
reg8 = read8(pmcbase + PCH_PWRM_ACPI_TMR_CTL);
|
reg8 = read8(pmcbase + PCH_PWRM_ACPI_TMR_CTL);
|
||||||
|
|
|
@ -175,14 +175,7 @@ uintptr_t soc_read_pmc_base(void)
|
||||||
void soc_get_gpi_gpe_configs(uint8_t *dw0, uint8_t *dw1, uint8_t *dw2)
|
void soc_get_gpi_gpe_configs(uint8_t *dw0, uint8_t *dw1, uint8_t *dw2)
|
||||||
{
|
{
|
||||||
DEVTREE_CONST struct soc_intel_cannonlake_config *config;
|
DEVTREE_CONST struct soc_intel_cannonlake_config *config;
|
||||||
|
config = config_of_path(SA_DEVFN_ROOT);
|
||||||
/* Look up the device in devicetree */
|
|
||||||
DEVTREE_CONST struct device *dev = pcidev_path_on_root(PCH_DEVFN_PMC);
|
|
||||||
if (!dev || !dev->chip_info) {
|
|
||||||
printk(BIOS_ERR, "BUG! Could not find SOC devicetree config\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
config = dev->chip_info;
|
|
||||||
|
|
||||||
/* Assign to out variable */
|
/* Assign to out variable */
|
||||||
*dw0 = config->gpe0_dw0;
|
*dw0 = config->gpe0_dw0;
|
||||||
|
|
|
@ -54,7 +54,6 @@ static void pch_handle_sideband(config_t *config)
|
||||||
|
|
||||||
static void pch_finalize(void)
|
static void pch_finalize(void)
|
||||||
{
|
{
|
||||||
struct device *dev;
|
|
||||||
uint32_t reg32;
|
uint32_t reg32;
|
||||||
uint8_t *pmcbase;
|
uint8_t *pmcbase;
|
||||||
config_t *config;
|
config_t *config;
|
||||||
|
@ -74,8 +73,7 @@ static void pch_finalize(void)
|
||||||
* point and hence removed from the root bus. pcidev_path_on_root thus
|
* point and hence removed from the root bus. pcidev_path_on_root thus
|
||||||
* returns NULL for PCH_DEV_PMC device.
|
* returns NULL for PCH_DEV_PMC device.
|
||||||
*/
|
*/
|
||||||
dev = SA_DEV_ROOT;
|
config = config_of_path(SA_DEVFN_ROOT);
|
||||||
config = dev->chip_info;
|
|
||||||
pmcbase = pmc_mmio_regs();
|
pmcbase = pmc_mmio_regs();
|
||||||
if (config->PmTimerDisabled) {
|
if (config->PmTimerDisabled) {
|
||||||
reg8 = read8(pmcbase + PCH_PWRM_ACPI_TMR_CTL);
|
reg8 = read8(pmcbase + PCH_PWRM_ACPI_TMR_CTL);
|
||||||
|
|
|
@ -174,13 +174,7 @@ void soc_get_gpi_gpe_configs(uint8_t *dw0, uint8_t *dw1, uint8_t *dw2)
|
||||||
{
|
{
|
||||||
DEVTREE_CONST struct soc_intel_icelake_config *config;
|
DEVTREE_CONST struct soc_intel_icelake_config *config;
|
||||||
|
|
||||||
/* Look up the device in devicetree */
|
config = config_of_path(SA_DEVFN_ROOT);
|
||||||
DEVTREE_CONST struct device *dev = pcidev_path_on_root(PCH_DEVFN_PMC);
|
|
||||||
if (!dev || !dev->chip_info) {
|
|
||||||
printk(BIOS_ERR, "BUG! Could not find SOC devicetree config\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
config = dev->chip_info;
|
|
||||||
|
|
||||||
/* Assign to out variable */
|
/* Assign to out variable */
|
||||||
*dw0 = config->gpe0_dw0;
|
*dw0 = config->gpe0_dw0;
|
||||||
|
|
Loading…
Reference in a new issue