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