trap.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
  2. /* Copyright (c) 2015-2018 Mellanox Technologies. All rights reserved */
  3. #ifndef _MLXSW_TRAP_H
  4. #define _MLXSW_TRAP_H
  5. enum {
  6. /* Ethernet EMAD and FDB miss */
  7. MLXSW_TRAP_ID_FDB_MC = 0x01,
  8. MLXSW_TRAP_ID_ETHEMAD = 0x05,
  9. /* L2 traps for specific packet types */
  10. MLXSW_TRAP_ID_STP = 0x10,
  11. MLXSW_TRAP_ID_LACP = 0x11,
  12. MLXSW_TRAP_ID_EAPOL = 0x12,
  13. MLXSW_TRAP_ID_LLDP = 0x13,
  14. MLXSW_TRAP_ID_MMRP = 0x14,
  15. MLXSW_TRAP_ID_MVRP = 0x15,
  16. MLXSW_TRAP_ID_RPVST = 0x16,
  17. MLXSW_TRAP_ID_DHCP = 0x19,
  18. MLXSW_TRAP_ID_PTP0 = 0x28,
  19. MLXSW_TRAP_ID_PTP1 = 0x29,
  20. MLXSW_TRAP_ID_IGMP_QUERY = 0x30,
  21. MLXSW_TRAP_ID_IGMP_V1_REPORT = 0x31,
  22. MLXSW_TRAP_ID_IGMP_V2_REPORT = 0x32,
  23. MLXSW_TRAP_ID_IGMP_V2_LEAVE = 0x33,
  24. MLXSW_TRAP_ID_IGMP_V3_REPORT = 0x34,
  25. MLXSW_TRAP_ID_PKT_SAMPLE = 0x38,
  26. MLXSW_TRAP_ID_FID_MISS = 0x3D,
  27. MLXSW_TRAP_ID_DECAP_ECN0 = 0x40,
  28. MLXSW_TRAP_ID_MTUERROR = 0x52,
  29. MLXSW_TRAP_ID_TTLERROR = 0x53,
  30. MLXSW_TRAP_ID_LBERROR = 0x54,
  31. MLXSW_TRAP_ID_IPV4_OSPF = 0x55,
  32. MLXSW_TRAP_ID_IPV4_PIM = 0x58,
  33. MLXSW_TRAP_ID_IPV4_VRRP = 0x59,
  34. MLXSW_TRAP_ID_RPF = 0x5C,
  35. MLXSW_TRAP_ID_IP2ME = 0x5F,
  36. MLXSW_TRAP_ID_IPV6_UNSPECIFIED_ADDRESS = 0x60,
  37. MLXSW_TRAP_ID_IPV6_LINK_LOCAL_DEST = 0x61,
  38. MLXSW_TRAP_ID_IPV6_LINK_LOCAL_SRC = 0x62,
  39. MLXSW_TRAP_ID_IPV6_ALL_NODES_LINK = 0x63,
  40. MLXSW_TRAP_ID_IPV6_OSPF = 0x64,
  41. MLXSW_TRAP_ID_IPV6_MLDV12_LISTENER_QUERY = 0x65,
  42. MLXSW_TRAP_ID_IPV6_MLDV1_LISTENER_REPORT = 0x66,
  43. MLXSW_TRAP_ID_IPV6_MLDV1_LISTENER_DONE = 0x67,
  44. MLXSW_TRAP_ID_IPV6_MLDV2_LISTENER_REPORT = 0x68,
  45. MLXSW_TRAP_ID_IPV6_DHCP = 0x69,
  46. MLXSW_TRAP_ID_IPV6_ALL_ROUTERS_LINK = 0x6F,
  47. MLXSW_TRAP_ID_RTR_INGRESS0 = 0x70,
  48. MLXSW_TRAP_ID_RTR_INGRESS1 = 0x71,
  49. MLXSW_TRAP_ID_IPV6_PIM = 0x79,
  50. MLXSW_TRAP_ID_IPV6_VRRP = 0x7A,
  51. MLXSW_TRAP_ID_RTR_EGRESS0 = 0x80,
  52. MLXSW_TRAP_ID_IPV4_BGP = 0x88,
  53. MLXSW_TRAP_ID_IPV6_BGP = 0x89,
  54. MLXSW_TRAP_ID_L3_IPV6_ROUTER_SOLICITATION = 0x8A,
  55. MLXSW_TRAP_ID_L3_IPV6_ROUTER_ADVERTISEMENT = 0x8B,
  56. MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_SOLICITATION = 0x8C,
  57. MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_ADVERTISEMENT = 0x8D,
  58. MLXSW_TRAP_ID_L3_IPV6_REDIRECTION = 0x8E,
  59. MLXSW_TRAP_ID_IPV4_DHCP = 0x8F,
  60. MLXSW_TRAP_ID_HOST_MISS_IPV4 = 0x90,
  61. MLXSW_TRAP_ID_IPV6_MC_LINK_LOCAL_DEST = 0x91,
  62. MLXSW_TRAP_ID_HOST_MISS_IPV6 = 0x92,
  63. MLXSW_TRAP_ID_IPIP_DECAP_ERROR = 0xB1,
  64. MLXSW_TRAP_ID_NVE_DECAP_ARP = 0xB8,
  65. MLXSW_TRAP_ID_NVE_ENCAP_ARP = 0xBD,
  66. MLXSW_TRAP_ID_IPV4_BFD = 0xD0,
  67. MLXSW_TRAP_ID_IPV6_BFD = 0xD1,
  68. MLXSW_TRAP_ID_ROUTER_ALERT_IPV4 = 0xD6,
  69. MLXSW_TRAP_ID_ROUTER_ALERT_IPV6 = 0xD7,
  70. MLXSW_TRAP_ID_ROUTER_ARPBC = 0xE0,
  71. MLXSW_TRAP_ID_ROUTER_ARPUC = 0xE1,
  72. MLXSW_TRAP_ID_DISCARD_NON_ROUTABLE = 0x11A,
  73. MLXSW_TRAP_ID_DISCARD_ROUTER2 = 0x130,
  74. MLXSW_TRAP_ID_DISCARD_ROUTER3 = 0x131,
  75. MLXSW_TRAP_ID_DISCARD_ING_PACKET_SMAC_MC = 0x140,
  76. MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VTAG_ALLOW = 0x148,
  77. MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VLAN = 0x149,
  78. MLXSW_TRAP_ID_DISCARD_ING_SWITCH_STP = 0x14A,
  79. MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_UC = 0x150,
  80. MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_MC_NULL = 0x151,
  81. MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_LB = 0x152,
  82. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_NON_IP_PACKET = 0x160,
  83. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_UC_DIP_MC_DMAC = 0x161,
  84. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LB = 0x162,
  85. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_MC = 0x163,
  86. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_CLASS_E = 0x164,
  87. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_LB = 0x165,
  88. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_CORRUPTED_IP_HDR = 0x167,
  89. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_MC_DMAC = 0x168,
  90. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_DIP = 0x169,
  91. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_SIP_BC = 0x16A,
  92. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_DIP_LOCAL_NET = 0x16B,
  93. MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LINK_LOCAL = 0x16C,
  94. MLXSW_TRAP_ID_DISCARD_ROUTER_IRIF_EN = 0x178,
  95. MLXSW_TRAP_ID_DISCARD_ROUTER_ERIF_EN = 0x179,
  96. MLXSW_TRAP_ID_DISCARD_ROUTER_LPM4 = 0x17B,
  97. MLXSW_TRAP_ID_DISCARD_ROUTER_LPM6 = 0x17C,
  98. MLXSW_TRAP_ID_DISCARD_DEC_PKT = 0x188,
  99. MLXSW_TRAP_ID_DISCARD_OVERLAY_SMAC_MC = 0x190,
  100. MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_RESERVED_SCOPE = 0x1B0,
  101. MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_INTERFACE_LOCAL_SCOPE = 0x1B1,
  102. MLXSW_TRAP_ID_ACL0 = 0x1C0,
  103. /* Multicast trap used for routes with trap action */
  104. MLXSW_TRAP_ID_ACL1 = 0x1C1,
  105. /* Multicast trap used for routes with trap-and-forward action */
  106. MLXSW_TRAP_ID_ACL2 = 0x1C2,
  107. MLXSW_TRAP_ID_DISCARD_INGRESS_ACL = 0x1C3,
  108. MLXSW_TRAP_ID_DISCARD_EGRESS_ACL = 0x1C4,
  109. MLXSW_TRAP_ID_MIRROR_SESSION0 = 0x220,
  110. MLXSW_TRAP_ID_MIRROR_SESSION1 = 0x221,
  111. MLXSW_TRAP_ID_MIRROR_SESSION2 = 0x222,
  112. MLXSW_TRAP_ID_MIRROR_SESSION3 = 0x223,
  113. MLXSW_TRAP_ID_MIRROR_SESSION4 = 0x224,
  114. MLXSW_TRAP_ID_MIRROR_SESSION5 = 0x225,
  115. MLXSW_TRAP_ID_MIRROR_SESSION6 = 0x226,
  116. MLXSW_TRAP_ID_MIRROR_SESSION7 = 0x227,
  117. MLXSW_TRAP_ID_MAX = 0x3FF,
  118. };
  119. enum mlxsw_event_trap_id {
  120. /* Fatal Event generated by FW */
  121. MLXSW_TRAP_ID_MFDE = 0x3,
  122. /* Port Up/Down event generated by hardware */
  123. MLXSW_TRAP_ID_PUDE = 0x8,
  124. /* Port Module Plug/Unplug Event generated by hardware */
  125. MLXSW_TRAP_ID_PMPE = 0x9,
  126. /* Temperature Warning event generated by hardware */
  127. MLXSW_TRAP_ID_MTWE = 0xC,
  128. /* PTP Ingress FIFO has a new entry */
  129. MLXSW_TRAP_ID_PTP_ING_FIFO = 0x2D,
  130. /* PTP Egress FIFO has a new entry */
  131. MLXSW_TRAP_ID_PTP_EGR_FIFO = 0x2E,
  132. /* Downstream Device Status Change */
  133. MLXSW_TRAP_ID_DSDSC = 0x321,
  134. /* Binary Code Transfer Operation Executed Event */
  135. MLXSW_TRAP_ID_BCTOE = 0x322,
  136. /* Port mapping change */
  137. MLXSW_TRAP_ID_PMLPE = 0x32E,
  138. };
  139. #endif /* _MLXSW_TRAP_H */