nb/intel: Fix 16-bit read/write PCI_COMMAND register
Change-Id: I7c7fb10308a6fcd1ead292c53ed03ddc693f6f15 Signed-off-by: Elyes HAOUAS <ehaouas@noos.fr> Reviewed-on: https://review.coreboot.org/c/coreboot/+/40835 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Nico Huber <nico.h@gmx.de>
This commit is contained in:
parent
b30fe36734
commit
5ac723e5a4
4 changed files with 6 additions and 19 deletions
|
@ -36,17 +36,16 @@ void init_iommu()
|
||||||
const pci_devfn_t igd = PCI_DEV(0, 2, 0);
|
const pci_devfn_t igd = PCI_DEV(0, 2, 0);
|
||||||
|
|
||||||
/* setup somewhere */
|
/* setup somewhere */
|
||||||
u8 cmd = pci_read_config8(igd, PCI_COMMAND);
|
pci_or_config16(igd, PCI_COMMAND, PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY);
|
||||||
cmd |= PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY;
|
|
||||||
pci_write_config8(igd, PCI_COMMAND, cmd);
|
|
||||||
void *bar = (void *)pci_read_config32(igd, PCI_BASE_ADDRESS_0);
|
void *bar = (void *)pci_read_config32(igd, PCI_BASE_ADDRESS_0);
|
||||||
|
|
||||||
/* clear GTT, 2MB is enough (and should be safe) */
|
/* clear GTT, 2MB is enough (and should be safe) */
|
||||||
memset(bar, 0, 2<<20);
|
memset(bar, 0, 2<<20);
|
||||||
|
|
||||||
/* and now disable again */
|
/* and now disable again */
|
||||||
|
u16 cmd = pci_read_config8(igd, PCI_COMMAND);
|
||||||
cmd &= ~(PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY);
|
cmd &= ~(PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY);
|
||||||
pci_write_config8(igd, PCI_COMMAND, cmd);
|
pci_write_config16(igd, PCI_COMMAND, cmd);
|
||||||
pci_write_config32(igd, PCI_BASE_ADDRESS_0, 0);
|
pci_write_config32(igd, PCI_BASE_ADDRESS_0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -178,14 +178,10 @@ static void mch_domain_set_resources(struct device *dev)
|
||||||
|
|
||||||
static void mch_domain_init(struct device *dev)
|
static void mch_domain_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u32 reg32;
|
|
||||||
|
|
||||||
struct device *mch = pcidev_on_root(0, 0);
|
struct device *mch = pcidev_on_root(0, 0);
|
||||||
|
|
||||||
/* Enable SERR */
|
/* Enable SERR */
|
||||||
reg32 = pci_read_config32(mch, PCI_COMMAND);
|
pci_or_config16(mch, PCI_COMMAND, PCI_COMMAND_SERR);
|
||||||
reg32 |= PCI_COMMAND_SERR;
|
|
||||||
pci_write_config32(mch, PCI_COMMAND, reg32);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *northbridge_acpi_name(const struct device *dev)
|
static const char *northbridge_acpi_name(const struct device *dev)
|
||||||
|
|
|
@ -147,12 +147,8 @@ static void mch_domain_set_resources(struct device *dev)
|
||||||
|
|
||||||
static void mch_domain_init(struct device *dev)
|
static void mch_domain_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u32 reg32;
|
|
||||||
|
|
||||||
/* Enable SERR */
|
/* Enable SERR */
|
||||||
reg32 = pci_read_config32(dev, PCI_COMMAND);
|
pci_or_config16(dev, PCI_COMMAND, PCI_COMMAND_SERR);
|
||||||
reg32 |= PCI_COMMAND_SERR;
|
|
||||||
pci_write_config32(dev, PCI_COMMAND, reg32);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *northbridge_acpi_name(const struct device *dev)
|
static const char *northbridge_acpi_name(const struct device *dev)
|
||||||
|
|
|
@ -131,12 +131,8 @@ static void mch_domain_set_resources(struct device *dev)
|
||||||
|
|
||||||
static void mch_domain_init(struct device *dev)
|
static void mch_domain_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u32 reg32;
|
|
||||||
|
|
||||||
/* Enable SERR */
|
/* Enable SERR */
|
||||||
reg32 = pci_read_config32(dev, PCI_COMMAND);
|
pci_or_config16(dev, PCI_COMMAND, PCI_COMMAND_SERR);
|
||||||
reg32 |= PCI_COMMAND_SERR;
|
|
||||||
pci_write_config32(dev, PCI_COMMAND, reg32);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *northbridge_acpi_name(const struct device *dev)
|
static const char *northbridge_acpi_name(const struct device *dev)
|
||||||
|
|
Loading…
Reference in a new issue