53 lines
1.1 KiB
C
53 lines
1.1 KiB
C
|
#ifndef LINUX_PCI_ATS_H
|
||
|
#define LINUX_PCI_ATS_H
|
||
|
|
||
|
/* Address Translation Service */
|
||
|
struct pci_ats {
|
||
|
int pos; /* capability position */
|
||
|
int stu; /* Smallest Translation Unit */
|
||
|
int qdep; /* Invalidate Queue Depth */
|
||
|
int ref_cnt; /* Physical Function reference count */
|
||
|
unsigned int is_enabled:1; /* Enable bit is set */
|
||
|
};
|
||
|
|
||
|
#ifdef CONFIG_PCI_IOV
|
||
|
|
||
|
extern int pci_enable_ats(struct pci_dev *dev, int ps);
|
||
|
extern void pci_disable_ats(struct pci_dev *dev);
|
||
|
extern int pci_ats_queue_depth(struct pci_dev *dev);
|
||
|
/**
|
||
|
* pci_ats_enabled - query the ATS status
|
||
|
* @dev: the PCI device
|
||
|
*
|
||
|
* Returns 1 if ATS capability is enabled, or 0 if not.
|
||
|
*/
|
||
|
static inline int pci_ats_enabled(struct pci_dev *dev)
|
||
|
{
|
||
|
return dev->ats && dev->ats->is_enabled;
|
||
|
}
|
||
|
|
||
|
#else /* CONFIG_PCI_IOV */
|
||
|
|
||
|
static inline int pci_enable_ats(struct pci_dev *dev, int ps)
|
||
|
{
|
||
|
return -ENODEV;
|
||
|
}
|
||
|
|
||
|
static inline void pci_disable_ats(struct pci_dev *dev)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
static inline int pci_ats_queue_depth(struct pci_dev *dev)
|
||
|
{
|
||
|
return -ENODEV;
|
||
|
}
|
||
|
|
||
|
static inline int pci_ats_enabled(struct pci_dev *dev)
|
||
|
{
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
#endif /* CONFIG_PCI_IOV */
|
||
|
|
||
|
#endif /* LINUX_PCI_ATS_H*/
|