xref: /openbmc/linux/drivers/pci/pcie/portdrv.h (revision f39d5b72)
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
17f9f45604SKenji Kaneshige  * the MSI-X table entires used by port services must not exceed 31
18b43d4513SRafael J. Wysocki  */
19b43d4513SRafael J. Wysocki #define PCIE_PORT_MAX_MSIX_ENTRIES	32
201da177e4SLinus Torvalds 
211da177e4SLinus Torvalds #define get_descriptor_id(type, service) (((type - 4) << 4) | 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