xref: /OK3568_Linux_fs/kernel/drivers/net/ethernet/mellanox/mlxsw/trap.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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