cap.h 4.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * Copyright (c) 2021 BayLibre, SAS
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #ifndef ZEPHYR_INCLUDE_DRIVERS_PCIE_CAP_H_
  7. #define ZEPHYR_INCLUDE_DRIVERS_PCIE_CAP_H_
  8. /*
  9. * PCI & PCI Express Capabilities
  10. * from PCI Code and ID Assignment Specification Revision 1.11
  11. */
  12. #define PCI_CAP_ID_NULL 0x00U /* Null Capability */
  13. #define PCI_CAP_ID_PM 0x01U /* Power Management */
  14. #define PCI_CAP_ID_AGP 0x02U /* Accelerated Graphics Port */
  15. #define PCI_CAP_ID_VPD 0x03U /* Vital Product Data */
  16. #define PCI_CAP_ID_SLOTID 0x04U /* Slot Identification */
  17. #define PCI_CAP_ID_MSI 0x05U /* Message Signalled Interrupts */
  18. #define PCI_CAP_ID_CHSWP 0x06U /* CompactPCI HotSwap */
  19. #define PCI_CAP_ID_PCIX 0x07U /* PCI-X */
  20. #define PCI_CAP_ID_HT 0x08U /* HyperTransport */
  21. #define PCI_CAP_ID_VNDR 0x09U /* Vendor-Specific */
  22. #define PCI_CAP_ID_DBG 0x0AU /* Debug port */
  23. #define PCI_CAP_ID_CCRC 0x0BU /* CompactPCI Central Resource Control */
  24. #define PCI_CAP_ID_SHPC 0x0CU /* PCI Standard Hot-Plug Controller */
  25. #define PCI_CAP_ID_SSVID 0x0DU /* Bridge subsystem vendor/device ID */
  26. #define PCI_CAP_ID_AGP3 0x0EU /* AGP 8x */
  27. #define PCI_CAP_ID_SECDEV 0x0FU /* Secure Device */
  28. #define PCI_CAP_ID_EXP 0x10U /* PCI Express */
  29. #define PCI_CAP_ID_MSIX 0x11U /* MSI-X */
  30. #define PCI_CAP_ID_SATA 0x12U /* Serial ATA Data/Index Configuration */
  31. #define PCI_CAP_ID_AF 0x13U /* PCI Advanced Features */
  32. #define PCI_CAP_ID_EA 0x14U /* PCI Enhanced Allocation */
  33. #define PCI_CAP_ID_FPB 0x14U /* Flattening Portal Bridge */
  34. /*
  35. * PCI Express Extended Capabilities
  36. */
  37. #define PCI_EXT_CAP_ID_NULL 0x0000U /* Null Capability */
  38. #define PCI_EXT_CAP_ID_ERR 0x0001U /* Advanced Error Reporting */
  39. #define PCI_EXT_CAP_ID_VC 0x0002U /* Virtual Channel when no MFVC */
  40. #define PCI_EXT_CAP_ID_DSN 0x0003U /* Device Serial Number */
  41. #define PCI_EXT_CAP_ID_PWR 0x0004U /* Power Budgeting */
  42. #define PCI_EXT_CAP_ID_RCLD 0x0005U /* Root Complex Link Declaration */
  43. #define PCI_EXT_CAP_ID_RCILC 0x0006U /* Root Complex Internal Link Control */
  44. #define PCI_EXT_CAP_ID_RCEC 0x0007U /* Root Complex Event Collector Endpoint Association */
  45. #define PCI_EXT_CAP_ID_MFVC 0x0008U /* Multi-Function VC Capability */
  46. #define PCI_EXT_CAP_ID_MFVC_VC 0x0009U /* Virtual Channel used with MFVC */
  47. #define PCI_EXT_CAP_ID_RCRB 0x000AU /* Root Complex Register Block */
  48. #define PCI_EXT_CAP_ID_VNDR 0x000BU /* Vendor-Specific Extended Capability */
  49. #define PCI_EXT_CAP_ID_CAC 0x000CU /* Config Access Correlation - obsolete */
  50. #define PCI_EXT_CAP_ID_ACS 0x000DU /* Access Control Services */
  51. #define PCI_EXT_CAP_ID_ARI 0x000EU /* Alternate Routing-ID Interpretation */
  52. #define PCI_EXT_CAP_ID_ATS 0x000FU /* Address Translation Services */
  53. #define PCI_EXT_CAP_ID_SRIOV 0x0010U /* Single Root I/O Virtualization */
  54. #define PCI_EXT_CAP_ID_MRIOV 0x0011U /* Multi Root I/O Virtualization */
  55. #define PCI_EXT_CAP_ID_MCAST 0x0012U /* Multicast */
  56. #define PCI_EXT_CAP_ID_PRI 0x0013U /* Page Request Interface */
  57. #define PCI_EXT_CAP_ID_AMD_XXX 0x0014U /* Reserved for AMD */
  58. #define PCI_EXT_CAP_ID_REBAR 0x0015U /* Resizable BAR */
  59. #define PCI_EXT_CAP_ID_DPA 0x0016U /* Dynamic Power Allocation */
  60. #define PCI_EXT_CAP_ID_TPH 0x0017U /* TPH Requester */
  61. #define PCI_EXT_CAP_ID_LTR 0x0018U /* Latency Tolerance Reporting */
  62. #define PCI_EXT_CAP_ID_SECPCI 0x0019U /* Secondary PCIe Capability */
  63. #define PCI_EXT_CAP_ID_PMUX 0x001AU /* Protocol Multiplexing */
  64. #define PCI_EXT_CAP_ID_PASID 0x001BU /* Process Address Space ID */
  65. #define PCI_EXT_CAP_ID_DPC 0x001DU /* DPC: Downstream Port Containment */
  66. #define PCI_EXT_CAP_ID_L1SS 0x001EU /* L1 PM Substates */
  67. #define PCI_EXT_CAP_ID_PTM 0x001FU /* Precision Time Measurement */
  68. #define PCI_EXT_CAP_ID_DVSEC 0x0023U /* Designated Vendor-Specific Extended Capability */
  69. #define PCI_EXT_CAP_ID_DLF 0x0025U /* Data Link Feature */
  70. #define PCI_EXT_CAP_ID_PL_16GT 0x0026U /* Physical Layer 16.0 GT/s */
  71. #define PCI_EXT_CAP_ID_LMR 0x0027U /* Lane Margining at the Receiver */
  72. #define PCI_EXT_CAP_ID_HID 0x0028U /* Hierarchy ID */
  73. #define PCI_EXT_CAP_ID_NPEM 0x0029U /* Native PCIe Enclosure Management */
  74. #define PCI_EXT_CAP_ID_PL_32GT 0x002AU /* Physical Layer 32.0 GT/s */
  75. #define PCI_EXT_CAP_ID_AP 0x002BU /* Alternate Protocol */
  76. #define PCI_EXT_CAP_ID_SFI 0x002CU /* System Firmware Intermediary */
  77. #endif /* ZEPHYR_INCLUDE_DRIVERS_PCIE_CAP_H_ */