- Update the device header files
git-svn-id: svn://svn.coreboot.org/coreboot/trunk@1663 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
b78c1972fe
commit
992cd008f1
|
@ -7,6 +7,8 @@
|
|||
|
||||
struct device;
|
||||
typedef struct device * device_t;
|
||||
struct pci_operations;
|
||||
struct smbus_bus_operations;
|
||||
|
||||
struct device_operations {
|
||||
void (*read_resources)(device_t dev);
|
||||
|
@ -15,6 +17,8 @@ struct device_operations {
|
|||
void (*init)(device_t dev);
|
||||
unsigned int (*scan_bus)(device_t bus, unsigned int max);
|
||||
void (*enable)(device_t dev);
|
||||
struct pci_operations *ops_pci;
|
||||
struct smbus_bus_operations *ops_smbus_bus;
|
||||
};
|
||||
|
||||
|
||||
|
@ -28,7 +32,7 @@ struct bus {
|
|||
unsigned char cap; /* PCi capability offset */
|
||||
};
|
||||
|
||||
#define MAX_RESOURCES 8
|
||||
#define MAX_RESOURCES 12
|
||||
#define MAX_LINKS 3
|
||||
/*
|
||||
* There is one device structure for each slot-number/function-number
|
||||
|
@ -47,6 +51,8 @@ struct device {
|
|||
unsigned int class; /* 3 bytes: (base,sub,prog-if) */
|
||||
unsigned int hdr_type; /* PCI header type */
|
||||
unsigned int enabled : 1; /* set if we should enable the device */
|
||||
unsigned int initialized : 1; /* set if we have initialized the device */
|
||||
unsigned int have_resources : 1; /* Set if we have read the devices resources */
|
||||
|
||||
uint8_t command;
|
||||
|
||||
|
@ -83,10 +89,9 @@ extern void enable_resources(struct device *dev);
|
|||
extern void enumerate_static_device(void);
|
||||
extern void enumerate_static_devices(void);
|
||||
extern const char *dev_path(device_t dev);
|
||||
extern void compact_resources(device_t dev);
|
||||
extern struct resource *get_resource(device_t dev, unsigned index);
|
||||
|
||||
/* Helper functions */
|
||||
device_t find_dev_path(struct bus *parent, struct device_path *path);
|
||||
device_t alloc_find_dev(struct bus *parent, struct device_path *path);
|
||||
device_t dev_find_device (unsigned int vendor, unsigned int device, device_t from);
|
||||
device_t dev_find_class (unsigned int class, device_t from);
|
||||
|
@ -103,6 +108,8 @@ extern void root_dev_read_resources(device_t dev);
|
|||
extern void root_dev_set_resources(device_t dev);
|
||||
extern unsigned int scan_static_bus(device_t bus, unsigned int max);
|
||||
extern void enable_childrens_resources(device_t dev);
|
||||
extern unsigned int root_dev_scan_pci_bus(device_t root, unsigned int max);
|
||||
extern void root_dev_enable_resources(device_t dev);
|
||||
extern unsigned int root_dev_scan_bus(device_t root, unsigned int max);
|
||||
extern void root_dev_init(device_t dev);
|
||||
|
||||
#endif /* DEVICE_H */
|
||||
|
|
|
@ -68,13 +68,13 @@
|
|||
#define PCI_BASE_ADDRESS_SPACE 0x01 /* 0 = memory, 1 = I/O */
|
||||
#define PCI_BASE_ADDRESS_SPACE_IO 0x01
|
||||
#define PCI_BASE_ADDRESS_SPACE_MEMORY 0x00
|
||||
#define PCI_BASE_ADDRESS_MEM_TYPE_MASK 0x06
|
||||
#define PCI_BASE_ADDRESS_MEM_TYPE_32 0x00 /* 32 bit address */
|
||||
#define PCI_BASE_ADDRESS_MEM_TYPE_1M 0x02 /* Below 1M [obsolete] */
|
||||
#define PCI_BASE_ADDRESS_MEM_TYPE_64 0x04 /* 64 bit address */
|
||||
#define PCI_BASE_ADDRESS_MEM_LIMIT_MASK 0x06
|
||||
#define PCI_BASE_ADDRESS_MEM_LIMIT_32 0x00 /* 32 bit address */
|
||||
#define PCI_BASE_ADDRESS_MEM_LIMIT_1M 0x02 /* Below 1M [obsolete] */
|
||||
#define PCI_BASE_ADDRESS_MEM_LIMIT_64 0x04 /* 64 bit address */
|
||||
#define PCI_BASE_ADDRESS_MEM_PREFETCH 0x08 /* prefetchable? */
|
||||
#define PCI_BASE_ADDRESS_MEM_MASK (~0x0fUL)
|
||||
#define PCI_BASE_ADDRESS_IO_MASK (~0x03UL)
|
||||
#define PCI_BASE_ADDRESS_MEM_ATTR_MASK 0x0f
|
||||
#define PCI_BASE_ADDRESS_IO_ATTR_MASK 0x03
|
||||
/* bit 1 is reserved if address_space = 1 */
|
||||
|
||||
/* Header type 0 (normal devices) */
|
||||
|
|
|
@ -1758,6 +1758,22 @@
|
|||
#define PCI_DEVICE_ID_INTEL_82801DB_11 0x24cb
|
||||
#define PCI_DEVICE_ID_INTEL_82801DB_13 0x24cd
|
||||
#define PCI_DEVICE_ID_INTEL_82801EB_0 0x24d0
|
||||
#define PCI_DEVICE_ID_INTEL_82801EB_USB 0x24d2
|
||||
#define PCI_DEVICE_ID_INTEL_82801EB_4 0x24d4
|
||||
#define PCI_DEVICE_ID_INTEL_82801EB_D 0x24dd
|
||||
#define PCI_DEVICE_ID_INTEL_82801EB_E 0x24de
|
||||
#define PCI_DEVICE_ID_INTEL_82801EB_IDE 0x24db
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_PCI 0x244e
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_ISA 0x24d0
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_USB 0x24d2
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_SMB 0x24d3
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_USB2 0x24d4
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_AC97_AUDIO 0x24d5
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_AC97_MODEM 0x24d6
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_USB3 0x24d7
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_EHCI 0x24dd
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_IDE 0x24db
|
||||
#define PCI_DEVICE_ID_INTEL_82801ER_SATA 0x24df
|
||||
#define PCI_DEVICE_ID_INTEL_80310 0x530d
|
||||
#define PCI_DEVICE_ID_INTEL_82810_MC1 0x7120
|
||||
#define PCI_DEVICE_ID_INTEL_82810_IG1 0x7121
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
#ifndef RESOURCE_H
|
||||
#define RESOURCE_H
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
#define IORESOURCE_BITS 0x000000ff /* Bus-specific bits */
|
||||
|
||||
|
@ -60,10 +61,12 @@
|
|||
#define IORESOURCE_MEM_SHADOWABLE (1<<5) /* dup: IORESOURCE_SHADOWABLE */
|
||||
#define IORESOURCE_MEM_EXPANSIONROM (1<<6)
|
||||
|
||||
|
||||
typedef uint64_t resource_t;
|
||||
struct resource {
|
||||
unsigned long base; /* Base address of the resource */
|
||||
unsigned long size; /* Size of the resource */
|
||||
unsigned long limit; /* Largest valid value base + size -1 */
|
||||
resource_t base; /* Base address of the resource */
|
||||
resource_t size; /* Size of the resource */
|
||||
resource_t limit; /* Largest valid value base + size -1 */
|
||||
unsigned long flags; /* Descriptions of the kind of resource */
|
||||
unsigned long index; /* Bus specific per device resource id */
|
||||
unsigned char align; /* Required alignment (log 2) of the resource */
|
||||
|
@ -71,4 +74,18 @@ struct resource {
|
|||
/* Alignment must be >= the granularity of the resource */
|
||||
};
|
||||
|
||||
/* Macros to generate index values for subtractive resources */
|
||||
#define IOINDEX_SUBTRACTIVE(IDX,LINK) (0x10000000 + ((IDX) << 8) + LINK)
|
||||
#define IOINDEX_SUBTRACTIVE_LINK(IDX) (IDX & 0xff)
|
||||
|
||||
/* Generic resource helper functions */
|
||||
struct device;
|
||||
extern void compact_resources(struct device * dev);
|
||||
extern struct resource *probe_resource(struct device *dev, unsigned index);
|
||||
extern struct resource *new_resource(struct device * dev, unsigned index);
|
||||
extern struct resource *find_resource(struct device * dev, unsigned index);
|
||||
extern resource_t resource_end(struct resource *resource);
|
||||
extern resource_t resource_max(struct resource *resource);
|
||||
extern void report_resource_stored(struct device * dev, struct resource *resource, const char *comment);
|
||||
|
||||
#endif /* RESOURCE_H */
|
||||
|
|
|
@ -0,0 +1,71 @@
|
|||
#ifndef DEVICE_SMBUS_H
|
||||
#define DEVICE_SMBUS_H
|
||||
|
||||
#include <stdint.h>
|
||||
#include <device/device.h>
|
||||
#include <device/path.h>
|
||||
#include <device/chip.h>
|
||||
#include <device/smbus_def.h>
|
||||
|
||||
/* Common smbus bus operations */
|
||||
struct smbus_bus_operations {
|
||||
int (*quick_read) (device_t dev);
|
||||
int (*quick_write) (device_t dev);
|
||||
int (*recv_byte) (device_t dev);
|
||||
int (*send_byte) (device_t dev, uint8_t value);
|
||||
int (*read_byte) (device_t dev, uint8_t addr);
|
||||
int (*write_byte) (device_t dev, uint8_t addr, uint8_t value);
|
||||
int (*read_word) (device_t dev, uint8_t addr);
|
||||
int (*write_word) (device_t dev, uint8_t addr, uint16_t value);
|
||||
int (*process_call)(device_t dev, uint8_t cmd, uint16_t data);
|
||||
int (*block_read) (device_t dev, uint8_t cmd, uint8_t bytes, uint8_t *buffer);
|
||||
int (*block_write) (device_t dev, uint8_t cmd, uint8_t bytes, const uint8_t *buffer);
|
||||
};
|
||||
|
||||
static inline int smbus_quick_read(device_t dev)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->quick_read(dev);
|
||||
}
|
||||
static inline int smbus_quick_write(device_t dev)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->quick_write(dev);
|
||||
}
|
||||
static inline int smbus_recv_byte(device_t dev)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->recv_byte(dev);
|
||||
}
|
||||
static inline int smbus_send_byte(device_t dev, uint8_t byte)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->send_byte(dev, byte);
|
||||
}
|
||||
static inline int smbus_read_byte(device_t dev, uint8_t addr)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->read_byte(dev, addr);
|
||||
}
|
||||
static inline int smbus_write_byte(device_t dev, uint8_t addr, uint8_t val)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->write_byte(dev, addr, val);
|
||||
}
|
||||
static inline int smbus_read_word(device_t dev, uint8_t addr)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->read_word(dev, addr);
|
||||
}
|
||||
static inline int smbus_write_word(device_t dev, uint8_t addr, uint16_t val)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->write_word(dev, addr, val);
|
||||
}
|
||||
static inline int smbus_process_call(device_t dev, uint8_t cmd, uint16_t data)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->process_call(dev, cmd, data);
|
||||
}
|
||||
static inline int smbus_block_read(device_t dev, uint8_t cmd, uint8_t bytes, uint8_t *buffer)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->block_read(dev, cmd, bytes, buffer);
|
||||
}
|
||||
static inline int smbus_block_write(device_t dev, uint8_t cmd, uint8_t bytes, const uint8_t *buffer)
|
||||
{
|
||||
return dev->bus->dev->ops->ops_smbus_bus->block_write(dev, cmd, bytes, buffer);
|
||||
}
|
||||
|
||||
|
||||
#endif /* DEVICE_SMBUS_H */
|
|
@ -0,0 +1,9 @@
|
|||
#ifndef DEVICE_SMBUS_DEF_H
|
||||
#define DEVICE_SMBUS_DEF_H
|
||||
|
||||
/* Error results are negative success is >= 0 */
|
||||
#define SMBUS_ERROR -1
|
||||
#define SMBUS_WAIT_UNTIL_READY_TIMEOUT -2
|
||||
#define SMBUS_WAIT_UNTIL_DONE_TIMEOUT -3
|
||||
|
||||
#endif /* DEVICE_SMBUS_DEF_H */
|
Loading…
Reference in New Issue