soc/amd/stoneyridge: Remove dev_find_slot where possible
The procedure dev_find_slot has 3 main uses. To find configuration (devicetree), to verify if a particular device is enabled at build \ time, and to get the address for PCI access while in bootblock/romstage. The third use can be hidden by using macros defined in pci_devs.h, making it very clear what PCI device is being accessed. replace the temporary pointers to device used with PCI access with SOC_XXX_DEV where XXX is the device being accessed, and remove the setting of the temporary pointers. BUG=b:117917136 TEST=Build grunt. Change-Id: Ic38ea04bfcc1ccaa12937b19e9442a26d869ef11 Signed-off-by: Richard Spiegel <richard.spiegel@silverbackltd.com> Reviewed-on: https://review.coreboot.org/29227 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com>
This commit is contained in:
parent
58bf3e7632
commit
41baf0c3ff
4 changed files with 24 additions and 30 deletions
|
@ -55,8 +55,8 @@ static void pre_mp_init(void)
|
||||||
|
|
||||||
static int get_cpu_count(void)
|
static int get_cpu_count(void)
|
||||||
{
|
{
|
||||||
struct device *nb = dev_find_slot(0, HT_DEVFN);
|
return (pci_read_config16(SOC_NB_DEV, D18F0_CPU_CNT) & CPU_CNT_MASK)
|
||||||
return (pci_read_config16(nb, D18F0_CPU_CNT) & CPU_CNT_MASK) + 1;
|
+ 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void get_smm_info(uintptr_t *perm_smbase, size_t *perm_smsize,
|
static void get_smm_info(uintptr_t *perm_smbase, size_t *perm_smsize,
|
||||||
|
|
|
@ -38,32 +38,30 @@ static void lpc_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u8 byte;
|
u8 byte;
|
||||||
u32 dword;
|
u32 dword;
|
||||||
struct device *sm_dev;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable the LPC Controller
|
* Enable the LPC Controller
|
||||||
* SMBus register 0x64 is not defined in public datasheet.
|
* SMBus register 0x64 is not defined in public datasheet.
|
||||||
*/
|
*/
|
||||||
sm_dev = dev_find_slot(0, SMBUS_DEVFN);
|
dword = pci_read_config32(SOC_SMBUS_DEV, 0x64);
|
||||||
dword = pci_read_config32(sm_dev, 0x64);
|
|
||||||
dword |= 1 << 20;
|
dword |= 1 << 20;
|
||||||
pci_write_config32(sm_dev, 0x64, dword);
|
pci_write_config32(SOC_SMBUS_DEV, 0x64, dword);
|
||||||
|
|
||||||
/* Initialize isa dma */
|
/* Initialize isa dma */
|
||||||
isa_dma_init();
|
isa_dma_init();
|
||||||
|
|
||||||
/* Enable DMA transaction on the LPC bus */
|
/* Enable DMA transaction on the LPC bus */
|
||||||
byte = pci_read_config8(dev, LPC_PCI_CONTROL);
|
byte = pci_read_config8(SOC_SMBUS_DEV, LPC_PCI_CONTROL);
|
||||||
byte |= LEGACY_DMA_EN;
|
byte |= LEGACY_DMA_EN;
|
||||||
pci_write_config8(dev, LPC_PCI_CONTROL, byte);
|
pci_write_config8(SOC_SMBUS_DEV, LPC_PCI_CONTROL, byte);
|
||||||
|
|
||||||
/* Disable the timeout mechanism on LPC */
|
/* Disable the timeout mechanism on LPC */
|
||||||
byte = pci_read_config8(dev, LPC_IO_OR_MEM_DECODE_ENABLE);
|
byte = pci_read_config8(SOC_SMBUS_DEV, LPC_IO_OR_MEM_DECODE_ENABLE);
|
||||||
byte &= ~LPC_SYNC_TIMEOUT_COUNT_ENABLE;
|
byte &= ~LPC_SYNC_TIMEOUT_COUNT_ENABLE;
|
||||||
pci_write_config8(dev, LPC_IO_OR_MEM_DECODE_ENABLE, byte);
|
pci_write_config8(SOC_SMBUS_DEV, LPC_IO_OR_MEM_DECODE_ENABLE, byte);
|
||||||
|
|
||||||
/* Disable LPC MSI Capability */
|
/* Disable LPC MSI Capability */
|
||||||
byte = pci_read_config8(dev, LPC_MISC_CONTROL_BITS);
|
byte = pci_read_config8(SOC_SMBUS_DEV, LPC_MISC_CONTROL_BITS);
|
||||||
/* BIT 1 is not defined in public datasheet. */
|
/* BIT 1 is not defined in public datasheet. */
|
||||||
byte &= ~(1 << 1);
|
byte &= ~(1 << 1);
|
||||||
|
|
||||||
|
@ -73,15 +71,15 @@ static void lpc_init(struct device *dev)
|
||||||
* interrupt and visit LPC.
|
* interrupt and visit LPC.
|
||||||
*/
|
*/
|
||||||
byte &= ~LPC_NOHOG;
|
byte &= ~LPC_NOHOG;
|
||||||
pci_write_config8(dev, LPC_MISC_CONTROL_BITS, byte);
|
pci_write_config8(SOC_SMBUS_DEV, LPC_MISC_CONTROL_BITS, byte);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable hand-instance of the pulse generator and SPI
|
* Enable hand-instance of the pulse generator and SPI
|
||||||
* controller prefetch of flash.
|
* controller prefetch of flash.
|
||||||
*/
|
*/
|
||||||
byte = pci_read_config8(dev, LPC_HOST_CONTROL);
|
byte = pci_read_config8(SOC_SMBUS_DEV, LPC_HOST_CONTROL);
|
||||||
byte |= PREFETCH_EN_SPI_FROM_HOST | T_START_ENH;
|
byte |= PREFETCH_EN_SPI_FROM_HOST | T_START_ENH;
|
||||||
pci_write_config8(dev, LPC_HOST_CONTROL, byte);
|
pci_write_config8(SOC_SMBUS_DEV, LPC_HOST_CONTROL, byte);
|
||||||
|
|
||||||
cmos_check_update_date();
|
cmos_check_update_date();
|
||||||
|
|
||||||
|
|
|
@ -48,27 +48,25 @@ static void set_io_addr_reg(struct device *dev, u32 nodeid, u32 linkn, u32 reg,
|
||||||
u32 io_min, u32 io_max)
|
u32 io_min, u32 io_max)
|
||||||
{
|
{
|
||||||
u32 tempreg;
|
u32 tempreg;
|
||||||
struct device *addr_map = dev_find_slot(0, ADDR_DEVFN);
|
|
||||||
|
|
||||||
/* io range allocation. Limit */
|
/* io range allocation. Limit */
|
||||||
tempreg = (nodeid & 0xf) | ((nodeid & 0x30) << (8 - 4)) | (linkn << 4)
|
tempreg = (nodeid & 0xf) | ((nodeid & 0x30) << (8 - 4)) | (linkn << 4)
|
||||||
| ((io_max & 0xf0) << (12 - 4));
|
| ((io_max & 0xf0) << (12 - 4));
|
||||||
pci_write_config32(addr_map, reg + 4, tempreg);
|
pci_write_config32(SOC_ADDR_DEV, reg + 4, tempreg);
|
||||||
tempreg = 3 | ((io_min & 0xf0) << (12 - 4)); /* base: ISA and VGA ? */
|
tempreg = 3 | ((io_min & 0xf0) << (12 - 4)); /* base: ISA and VGA ? */
|
||||||
pci_write_config32(addr_map, reg, tempreg);
|
pci_write_config32(SOC_ADDR_DEV, reg, tempreg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_mmio_addr_reg(u32 nodeid, u32 linkn, u32 reg, u32 index,
|
static void set_mmio_addr_reg(u32 nodeid, u32 linkn, u32 reg, u32 index,
|
||||||
u32 mmio_min, u32 mmio_max)
|
u32 mmio_min, u32 mmio_max)
|
||||||
{
|
{
|
||||||
u32 tempreg;
|
u32 tempreg;
|
||||||
struct device *addr_map = dev_find_slot(0, ADDR_DEVFN);
|
|
||||||
|
|
||||||
/* io range allocation. Limit */
|
/* io range allocation. Limit */
|
||||||
tempreg = (nodeid & 0xf) | (linkn << 4) | (mmio_max & 0xffffff00);
|
tempreg = (nodeid & 0xf) | (linkn << 4) | (mmio_max & 0xffffff00);
|
||||||
pci_write_config32(addr_map, reg + 4, tempreg);
|
pci_write_config32(SOC_ADDR_DEV, reg + 4, tempreg);
|
||||||
tempreg = 3 | (nodeid & 0x30) | (mmio_min & 0xffffff00);
|
tempreg = 3 | (nodeid & 0x30) | (mmio_min & 0xffffff00);
|
||||||
pci_write_config32(addr_map, reg, tempreg);
|
pci_write_config32(SOC_ADDR_DEV, reg, tempreg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void read_resources(struct device *dev)
|
static void read_resources(struct device *dev)
|
||||||
|
@ -154,7 +152,7 @@ static void create_vga_resource(struct device *dev)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "VGA: %s has VGA device\n", dev_path(dev));
|
printk(BIOS_DEBUG, "VGA: %s has VGA device\n", dev_path(dev));
|
||||||
/* Route A0000-BFFFF, IO 3B0-3BB 3C0-3DF */
|
/* Route A0000-BFFFF, IO 3B0-3BB 3C0-3DF */
|
||||||
pci_write_config32(dev_find_slot(0, ADDR_DEVFN), 0xf4, 1);
|
pci_write_config32(SOC_ADDR_DEV, D18F1_VGAEN, VGA_ADDR_ENABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_resources(struct device *dev)
|
static void set_resources(struct device *dev)
|
||||||
|
@ -379,17 +377,16 @@ void amd_initcpuio(void)
|
||||||
|
|
||||||
void fam15_finalize(void *chip_info)
|
void fam15_finalize(void *chip_info)
|
||||||
{
|
{
|
||||||
struct device *dev;
|
|
||||||
u32 value;
|
u32 value;
|
||||||
dev = dev_find_slot(0, GNB_DEVFN); /* clear IoapicSbFeatureEn */
|
|
||||||
pci_write_config32(dev, 0xf8, 0);
|
/* TODO: move IOAPIC code to dsdt.asl */
|
||||||
pci_write_config32(dev, 0xfc, 5); /* TODO: move it to dsdt.asl */
|
pci_write_config32(SOC_GNB_DEV, NB_IOAPIC_INDEX, 0);
|
||||||
|
pci_write_config32(SOC_GNB_DEV, NB_IOAPIC_DATA, 5);
|
||||||
|
|
||||||
/* disable No Snoop */
|
/* disable No Snoop */
|
||||||
dev = dev_find_slot(0, HDA0_DEVFN);
|
value = pci_read_config32(SOC_HDA0_DEV, HDA_DEV_CTRL_STATUS);
|
||||||
value = pci_read_config32(dev, HDA_DEV_CTRL_STATUS);
|
|
||||||
value &= ~HDA_NO_SNOOP_EN;
|
value &= ~HDA_NO_SNOOP_EN;
|
||||||
pci_write_config32(dev, HDA_DEV_CTRL_STATUS, value);
|
pci_write_config32(SOC_HDA0_DEV, HDA_DEV_CTRL_STATUS, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void domain_read_resources(struct device *dev)
|
void domain_read_resources(struct device *dev)
|
||||||
|
|
|
@ -892,7 +892,7 @@ static void set_sb_final_nvs(void)
|
||||||
uintptr_t xhci_fw;
|
uintptr_t xhci_fw;
|
||||||
uintptr_t fwaddr;
|
uintptr_t fwaddr;
|
||||||
size_t fwsize;
|
size_t fwsize;
|
||||||
const struct device *sd, *sata, *ehci;
|
const struct device *sd, *sata;
|
||||||
|
|
||||||
struct global_nvs_t *gnvs = cbmem_find(CBMEM_ID_ACPI_GNVS);
|
struct global_nvs_t *gnvs = cbmem_find(CBMEM_ID_ACPI_GNVS);
|
||||||
if (gnvs == NULL)
|
if (gnvs == NULL)
|
||||||
|
@ -925,7 +925,6 @@ static void set_sb_final_nvs(void)
|
||||||
gnvs->fw02 = fwaddr + XHCI_FW_BOOTRAM_SIZE;
|
gnvs->fw02 = fwaddr + XHCI_FW_BOOTRAM_SIZE;
|
||||||
gnvs->fw03 = fwsize << 16;
|
gnvs->fw03 = fwsize << 16;
|
||||||
|
|
||||||
ehci = dev_find_slot(0, EHCI1_DEVFN);
|
|
||||||
gnvs->eh10 = pci_read_config32(SOC_EHCI1_DEV, PCI_BASE_ADDRESS_0)
|
gnvs->eh10 = pci_read_config32(SOC_EHCI1_DEV, PCI_BASE_ADDRESS_0)
|
||||||
& ~PCI_BASE_ADDRESS_MEM_ATTR_MASK;
|
& ~PCI_BASE_ADDRESS_MEM_ATTR_MASK;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue