162306a36Sopenharmony_ci/* SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 */
262306a36Sopenharmony_ci/* Copyright (c) 2015-2018 Mellanox Technologies. All rights reserved */
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci#ifndef _MLXSW_TRAP_H
562306a36Sopenharmony_ci#define _MLXSW_TRAP_H
662306a36Sopenharmony_ci
762306a36Sopenharmony_cienum {
862306a36Sopenharmony_ci	/* Ethernet EMAD and FDB miss */
962306a36Sopenharmony_ci	MLXSW_TRAP_ID_FDB_MC = 0x01,
1062306a36Sopenharmony_ci	MLXSW_TRAP_ID_ETHEMAD = 0x05,
1162306a36Sopenharmony_ci	/* L2 traps for specific packet types */
1262306a36Sopenharmony_ci	MLXSW_TRAP_ID_STP = 0x10,
1362306a36Sopenharmony_ci	MLXSW_TRAP_ID_LACP = 0x11,
1462306a36Sopenharmony_ci	MLXSW_TRAP_ID_EAPOL = 0x12,
1562306a36Sopenharmony_ci	MLXSW_TRAP_ID_LLDP = 0x13,
1662306a36Sopenharmony_ci	MLXSW_TRAP_ID_MMRP = 0x14,
1762306a36Sopenharmony_ci	MLXSW_TRAP_ID_MVRP = 0x15,
1862306a36Sopenharmony_ci	MLXSW_TRAP_ID_RPVST = 0x16,
1962306a36Sopenharmony_ci	MLXSW_TRAP_ID_DHCP = 0x19,
2062306a36Sopenharmony_ci	MLXSW_TRAP_ID_PTP0 = 0x28,
2162306a36Sopenharmony_ci	MLXSW_TRAP_ID_PTP1 = 0x29,
2262306a36Sopenharmony_ci	MLXSW_TRAP_ID_IGMP_QUERY = 0x30,
2362306a36Sopenharmony_ci	MLXSW_TRAP_ID_IGMP_V1_REPORT = 0x31,
2462306a36Sopenharmony_ci	MLXSW_TRAP_ID_IGMP_V2_REPORT = 0x32,
2562306a36Sopenharmony_ci	MLXSW_TRAP_ID_IGMP_V2_LEAVE = 0x33,
2662306a36Sopenharmony_ci	MLXSW_TRAP_ID_IGMP_V3_REPORT = 0x34,
2762306a36Sopenharmony_ci	MLXSW_TRAP_ID_PKT_SAMPLE = 0x38,
2862306a36Sopenharmony_ci	MLXSW_TRAP_ID_FDB_MISS = 0x3A,
2962306a36Sopenharmony_ci	MLXSW_TRAP_ID_FDB_MISMATCH = 0x3B,
3062306a36Sopenharmony_ci	MLXSW_TRAP_ID_FID_MISS = 0x3D,
3162306a36Sopenharmony_ci	MLXSW_TRAP_ID_DECAP_ECN0 = 0x40,
3262306a36Sopenharmony_ci	MLXSW_TRAP_ID_MTUERROR = 0x52,
3362306a36Sopenharmony_ci	MLXSW_TRAP_ID_TTLERROR = 0x53,
3462306a36Sopenharmony_ci	MLXSW_TRAP_ID_LBERROR = 0x54,
3562306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV4_OSPF = 0x55,
3662306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV4_PIM = 0x58,
3762306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV4_VRRP = 0x59,
3862306a36Sopenharmony_ci	MLXSW_TRAP_ID_RPF = 0x5C,
3962306a36Sopenharmony_ci	MLXSW_TRAP_ID_IP2ME = 0x5F,
4062306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_UNSPECIFIED_ADDRESS = 0x60,
4162306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_LINK_LOCAL_DEST = 0x61,
4262306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_LINK_LOCAL_SRC = 0x62,
4362306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_ALL_NODES_LINK = 0x63,
4462306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_OSPF = 0x64,
4562306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_MLDV12_LISTENER_QUERY = 0x65,
4662306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_MLDV1_LISTENER_REPORT = 0x66,
4762306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_MLDV1_LISTENER_DONE = 0x67,
4862306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_MLDV2_LISTENER_REPORT = 0x68,
4962306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_DHCP = 0x69,
5062306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_ALL_ROUTERS_LINK = 0x6F,
5162306a36Sopenharmony_ci	MLXSW_TRAP_ID_RTR_INGRESS0 = 0x70,
5262306a36Sopenharmony_ci	MLXSW_TRAP_ID_RTR_INGRESS1 = 0x71,
5362306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_PIM = 0x79,
5462306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_VRRP = 0x7A,
5562306a36Sopenharmony_ci	MLXSW_TRAP_ID_RTR_EGRESS0 = 0x80,
5662306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV4_BGP = 0x88,
5762306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_BGP = 0x89,
5862306a36Sopenharmony_ci	MLXSW_TRAP_ID_L3_IPV6_ROUTER_SOLICITATION = 0x8A,
5962306a36Sopenharmony_ci	MLXSW_TRAP_ID_L3_IPV6_ROUTER_ADVERTISEMENT = 0x8B,
6062306a36Sopenharmony_ci	MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_SOLICITATION = 0x8C,
6162306a36Sopenharmony_ci	MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_ADVERTISEMENT = 0x8D,
6262306a36Sopenharmony_ci	MLXSW_TRAP_ID_L3_IPV6_REDIRECTION = 0x8E,
6362306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV4_DHCP = 0x8F,
6462306a36Sopenharmony_ci	MLXSW_TRAP_ID_HOST_MISS_IPV4 = 0x90,
6562306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_MC_LINK_LOCAL_DEST = 0x91,
6662306a36Sopenharmony_ci	MLXSW_TRAP_ID_HOST_MISS_IPV6 = 0x92,
6762306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPIP_DECAP_ERROR = 0xB1,
6862306a36Sopenharmony_ci	MLXSW_TRAP_ID_NVE_DECAP_ARP = 0xB8,
6962306a36Sopenharmony_ci	MLXSW_TRAP_ID_NVE_ENCAP_ARP = 0xBD,
7062306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV4_BFD = 0xD0,
7162306a36Sopenharmony_ci	MLXSW_TRAP_ID_IPV6_BFD = 0xD1,
7262306a36Sopenharmony_ci	MLXSW_TRAP_ID_ROUTER_ALERT_IPV4 = 0xD6,
7362306a36Sopenharmony_ci	MLXSW_TRAP_ID_ROUTER_ALERT_IPV6 = 0xD7,
7462306a36Sopenharmony_ci	MLXSW_TRAP_ID_ROUTER_ARPBC = 0xE0,
7562306a36Sopenharmony_ci	MLXSW_TRAP_ID_ROUTER_ARPUC = 0xE1,
7662306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_NON_ROUTABLE = 0x11A,
7762306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ROUTER2 = 0x130,
7862306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ROUTER3 = 0x131,
7962306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_PACKET_SMAC_MC = 0x140,
8062306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VTAG_ALLOW = 0x148,
8162306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VLAN = 0x149,
8262306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_SWITCH_STP = 0x14A,
8362306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_UC = 0x150,
8462306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_MC_NULL = 0x151,
8562306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_LB = 0x152,
8662306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_NON_IP_PACKET = 0x160,
8762306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_UC_DIP_MC_DMAC = 0x161,
8862306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LB = 0x162,
8962306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_MC = 0x163,
9062306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_CLASS_E = 0x164,
9162306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_LB = 0x165,
9262306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_CORRUPTED_IP_HDR = 0x167,
9362306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_MC_DMAC = 0x168,
9462306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_DIP = 0x169,
9562306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_SIP_BC = 0x16A,
9662306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_DIP_LOCAL_NET = 0x16B,
9762306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LINK_LOCAL = 0x16C,
9862306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ROUTER_IRIF_EN = 0x178,
9962306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ROUTER_ERIF_EN = 0x179,
10062306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ROUTER_LPM4 = 0x17B,
10162306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_ROUTER_LPM6 = 0x17C,
10262306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_DEC_PKT = 0x188,
10362306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_OVERLAY_SMAC_MC = 0x190,
10462306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_RESERVED_SCOPE = 0x1B0,
10562306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_INTERFACE_LOCAL_SCOPE = 0x1B1,
10662306a36Sopenharmony_ci	MLXSW_TRAP_ID_ACL0 = 0x1C0,
10762306a36Sopenharmony_ci	/* Multicast trap used for routes with trap action */
10862306a36Sopenharmony_ci	MLXSW_TRAP_ID_ACL1 = 0x1C1,
10962306a36Sopenharmony_ci	/* Multicast trap used for routes with trap-and-forward action */
11062306a36Sopenharmony_ci	MLXSW_TRAP_ID_ACL2 = 0x1C2,
11162306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_INGRESS_ACL = 0x1C3,
11262306a36Sopenharmony_ci	MLXSW_TRAP_ID_DISCARD_EGRESS_ACL = 0x1C4,
11362306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION0 = 0x220,
11462306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION1 = 0x221,
11562306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION2 = 0x222,
11662306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION3 = 0x223,
11762306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION4 = 0x224,
11862306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION5 = 0x225,
11962306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION6 = 0x226,
12062306a36Sopenharmony_ci	MLXSW_TRAP_ID_MIRROR_SESSION7 = 0x227,
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_ci	MLXSW_TRAP_ID_MAX = 0x3FF,
12362306a36Sopenharmony_ci};
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_cienum mlxsw_event_trap_id {
12662306a36Sopenharmony_ci	/* Fatal Event generated by FW */
12762306a36Sopenharmony_ci	MLXSW_TRAP_ID_MFDE = 0x3,
12862306a36Sopenharmony_ci	/* Port Up/Down event generated by hardware */
12962306a36Sopenharmony_ci	MLXSW_TRAP_ID_PUDE = 0x8,
13062306a36Sopenharmony_ci	/* Port Module Plug/Unplug Event generated by hardware */
13162306a36Sopenharmony_ci	MLXSW_TRAP_ID_PMPE = 0x9,
13262306a36Sopenharmony_ci	/* Temperature Warning event generated by hardware */
13362306a36Sopenharmony_ci	MLXSW_TRAP_ID_MTWE = 0xC,
13462306a36Sopenharmony_ci	/* PTP Ingress FIFO has a new entry */
13562306a36Sopenharmony_ci	MLXSW_TRAP_ID_PTP_ING_FIFO = 0x2D,
13662306a36Sopenharmony_ci	/* PTP Egress FIFO has a new entry */
13762306a36Sopenharmony_ci	MLXSW_TRAP_ID_PTP_EGR_FIFO = 0x2E,
13862306a36Sopenharmony_ci	/* Downstream Device Status Change */
13962306a36Sopenharmony_ci	MLXSW_TRAP_ID_DSDSC = 0x321,
14062306a36Sopenharmony_ci	/* Binary Code Transfer Operation Executed Event */
14162306a36Sopenharmony_ci	MLXSW_TRAP_ID_BCTOE = 0x322,
14262306a36Sopenharmony_ci	/* Port mapping change */
14362306a36Sopenharmony_ci	MLXSW_TRAP_ID_PMLPE = 0x32E,
14462306a36Sopenharmony_ci};
14562306a36Sopenharmony_ci
14662306a36Sopenharmony_ci#endif /* _MLXSW_TRAP_H */
147