Add pci_devfn_t and use with __SIMPLE_DEVICE__

Declare the functions that may be used in both romstage and ramstage
with simple device model. This will later allow to define PCI access
functions for ramstage using the inlined functions from romstage.

Change-Id: I32ff622883ceee4628e6b1b01023b970e379113f
Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com>
Reviewed-on: http://review.coreboot.org/3508
Tested-by: build bot (Jenkins)
Reviewed-by: Aaron Durbin <adurbin@google.com>
This commit is contained in:
Kyösti Mälkki 2013-06-20 20:25:21 +03:00
parent a2adaeb68c
commit 3f9a62e5ad
16 changed files with 45 additions and 38 deletions

View file

@ -210,7 +210,10 @@ static inline int log2f(int value)
#define PNP_DEV(PORT, FUNC) (((PORT) << 8) | (FUNC)) #define PNP_DEV(PORT, FUNC) (((PORT) << 8) | (FUNC))
typedef unsigned device_t; /* pci and pci_mmio need to have different ways to have dev */ /* FIXME: Sources for romstage still use device_t. */
typedef u32 device_t;
typedef u32 pci_devfn_t;
/* FIXME: We need to make the coreboot to run at 64bit mode, So when read/write memory above 4G, /* FIXME: We need to make the coreboot to run at 64bit mode, So when read/write memory above 4G,
* We don't need to set %fs, and %gs anymore * We don't need to set %fs, and %gs anymore
@ -220,23 +223,26 @@ typedef unsigned device_t; /* pci and pci_mmio need to have different ways to ha
#include <arch/pci_io_cfg.h> #include <arch/pci_io_cfg.h>
#include <arch/pci_mmio_cfg.h> #include <arch/pci_mmio_cfg.h>
static inline __attribute__((always_inline)) void pci_or_config8(device_t dev, unsigned where, uint8_t value) static inline __attribute__((always_inline))
void pci_or_config8(pci_devfn_t dev, unsigned where, uint8_t value)
{ {
pci_write_config8(dev, where, pci_read_config8(dev, where) | value); pci_write_config8(dev, where, pci_read_config8(dev, where) | value);
} }
static inline __attribute__((always_inline)) void pci_or_config16(device_t dev, unsigned where, uint16_t value) static inline __attribute__((always_inline))
void pci_or_config16(pci_devfn_t dev, unsigned where, uint16_t value)
{ {
pci_write_config16(dev, where, pci_read_config16(dev, where) | value); pci_write_config16(dev, where, pci_read_config16(dev, where) | value);
} }
static inline __attribute__((always_inline)) void pci_or_config32(device_t dev, unsigned where, uint32_t value) static inline __attribute__((always_inline))
void pci_or_config32(pci_devfn_t dev, unsigned where, uint32_t value)
{ {
pci_write_config32(dev, where, pci_read_config32(dev, where) | value); pci_write_config32(dev, where, pci_read_config32(dev, where) | value);
} }
#define PCI_DEV_INVALID (0xffffffffU) #define PCI_DEV_INVALID (0xffffffffU)
static inline device_t pci_io_locate_device(unsigned pci_id, device_t dev) static inline pci_devfn_t pci_io_locate_device(unsigned pci_id, pci_devfn_t dev)
{ {
for(; dev <= PCI_DEV(255, 31, 7); dev += PCI_DEV(0,0,1)) { for(; dev <= PCI_DEV(255, 31, 7); dev += PCI_DEV(0,0,1)) {
unsigned int id; unsigned int id;
@ -248,7 +254,7 @@ static inline device_t pci_io_locate_device(unsigned pci_id, device_t dev)
return PCI_DEV_INVALID; return PCI_DEV_INVALID;
} }
static inline device_t pci_locate_device(unsigned pci_id, device_t dev) static inline pci_devfn_t pci_locate_device(unsigned pci_id, pci_devfn_t dev)
{ {
for(; dev <= PCI_DEV(255|(((1<<CONFIG_PCI_BUS_SEGN_BITS)-1)<<8), 31, 7); dev += PCI_DEV(0,0,1)) { for(; dev <= PCI_DEV(255|(((1<<CONFIG_PCI_BUS_SEGN_BITS)-1)<<8), 31, 7); dev += PCI_DEV(0,0,1)) {
unsigned int id; unsigned int id;
@ -260,9 +266,9 @@ static inline device_t pci_locate_device(unsigned pci_id, device_t dev)
return PCI_DEV_INVALID; return PCI_DEV_INVALID;
} }
static inline device_t pci_locate_device_on_bus(unsigned pci_id, unsigned bus) static inline pci_devfn_t pci_locate_device_on_bus(unsigned pci_id, unsigned bus)
{ {
device_t dev, last; pci_devfn_t dev, last;
dev = PCI_DEV(bus, 0, 0); dev = PCI_DEV(bus, 0, 0);
last = PCI_DEV(bus, 31, 7); last = PCI_DEV(bus, 31, 7);

View file

@ -21,7 +21,7 @@
#include <arch/io.h> #include <arch/io.h>
static inline __attribute__((always_inline)) static inline __attribute__((always_inline))
uint8_t pci_io_read_config8(device_t dev, unsigned where) uint8_t pci_io_read_config8(pci_devfn_t dev, unsigned where)
{ {
unsigned addr; unsigned addr;
#if !CONFIG_PCI_IO_CFG_EXT #if !CONFIG_PCI_IO_CFG_EXT
@ -34,7 +34,7 @@ uint8_t pci_io_read_config8(device_t dev, unsigned where)
} }
static inline __attribute__((always_inline)) static inline __attribute__((always_inline))
uint16_t pci_io_read_config16(device_t dev, unsigned where) uint16_t pci_io_read_config16(pci_devfn_t dev, unsigned where)
{ {
unsigned addr; unsigned addr;
#if !CONFIG_PCI_IO_CFG_EXT #if !CONFIG_PCI_IO_CFG_EXT
@ -47,7 +47,7 @@ uint16_t pci_io_read_config16(device_t dev, unsigned where)
} }
static inline __attribute__((always_inline)) static inline __attribute__((always_inline))
uint32_t pci_io_read_config32(device_t dev, unsigned where) uint32_t pci_io_read_config32(pci_devfn_t dev, unsigned where)
{ {
unsigned addr; unsigned addr;
#if !CONFIG_PCI_IO_CFG_EXT #if !CONFIG_PCI_IO_CFG_EXT
@ -60,7 +60,7 @@ uint32_t pci_io_read_config32(device_t dev, unsigned where)
} }
static inline __attribute__((always_inline)) static inline __attribute__((always_inline))
void pci_io_write_config8(device_t dev, unsigned where, uint8_t value) void pci_io_write_config8(pci_devfn_t dev, unsigned where, uint8_t value)
{ {
unsigned addr; unsigned addr;
#if !CONFIG_PCI_IO_CFG_EXT #if !CONFIG_PCI_IO_CFG_EXT
@ -73,7 +73,7 @@ void pci_io_write_config8(device_t dev, unsigned where, uint8_t value)
} }
static inline __attribute__((always_inline)) static inline __attribute__((always_inline))
void pci_io_write_config16(device_t dev, unsigned where, uint16_t value) void pci_io_write_config16(pci_devfn_t dev, unsigned where, uint16_t value)
{ {
unsigned addr; unsigned addr;
#if !CONFIG_PCI_IO_CFG_EXT #if !CONFIG_PCI_IO_CFG_EXT
@ -86,7 +86,7 @@ void pci_io_write_config16(device_t dev, unsigned where, uint16_t value)
} }
static inline __attribute__((always_inline)) static inline __attribute__((always_inline))
void pci_io_write_config32(device_t dev, unsigned where, uint32_t value) void pci_io_write_config32(pci_devfn_t dev, unsigned where, uint32_t value)
{ {
unsigned addr; unsigned addr;
#if !CONFIG_PCI_IO_CFG_EXT #if !CONFIG_PCI_IO_CFG_EXT

View file

@ -26,7 +26,7 @@
#define DEFAULT_PCIEXBAR CONFIG_MMCONF_BASE_ADDRESS #define DEFAULT_PCIEXBAR CONFIG_MMCONF_BASE_ADDRESS
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
u8 pcie_read_config8(device_t dev, unsigned int where) u8 pcie_read_config8(pci_devfn_t dev, unsigned int where)
{ {
unsigned long addr; unsigned long addr;
addr = DEFAULT_PCIEXBAR | dev | where; addr = DEFAULT_PCIEXBAR | dev | where;
@ -34,7 +34,7 @@ u8 pcie_read_config8(device_t dev, unsigned int where)
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
u16 pcie_read_config16(device_t dev, unsigned int where) u16 pcie_read_config16(pci_devfn_t dev, unsigned int where)
{ {
unsigned long addr; unsigned long addr;
addr = DEFAULT_PCIEXBAR | dev | (where & ~1); addr = DEFAULT_PCIEXBAR | dev | (where & ~1);
@ -42,7 +42,7 @@ u16 pcie_read_config16(device_t dev, unsigned int where)
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
u32 pcie_read_config32(device_t dev, unsigned int where) u32 pcie_read_config32(pci_devfn_t dev, unsigned int where)
{ {
unsigned long addr; unsigned long addr;
addr = DEFAULT_PCIEXBAR | dev | (where & ~3); addr = DEFAULT_PCIEXBAR | dev | (where & ~3);
@ -50,7 +50,7 @@ u32 pcie_read_config32(device_t dev, unsigned int where)
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
void pcie_write_config8(device_t dev, unsigned int where, u8 value) void pcie_write_config8(pci_devfn_t dev, unsigned int where, u8 value)
{ {
unsigned long addr; unsigned long addr;
addr = DEFAULT_PCIEXBAR | dev | where; addr = DEFAULT_PCIEXBAR | dev | where;
@ -58,7 +58,7 @@ void pcie_write_config8(device_t dev, unsigned int where, u8 value)
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
void pcie_write_config16(device_t dev, unsigned int where, u16 value) void pcie_write_config16(pci_devfn_t dev, unsigned int where, u16 value)
{ {
unsigned long addr; unsigned long addr;
addr = DEFAULT_PCIEXBAR | dev | (where & ~1); addr = DEFAULT_PCIEXBAR | dev | (where & ~1);
@ -66,7 +66,7 @@ void pcie_write_config16(device_t dev, unsigned int where, u16 value)
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
void pcie_write_config32(device_t dev, unsigned int where, u32 value) void pcie_write_config32(pci_devfn_t dev, unsigned int where, u32 value)
{ {
unsigned long addr; unsigned long addr;
addr = DEFAULT_PCIEXBAR | dev | (where & ~3); addr = DEFAULT_PCIEXBAR | dev | (where & ~3);
@ -74,21 +74,21 @@ void pcie_write_config32(device_t dev, unsigned int where, u32 value)
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
void pcie_or_config8(device_t dev, unsigned int where, u8 ormask) void pcie_or_config8(pci_devfn_t dev, unsigned int where, u8 ormask)
{ {
u8 value = pcie_read_config8(dev, where); u8 value = pcie_read_config8(dev, where);
pcie_write_config8(dev, where, value | ormask); pcie_write_config8(dev, where, value | ormask);
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
void pcie_or_config16(device_t dev, unsigned int where, u16 ormask) void pcie_or_config16(pci_devfn_t dev, unsigned int where, u16 ormask)
{ {
u16 value = pcie_read_config16(dev, where); u16 value = pcie_read_config16(dev, where);
pcie_write_config16(dev, where, value | ormask); pcie_write_config16(dev, where, value | ormask);
} }
static inline __attribute__ ((always_inline)) static inline __attribute__ ((always_inline))
void pcie_or_config32(device_t dev, unsigned int where, u32 ormask) void pcie_or_config32(pci_devfn_t dev, unsigned int where, u32 ormask)
{ {
u32 value = pcie_read_config32(dev, where); u32 value = pcie_read_config32(dev, where);
pcie_write_config32(dev, where, value | ormask); pcie_write_config32(dev, where, value | ormask);

View file

@ -11,6 +11,7 @@ struct device;
#ifndef __SIMPLE_DEVICE__ #ifndef __SIMPLE_DEVICE__
typedef struct device * device_t; typedef struct device * device_t;
typedef u32 pci_devfn_t;
struct pci_operations; struct pci_operations;
struct pci_bus_operations; struct pci_bus_operations;
struct smbus_bus_operations; struct smbus_bus_operations;

View file

@ -85,7 +85,7 @@ u32 decode_igd_gtt_size(const u32 gsm)
u32 get_top_of_ram(void) u32 get_top_of_ram(void)
{ {
const device_t dev = PCI_DEV(0, 0, 0); const pci_devfn_t dev = PCI_DEV(0, 0, 0);
u32 tor; u32 tor;

View file

@ -36,7 +36,7 @@ static inline void set_bios_reset(void)
{ {
u32 nodes; u32 nodes;
u32 htic; u32 htic;
device_t dev; pci_devfn_t dev;
int i; int i;
nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1; nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1;

View file

@ -36,7 +36,7 @@ static inline void set_bios_reset(void)
{ {
u32 nodes; u32 nodes;
u32 htic; u32 htic;
device_t dev; pci_devfn_t dev;
int i; int i;
nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1; nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1;

View file

@ -36,7 +36,7 @@
*/ */
u32 get_sbdn(u32 bus) u32 get_sbdn(u32 bus)
{ {
device_t dev; pci_devfn_t dev;
printk(BIOS_SPEW, "SB900 - Early.c - get_sbdn - Start.\n"); printk(BIOS_SPEW, "SB900 - Early.c - get_sbdn - Start.\n");

View file

@ -36,7 +36,7 @@ static inline void set_bios_reset(void)
{ {
u32 nodes; u32 nodes;
u32 htic; u32 htic;
device_t dev; pci_devfn_t dev;
int i; int i;
nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1; nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1;

View file

@ -34,7 +34,7 @@ void set_debug_port(unsigned int port)
void enable_usbdebug(unsigned int port) void enable_usbdebug(unsigned int port)
{ {
device_t dev = PCI_DEV(0, 0x13, 5); /* USB EHCI, D19:F5 */ pci_devfn_t dev = PCI_DEV(0, 0x13, 5); /* USB EHCI, D19:F5 */
/* Select the requested physical USB port (1-15) as the Debug Port. */ /* Select the requested physical USB port (1-15) as the Debug Port. */
set_debug_port(port); set_debug_port(port);

View file

@ -49,7 +49,7 @@ void set_debug_port(unsigned int port)
*/ */
void enable_usbdebug(unsigned int port) void enable_usbdebug(unsigned int port)
{ {
device_t dev = PCI_DEV(0, 0x12, 2); /* USB EHCI, D18:F2 */ pci_devfn_t dev = PCI_DEV(0, 0x12, 2); /* USB EHCI, D18:F2 */
/* Set the EHCI BAR address. */ /* Set the EHCI BAR address. */
pci_write_config32(dev, EHCI_BAR_INDEX, CONFIG_EHCI_BAR); pci_write_config32(dev, EHCI_BAR_INDEX, CONFIG_EHCI_BAR);

View file

@ -36,7 +36,7 @@ static void set_bios_reset(void)
{ {
u32 nodes; u32 nodes;
u32 htic; u32 htic;
device_t dev; pci_devfn_t dev;
int i; int i;
nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1; nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1;

View file

@ -35,7 +35,7 @@ void set_debug_port(unsigned int port)
void enable_usbdebug(unsigned int port) void enable_usbdebug(unsigned int port)
{ {
u32 dbgctl; u32 dbgctl;
device_t dev = PCI_DEV(0, 0x1d, 7); /* USB EHCI, D29:F7 */ pci_devfn_t dev = PCI_DEV(0, 0x1d, 7); /* USB EHCI, D29:F7 */
/* Set the EHCI BAR address. */ /* Set the EHCI BAR address. */
pci_write_config32(dev, EHCI_BAR_INDEX, CONFIG_EHCI_BAR); pci_write_config32(dev, EHCI_BAR_INDEX, CONFIG_EHCI_BAR);

View file

@ -39,7 +39,7 @@
void set_debug_port(unsigned int port) void set_debug_port(unsigned int port)
{ {
u32 dword; u32 dword;
device_t dev = PCI_DEV(0, CK804_DEVN_BASE + 2, 1); /* USB EHCI */ pci_devfn_t dev = PCI_DEV(0, CK804_DEVN_BASE + 2, 1); /* USB EHCI */
/* Write the port number to 0x74[15:12]. */ /* Write the port number to 0x74[15:12]. */
dword = pci_read_config32(dev, 0x74); dword = pci_read_config32(dev, 0x74);
@ -50,7 +50,7 @@ void set_debug_port(unsigned int port)
void enable_usbdebug(unsigned int port) void enable_usbdebug(unsigned int port)
{ {
device_t dev = PCI_DEV(0, CK804_DEVN_BASE + 2, 1); /* USB EHCI */ pci_devfn_t dev = PCI_DEV(0, CK804_DEVN_BASE + 2, 1); /* USB EHCI */
/* Mark the requested physical USB port (1-15) as the Debug Port. */ /* Mark the requested physical USB port (1-15) as the Debug Port. */
set_debug_port(port); set_debug_port(port);

View file

@ -33,7 +33,7 @@
void set_debug_port(unsigned int port) void set_debug_port(unsigned int port)
{ {
u32 dword; u32 dword;
device_t dev = PCI_DEV(0, MCP55_DEVN_BASE + 2, 1); /* USB EHCI */ pci_devfn_t dev = PCI_DEV(0, MCP55_DEVN_BASE + 2, 1); /* USB EHCI */
/* Write the port number to 0x74[15:12]. */ /* Write the port number to 0x74[15:12]. */
dword = pci_read_config32(dev, 0x74); dword = pci_read_config32(dev, 0x74);
@ -44,7 +44,7 @@ void set_debug_port(unsigned int port)
void enable_usbdebug(unsigned int port) void enable_usbdebug(unsigned int port)
{ {
device_t dev = PCI_DEV(0, MCP55_DEVN_BASE + 2, 1); /* USB EHCI */ pci_devfn_t dev = PCI_DEV(0, MCP55_DEVN_BASE + 2, 1); /* USB EHCI */
/* Mark the requested physical USB port (1-15) as the Debug Port. */ /* Mark the requested physical USB port (1-15) as the Debug Port. */
set_debug_port(port); set_debug_port(port);

View file

@ -35,7 +35,7 @@
void set_debug_port(unsigned int port) void set_debug_port(unsigned int port)
{ {
u32 dword; u32 dword;
device_t dev = PCI_DEV(0, SIS966_DEVN_BASE + 2, 1); /* USB EHCI */ pci_devfn_t dev = PCI_DEV(0, SIS966_DEVN_BASE + 2, 1); /* USB EHCI */
/* Write the port number to 0x74[15:12]. */ /* Write the port number to 0x74[15:12]. */
dword = pci_read_config32(dev, 0x74); dword = pci_read_config32(dev, 0x74);
@ -46,7 +46,7 @@ void set_debug_port(unsigned int port)
void enable_usbdebug(unsigned int port) void enable_usbdebug(unsigned int port)
{ {
device_t dev = PCI_DEV(0, SIS966_DEVN_BASE + 2, 1); /* USB EHCI */ pci_devfn_t dev = PCI_DEV(0, SIS966_DEVN_BASE + 2, 1); /* USB EHCI */
/* Mark the requested physical USB port (1-15) as the Debug Port. */ /* Mark the requested physical USB port (1-15) as the Debug Port. */
set_debug_port(port); set_debug_port(port);