| #ifndef LINUX_PCI_ATS_H |
| #define LINUX_PCI_ATS_H |
| |
| #include <linux/pci.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 */ |
| |
| #ifdef CONFIG_PCI_PRI |
| |
| extern int pci_enable_pri(struct pci_dev *pdev, u32 reqs); |
| extern void pci_disable_pri(struct pci_dev *pdev); |
| extern bool pci_pri_enabled(struct pci_dev *pdev); |
| extern int pci_reset_pri(struct pci_dev *pdev); |
| extern bool pci_pri_stopped(struct pci_dev *pdev); |
| extern int pci_pri_status(struct pci_dev *pdev); |
| |
| #else /* CONFIG_PCI_PRI */ |
| |
| static inline int pci_enable_pri(struct pci_dev *pdev, u32 reqs) |
| { |
| return -ENODEV; |
| } |
| |
| static inline void pci_disable_pri(struct pci_dev *pdev) |
| { |
| } |
| |
| static inline bool pci_pri_enabled(struct pci_dev *pdev) |
| { |
| return false; |
| } |
| |
| static inline int pci_reset_pri(struct pci_dev *pdev) |
| { |
| return -ENODEV; |
| } |
| |
| static inline bool pci_pri_stopped(struct pci_dev *pdev) |
| { |
| return true; |
| } |
| |
| static inline int pci_pri_status(struct pci_dev *pdev) |
| { |
| return -ENODEV; |
| } |
| #endif /* CONFIG_PCI_PRI */ |
| |
| #ifdef CONFIG_PCI_PASID |
| |
| extern int pci_enable_pasid(struct pci_dev *pdev, int features); |
| extern void pci_disable_pasid(struct pci_dev *pdev); |
| extern int pci_pasid_features(struct pci_dev *pdev); |
| extern int pci_max_pasids(struct pci_dev *pdev); |
| |
| #else /* CONFIG_PCI_PASID */ |
| |
| static inline int pci_enable_pasid(struct pci_dev *pdev, int features) |
| { |
| return -EINVAL; |
| } |
| |
| static inline void pci_disable_pasid(struct pci_dev *pdev) |
| { |
| } |
| |
| static inline int pci_pasid_features(struct pci_dev *pdev) |
| { |
| return -EINVAL; |
| } |
| |
| static inline int pci_max_pasids(struct pci_dev *pdev) |
| { |
| return -EINVAL; |
| } |
| |
| #endif /* CONFIG_PCI_PASID */ |
| |
| |
| #endif /* LINUX_PCI_ATS_H*/ |