portdrv.h 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*
  2. * File: portdrv.h
  3. * Purpose: PCI Express Port Bus Driver's Internal Data Structures
  4. *
  5. * Copyright (C) 2004 Intel
  6. * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
  7. */
  8. #ifndef _PORTDRV_H_
  9. #define _PORTDRV_H_
  10. #if !defined(PCI_CAP_ID_PME)
  11. #define PCI_CAP_ID_PME 1
  12. #endif
  13. #if !defined(PCI_CAP_ID_EXP)
  14. #define PCI_CAP_ID_EXP 0x10
  15. #endif
  16. #define PORT_TYPE_MASK 0xf
  17. #define PORT_TO_SLOT_MASK 0x100
  18. #define SLOT_HP_CAPABLE_MASK 0x40
  19. #define PCIE_CAPABILITIES_REG 0x2
  20. #define PCIE_SLOT_CAPABILITIES_REG 0x14
  21. #define PCIE_PORT_DEVICE_MAXSERVICES 4
  22. #define PCI_CFG_SPACE_SIZE 256
  23. #define get_descriptor_id(type, service) (((type - 4) << 4) | service)
  24. struct pcie_port_device_ext {
  25. int interrupt_mode; /* [0:INTx | 1:MSI | 2:MSI-X] */
  26. unsigned int saved_msi_config_space[5];
  27. };
  28. extern struct bus_type pcie_port_bus_type;
  29. extern int pcie_port_device_probe(struct pci_dev *dev);
  30. extern int pcie_port_device_register(struct pci_dev *dev);
  31. #ifdef CONFIG_PM
  32. extern int pcie_port_device_suspend(struct pci_dev *dev, pm_message_t state);
  33. extern int pcie_port_device_resume(struct pci_dev *dev);
  34. #endif
  35. extern void pcie_port_device_remove(struct pci_dev *dev);
  36. extern void pcie_port_bus_register(void);
  37. extern void pcie_port_bus_unregister(void);
  38. #endif /* _PORTDRV_H_ */