xref: /linux/drivers/net/ethernet/mellanox/mlxsw/trap.h (revision 62b0fb099ce2559293913d5bacf0c3aef08324e1)
19948a064SJiri Pirko /* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
29948a064SJiri Pirko /* Copyright (c) 2015-2018 Mellanox Technologies. All rights reserved */
39948a064SJiri Pirko 
493c1edb2SJiri Pirko #ifndef _MLXSW_TRAP_H
593c1edb2SJiri Pirko #define _MLXSW_TRAP_H
693c1edb2SJiri Pirko 
793c1edb2SJiri Pirko enum {
893c1edb2SJiri Pirko 	/* Ethernet EMAD and FDB miss */
993c1edb2SJiri Pirko 	MLXSW_TRAP_ID_FDB_MC = 0x01,
1093c1edb2SJiri Pirko 	MLXSW_TRAP_ID_ETHEMAD = 0x05,
1193c1edb2SJiri Pirko 	/* L2 traps for specific packet types */
1293c1edb2SJiri Pirko 	MLXSW_TRAP_ID_STP = 0x10,
1393c1edb2SJiri Pirko 	MLXSW_TRAP_ID_LACP = 0x11,
1493c1edb2SJiri Pirko 	MLXSW_TRAP_ID_EAPOL = 0x12,
1593c1edb2SJiri Pirko 	MLXSW_TRAP_ID_LLDP = 0x13,
1693c1edb2SJiri Pirko 	MLXSW_TRAP_ID_MMRP = 0x14,
1793c1edb2SJiri Pirko 	MLXSW_TRAP_ID_MVRP = 0x15,
1893c1edb2SJiri Pirko 	MLXSW_TRAP_ID_RPVST = 0x16,
1993c1edb2SJiri Pirko 	MLXSW_TRAP_ID_DHCP = 0x19,
20aed4b572SPetr Machata 	MLXSW_TRAP_ID_PTP0 = 0x28,
21aed4b572SPetr Machata 	MLXSW_TRAP_ID_PTP1 = 0x29,
2293c1edb2SJiri Pirko 	MLXSW_TRAP_ID_IGMP_QUERY = 0x30,
2393c1edb2SJiri Pirko 	MLXSW_TRAP_ID_IGMP_V1_REPORT = 0x31,
2493c1edb2SJiri Pirko 	MLXSW_TRAP_ID_IGMP_V2_REPORT = 0x32,
2593c1edb2SJiri Pirko 	MLXSW_TRAP_ID_IGMP_V2_LEAVE = 0x33,
2693c1edb2SJiri Pirko 	MLXSW_TRAP_ID_IGMP_V3_REPORT = 0x34,
2798d0f7b9SYotam Gigi 	MLXSW_TRAP_ID_PKT_SAMPLE = 0x38,
289d41acccSJiri Pirko 	MLXSW_TRAP_ID_FID_MISS = 0x3D,
29b02597d5SIdo Schimmel 	MLXSW_TRAP_ID_DECAP_ECN0 = 0x40,
307b27ce7bSJiri Pirko 	MLXSW_TRAP_ID_ARPBC = 0x50,
317b27ce7bSJiri Pirko 	MLXSW_TRAP_ID_ARPUC = 0x51,
32c20b8018SElad Raz 	MLXSW_TRAP_ID_MTUERROR = 0x52,
33c20b8018SElad Raz 	MLXSW_TRAP_ID_TTLERROR = 0x53,
34a94a614fSIdo Schimmel 	MLXSW_TRAP_ID_LBERROR = 0x54,
358d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV4_OSPF = 0x55,
36b48cfc80SYotam Gigi 	MLXSW_TRAP_ID_IPV4_PIM = 0x58,
3711566d34SIdo Schimmel 	MLXSW_TRAP_ID_IPV4_VRRP = 0x59,
38b48cfc80SYotam Gigi 	MLXSW_TRAP_ID_RPF = 0x5C,
397b27ce7bSJiri Pirko 	MLXSW_TRAP_ID_IP2ME = 0x5F,
408d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_UNSPECIFIED_ADDRESS = 0x60,
418d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_LINK_LOCAL_DEST = 0x61,
428d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_LINK_LOCAL_SRC = 0x62,
438d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_ALL_NODES_LINK = 0x63,
448d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_OSPF = 0x64,
45588823f9SArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_MLDV12_LISTENER_QUERY = 0x65,
46588823f9SArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_MLDV1_LISTENER_REPORT = 0x66,
47588823f9SArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_MLDV1_LISTENER_DONE = 0x67,
48588823f9SArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_MLDV2_LISTENER_REPORT = 0x68,
498d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_DHCP = 0x69,
508d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_ALL_ROUTERS_LINK = 0x6F,
517b27ce7bSJiri Pirko 	MLXSW_TRAP_ID_RTR_INGRESS0 = 0x70,
5221151f64SAmit Cohen 	MLXSW_TRAP_ID_RTR_INGRESS1 = 0x71,
536a170d32SYuval Mintz 	MLXSW_TRAP_ID_IPV6_PIM = 0x79,
5411566d34SIdo Schimmel 	MLXSW_TRAP_ID_IPV6_VRRP = 0x7A,
558d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV4_BGP = 0x88,
568d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_BGP = 0x89,
578d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_L3_IPV6_ROUTER_SOLICITATION = 0x8A,
588d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_L3_IPV6_ROUTER_ADVERTISMENT = 0x8B,
598d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_SOLICITATION = 0x8C,
608d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_ADVERTISMENT = 0x8D,
618d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_L3_IPV6_REDIRECTION = 0x8E,
627b27ce7bSJiri Pirko 	MLXSW_TRAP_ID_HOST_MISS_IPV4 = 0x90,
638d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_IPV6_MC_LINK_LOCAL_DEST = 0x91,
648d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_HOST_MISS_IPV6 = 0x92,
6586484de2SPetr Machata 	MLXSW_TRAP_ID_IPIP_DECAP_ERROR = 0xB1,
665d504391SIdo Schimmel 	MLXSW_TRAP_ID_NVE_DECAP_ARP = 0xB8,
67b02597d5SIdo Schimmel 	MLXSW_TRAP_ID_NVE_ENCAP_ARP = 0xBD,
687607dd35SIdo Schimmel 	MLXSW_TRAP_ID_ROUTER_ALERT_IPV4 = 0xD6,
698d54814eSArkadi Sharshevsky 	MLXSW_TRAP_ID_ROUTER_ALERT_IPV6 = 0xD7,
70dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ROUTER2 = 0x130,
710c3cbbf9SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ROUTER3 = 0x131,
72a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_ING_PACKET_SMAC_MC = 0x140,
73a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VTAG_ALLOW = 0x148,
74a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VLAN = 0x149,
75a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_ING_SWITCH_STP = 0x14A,
76a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_UC = 0x150,
77a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_MC_NULL = 0x151,
78a812cedbSIdo Schimmel 	MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_LB = 0x152,
79dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_NON_IP_PACKET = 0x160,
80dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_UC_DIP_MC_DMAC = 0x161,
81dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LB = 0x162,
82dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_MC = 0x163,
83*62b0fb09SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_CLASS_E = 0x164,
84dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_LB = 0x165,
85dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_CORRUPTED_IP_HDR = 0x167,
86dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_SIP_BC = 0x16A,
87dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_DIP_LOCAL_NET = 0x16B,
88fd74feebSAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ROUTER_LPM4 = 0x17B,
89fd74feebSAmit Cohen 	MLXSW_TRAP_ID_DISCARD_ROUTER_LPM6 = 0x17C,
90dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_RESERVED_SCOPE = 0x1B0,
91dbc684f1SAmit Cohen 	MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_INTERFACE_LOCAL_SCOPE = 0x1B1,
920db7b386SJiri Pirko 	MLXSW_TRAP_ID_ACL0 = 0x1C0,
93b48cfc80SYotam Gigi 	/* Multicast trap used for routes with trap action */
94b48cfc80SYotam Gigi 	MLXSW_TRAP_ID_ACL1 = 0x1C1,
95a0040c8cSYotam Gigi 	/* Multicast trap used for routes with trap-and-forward action */
96a0040c8cSYotam Gigi 	MLXSW_TRAP_ID_ACL2 = 0x1C2,
9793c1edb2SJiri Pirko 
9893c1edb2SJiri Pirko 	MLXSW_TRAP_ID_MAX = 0x1FF
9993c1edb2SJiri Pirko };
10093c1edb2SJiri Pirko 
10193c1edb2SJiri Pirko enum mlxsw_event_trap_id {
10293c1edb2SJiri Pirko 	/* Port Up/Down event generated by hardware */
10393c1edb2SJiri Pirko 	MLXSW_TRAP_ID_PUDE = 0x8,
104d92e4e6eSPetr Machata 	/* PTP Ingress FIFO has a new entry */
105d92e4e6eSPetr Machata 	MLXSW_TRAP_ID_PTP_ING_FIFO = 0x2D,
106d92e4e6eSPetr Machata 	/* PTP Egress FIFO has a new entry */
107d92e4e6eSPetr Machata 	MLXSW_TRAP_ID_PTP_EGR_FIFO = 0x2E,
10893c1edb2SJiri Pirko };
10993c1edb2SJiri Pirko 
11093c1edb2SJiri Pirko #endif /* _MLXSW_TRAP_H */
111