soc/intel/common/block/p2sb: Add helper function to enable BAR

This patch creates a new helper function to enable P2SB BAR.

`p2sb_dev_enable_bar()` takes the PCI P2SB device address (B/D/F)
and BAR address (combining high and low base addresses).

BUG=b:224325352
TEST=Able to build and boot brya.

Signed-off-by: Subrata Banik <subratabanik@google.com>
Change-Id: Ica41e8e8bdfcfe855e730b3878b874070062ef93
Reviewed-on: https://review.coreboot.org/c/coreboot/+/62778
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Eric Lai <eric_lai@quanta.corp-partner.google.com>
Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
Reviewed-by: Felix Held <felix-coreboot@felixheld.de>
Reviewed-by: Wonkyu Kim <wonkyu.kim@intel.com>
This commit is contained in:
Subrata Banik 2022-03-14 12:47:31 +05:30
parent 9b6e851e5b
commit 7c477a9d1a
4 changed files with 14 additions and 7 deletions

View File

@ -10,6 +10,7 @@
#define P2SBC 0xe0 #define P2SBC 0xe0
#define P2SBC_HIDE_BIT (1 << 0) #define P2SBC_HIDE_BIT (1 << 0)
void p2sb_dev_enable_bar(pci_devfn_t dev, uint64_t bar);
bool p2sb_dev_is_hidden(pci_devfn_t dev); bool p2sb_dev_is_hidden(pci_devfn_t dev);
void p2sb_dev_unhide(pci_devfn_t dev); void p2sb_dev_unhide(pci_devfn_t dev);
void p2sb_dev_hide(pci_devfn_t dev); void p2sb_dev_hide(pci_devfn_t dev);

View File

@ -1,3 +1,5 @@
bootblock-$(CONFIG_SOC_INTEL_COMMON_BLOCK_BASE_P2SB) += p2sblib.c
romstage-$(CONFIG_SOC_INTEL_COMMON_BLOCK_BASE_P2SB) += p2sblib.c
ramstage-$(CONFIG_SOC_INTEL_COMMON_BLOCK_BASE_P2SB) += p2sblib.c ramstage-$(CONFIG_SOC_INTEL_COMMON_BLOCK_BASE_P2SB) += p2sblib.c
smm-$(CONFIG_SOC_INTEL_COMMON_BLOCK_BASE_P2SB) += p2sblib.c smm-$(CONFIG_SOC_INTEL_COMMON_BLOCK_BASE_P2SB) += p2sblib.c

View File

@ -18,13 +18,7 @@
void p2sb_enable_bar(void) void p2sb_enable_bar(void)
{ {
/* Enable PCR Base address in PCH */ p2sb_dev_enable_bar(PCH_DEV_P2SB, P2SB_BAR);
pci_write_config32(PCH_DEV_P2SB, PCI_BASE_ADDRESS_0, P2SB_BAR);
pci_write_config32(PCH_DEV_P2SB, PCI_BASE_ADDRESS_1, 0);
/* Enable P2SB MSE */
pci_write_config16(PCH_DEV_P2SB, PCI_COMMAND,
PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY);
} }
/* /*

View File

@ -10,6 +10,16 @@
#include <intelblocks/pcr.h> #include <intelblocks/pcr.h>
#include <soc/pci_devs.h> #include <soc/pci_devs.h>
void p2sb_dev_enable_bar(pci_devfn_t dev, uint64_t bar)
{
/* Enable PCR Base addresses */
pci_write_config32(dev, PCI_BASE_ADDRESS_0, (uint32_t)bar);
pci_write_config32(dev, PCI_BASE_ADDRESS_1, (uint32_t)(bar >> 32));
/* Enable P2SB MSE */
pci_write_config16(dev, PCI_COMMAND, PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY);
}
bool p2sb_dev_is_hidden(pci_devfn_t dev) bool p2sb_dev_is_hidden(pci_devfn_t dev)
{ {
const uint16_t pci_vid = pci_read_config16(dev, PCI_VENDOR_ID); const uint16_t pci_vid = pci_read_config16(dev, PCI_VENDOR_ID);