11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * File: portdrv.h 31da177e4SLinus Torvalds * Purpose: PCI Express Port Bus Driver's Internal Data Structures 41da177e4SLinus Torvalds * 51da177e4SLinus Torvalds * Copyright (C) 2004 Intel 61da177e4SLinus Torvalds * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com) 71da177e4SLinus Torvalds */ 81da177e4SLinus Torvalds 91da177e4SLinus Torvalds #ifndef _PORTDRV_H_ 101da177e4SLinus Torvalds #define _PORTDRV_H_ 111da177e4SLinus Torvalds 123ec6a8d0SAndrew Morton #include <linux/compiler.h> 133ec6a8d0SAndrew Morton 141da177e4SLinus Torvalds #define PCIE_PORT_DEVICE_MAXSERVICES 4 15b43d4513SRafael J. Wysocki /* 16f9f45604SKenji Kaneshige * According to the PCI Express Base Specification 2.0, the indices of 17f7625980SBjorn Helgaas * the MSI-X table entries used by port services must not exceed 31 18b43d4513SRafael J. Wysocki */ 19b43d4513SRafael J. Wysocki #define PCIE_PORT_MAX_MSIX_ENTRIES 32 201da177e4SLinus Torvalds 216d81417dSKeith Busch #define get_descriptor_id(type, service) (((type - 4) << 8) | service) 221da177e4SLinus Torvalds 231da177e4SLinus Torvalds extern struct bus_type pcie_port_bus_type; 24f39d5b72SBjorn Helgaas int pcie_port_device_register(struct pci_dev *dev); 251da177e4SLinus Torvalds #ifdef CONFIG_PM 26f39d5b72SBjorn Helgaas int pcie_port_device_suspend(struct device *dev); 27f39d5b72SBjorn Helgaas int pcie_port_device_resume(struct device *dev); 281da177e4SLinus Torvalds #endif 29f39d5b72SBjorn Helgaas void pcie_port_device_remove(struct pci_dev *dev); 30f39d5b72SBjorn Helgaas int __must_check pcie_port_bus_register(void); 31f39d5b72SBjorn Helgaas void pcie_port_bus_unregister(void); 321da177e4SLinus Torvalds 3328eb5f27SRafael J. Wysocki struct pci_dev; 3428eb5f27SRafael J. Wysocki 35f39d5b72SBjorn Helgaas void pcie_clear_root_pme_status(struct pci_dev *dev); 36fe31e697SRafael J. Wysocki 377570a333SMUNEDA Takahiro #ifdef CONFIG_HOTPLUG_PCI_PCIE 387570a333SMUNEDA Takahiro extern bool pciehp_msi_disabled; 397570a333SMUNEDA Takahiro 407570a333SMUNEDA Takahiro static inline bool pciehp_no_msi(void) 417570a333SMUNEDA Takahiro { 427570a333SMUNEDA Takahiro return pciehp_msi_disabled; 437570a333SMUNEDA Takahiro } 447570a333SMUNEDA Takahiro 457570a333SMUNEDA Takahiro #else /* !CONFIG_HOTPLUG_PCI_PCIE */ 467570a333SMUNEDA Takahiro static inline bool pciehp_no_msi(void) { return false; } 477570a333SMUNEDA Takahiro #endif /* !CONFIG_HOTPLUG_PCI_PCIE */ 487570a333SMUNEDA Takahiro 49c39fae14SRafael J. Wysocki #ifdef CONFIG_PCIE_PME 50c39fae14SRafael J. Wysocki extern bool pcie_pme_msi_disabled; 51c39fae14SRafael J. Wysocki 52c39fae14SRafael J. Wysocki static inline void pcie_pme_disable_msi(void) 53c39fae14SRafael J. Wysocki { 54c39fae14SRafael J. Wysocki pcie_pme_msi_disabled = true; 55c39fae14SRafael J. Wysocki } 56c39fae14SRafael J. Wysocki 57c39fae14SRafael J. Wysocki static inline bool pcie_pme_no_msi(void) 58c39fae14SRafael J. Wysocki { 59c39fae14SRafael J. Wysocki return pcie_pme_msi_disabled; 60c39fae14SRafael J. Wysocki } 6128eb5f27SRafael J. Wysocki 62f39d5b72SBjorn Helgaas void pcie_pme_interrupt_enable(struct pci_dev *dev, bool enable); 63c39fae14SRafael J. Wysocki #else /* !CONFIG_PCIE_PME */ 64c39fae14SRafael J. Wysocki static inline void pcie_pme_disable_msi(void) {} 65c39fae14SRafael J. Wysocki static inline bool pcie_pme_no_msi(void) { return false; } 6628eb5f27SRafael J. Wysocki static inline void pcie_pme_interrupt_enable(struct pci_dev *dev, bool en) {} 67c39fae14SRafael J. Wysocki #endif /* !CONFIG_PCIE_PME */ 68c39fae14SRafael J. Wysocki 6928eb5f27SRafael J. Wysocki #ifdef CONFIG_ACPI 70f39d5b72SBjorn Helgaas int pcie_port_acpi_setup(struct pci_dev *port, int *mask); 7128eb5f27SRafael J. Wysocki 7228eb5f27SRafael J. Wysocki static inline int pcie_port_platform_notify(struct pci_dev *port, int *mask) 7328eb5f27SRafael J. Wysocki { 7428eb5f27SRafael J. Wysocki return pcie_port_acpi_setup(port, mask); 7528eb5f27SRafael J. Wysocki } 7628eb5f27SRafael J. Wysocki #else /* !CONFIG_ACPI */ 7728eb5f27SRafael J. Wysocki static inline int pcie_port_platform_notify(struct pci_dev *port, int *mask) 7828eb5f27SRafael J. Wysocki { 7928eb5f27SRafael J. Wysocki return 0; 8028eb5f27SRafael J. Wysocki } 8128eb5f27SRafael J. Wysocki #endif /* !CONFIG_ACPI */ 8228eb5f27SRafael J. Wysocki 831da177e4SLinus Torvalds #endif /* _PORTDRV_H_ */ 84