📄 pci.h
字号:
/****************************************************************************** * pci.h * * PCI access functions. */#ifndef __XEN_PCI_H__#define __XEN_PCI_H__#include <xen/config.h>#include <xen/types.h>#include <xen/list.h>#include <xen/spinlock.h>/* * The PCI interface treats multi-function devices as independent * devices. The slot/function address of each device is encoded * in a single byte as follows: * * 15:8 = bus * 7:3 = slot * 2:0 = function */#define PCI_BUS(bdf) (((bdf) >> 8) & 0xff)#define PCI_SLOT(bdf) (((bdf) >> 3) & 0x1f)#define PCI_FUNC(bdf) ((bdf) & 0x07)#define PCI_DEVFN(d,f) ((((d) & 0x1f) << 3) | ((f) & 0x07))#define PCI_DEVFN2(bdf) ((bdf) & 0xff)#define PCI_BDF(b,d,f) ((((b) & 0xff) << 8) | PCI_DEVFN(d,f))#define PCI_BDF2(b,df) ((((b) & 0xff) << 8) | ((df) & 0xff))struct pci_dev { struct list_head alldevs_list; struct list_head domain_list; struct list_head msi_list; struct domain *domain; const u8 bus; const u8 devfn; spinlock_t lock;};#define for_each_pdev(domain, pdev) \ list_for_each_entry(pdev, &(domain->arch.pdev_list), domain_list)/* * The pcidevs_lock write-lock must be held when doing alloc_pdev() or * free_pdev(). Never de-reference pdev without holding pdev->lock or * pcidevs_lock. Always aquire pcidevs_lock before pdev->lock when * doing free_pdev(). */extern rwlock_t pcidevs_lock;struct pci_dev *alloc_pdev(u8 bus, u8 devfn);void free_pdev(struct pci_dev *pdev);struct pci_dev *pci_lock_pdev(int bus, int devfn);struct pci_dev *pci_lock_domain_pdev(struct domain *d, int bus, int devfn);void pci_release_devices(struct domain *d);int pci_add_device(u8 bus, u8 devfn);int pci_remove_device(u8 bus, u8 devfn);uint8_t pci_conf_read8( unsigned int bus, unsigned int dev, unsigned int func, unsigned int reg);uint16_t pci_conf_read16( unsigned int bus, unsigned int dev, unsigned int func, unsigned int reg);uint32_t pci_conf_read32( unsigned int bus, unsigned int dev, unsigned int func, unsigned int reg);void pci_conf_write8( unsigned int bus, unsigned int dev, unsigned int func, unsigned int reg, uint8_t data);void pci_conf_write16( unsigned int bus, unsigned int dev, unsigned int func, unsigned int reg, uint16_t data);void pci_conf_write32( unsigned int bus, unsigned int dev, unsigned int func, unsigned int reg, uint32_t data);int pci_find_cap_offset(u8 bus, u8 dev, u8 func, u8 cap);int pci_find_next_cap(u8 bus, unsigned int devfn, u8 pos, int cap);#endif /* __XEN_PCI_H__ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -