| #ifndef PCI_OPS_H |
| #define PCI_OPS_H |
| |
| #include <stdint.h> |
| #include <device/device.h> |
| #include <arch/pci_ops.h> |
| |
| #ifndef __SIMPLE_DEVICE__ |
| u8 pci_read_config8(struct device *dev, unsigned int where); |
| u16 pci_read_config16(struct device *dev, unsigned int where); |
| u32 pci_read_config32(struct device *dev, unsigned int where); |
| void pci_write_config8(struct device *dev, unsigned int where, u8 val); |
| void pci_write_config16(struct device *dev, unsigned int where, u16 val); |
| void pci_write_config32(struct device *dev, unsigned int where, u32 val); |
| |
| #endif |
| |
| /* |
| * Use device_t here as the functions are to be used with either |
| * __SIMPLE_DEVICE__ defined or undefined. |
| */ |
| static __always_inline |
| void pci_or_config8(device_t dev, unsigned int where, u8 ormask) |
| { |
| u8 value = pci_read_config8(dev, where); |
| pci_write_config8(dev, where, value | ormask); |
| } |
| |
| static __always_inline |
| void pci_or_config16(device_t dev, unsigned int where, u16 ormask) |
| { |
| u16 value = pci_read_config16(dev, where); |
| pci_write_config16(dev, where, value | ormask); |
| } |
| |
| static __always_inline |
| void pci_or_config32(device_t dev, unsigned int where, u32 ormask) |
| { |
| u32 value = pci_read_config32(dev, where); |
| pci_write_config32(dev, where, value | ormask); |
| } |
| |
| static __always_inline |
| void pci_update_config8(device_t dev, int reg, u8 mask, u8 or) |
| { |
| u8 reg8; |
| |
| reg8 = pci_read_config8(dev, reg); |
| reg8 &= mask; |
| reg8 |= or; |
| pci_write_config8(dev, reg, reg8); |
| } |
| |
| static __always_inline |
| void pci_update_config16(device_t dev, int reg, u16 mask, u16 or) |
| { |
| u16 reg16; |
| |
| reg16 = pci_read_config16(dev, reg); |
| reg16 &= mask; |
| reg16 |= or; |
| pci_write_config16(dev, reg, reg16); |
| } |
| |
| static __always_inline |
| void pci_update_config32(device_t dev, int reg, u32 mask, u32 or) |
| { |
| u32 reg32; |
| |
| reg32 = pci_read_config32(dev, reg); |
| reg32 &= mask; |
| reg32 |= or; |
| pci_write_config32(dev, reg, reg32); |
| } |
| |
| const struct pci_bus_operations *pci_bus_default_ops(struct device *dev); |
| |
| #endif /* PCI_OPS_H */ |