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, 5552d45575SIdo Schimmel MLXSW_TRAP_ID_RTR_EGRESS0 = 0x80, 568d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_IPV4_BGP = 0x88, 578d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_IPV6_BGP = 0x89, 588d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_L3_IPV6_ROUTER_SOLICITATION = 0x8A, 59154388e1SIdo Schimmel MLXSW_TRAP_ID_L3_IPV6_ROUTER_ADVERTISEMENT = 0x8B, 608d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_SOLICITATION = 0x8C, 61154388e1SIdo Schimmel MLXSW_TRAP_ID_L3_IPV6_NEIGHBOR_ADVERTISEMENT = 0x8D, 628d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_L3_IPV6_REDIRECTION = 0x8E, 630ecb9474SIdo Schimmel MLXSW_TRAP_ID_IPV4_DHCP = 0x8F, 647b27ce7bSJiri Pirko MLXSW_TRAP_ID_HOST_MISS_IPV4 = 0x90, 658d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_IPV6_MC_LINK_LOCAL_DEST = 0x91, 668d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_HOST_MISS_IPV6 = 0x92, 6786484de2SPetr Machata MLXSW_TRAP_ID_IPIP_DECAP_ERROR = 0xB1, 685d504391SIdo Schimmel MLXSW_TRAP_ID_NVE_DECAP_ARP = 0xB8, 69b02597d5SIdo Schimmel MLXSW_TRAP_ID_NVE_ENCAP_ARP = 0xBD, 709785b92bSIdo Schimmel MLXSW_TRAP_ID_IPV4_BFD = 0xD0, 719785b92bSIdo Schimmel MLXSW_TRAP_ID_IPV6_BFD = 0xD1, 727607dd35SIdo Schimmel MLXSW_TRAP_ID_ROUTER_ALERT_IPV4 = 0xD6, 738d54814eSArkadi Sharshevsky MLXSW_TRAP_ID_ROUTER_ALERT_IPV6 = 0xD7, 74196442ecSAmit Cohen MLXSW_TRAP_ID_DISCARD_NON_ROUTABLE = 0x11A, 75dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ROUTER2 = 0x130, 760c3cbbf9SAmit Cohen MLXSW_TRAP_ID_DISCARD_ROUTER3 = 0x131, 77a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_ING_PACKET_SMAC_MC = 0x140, 78a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VTAG_ALLOW = 0x148, 79a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_ING_SWITCH_VLAN = 0x149, 80a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_ING_SWITCH_STP = 0x14A, 81a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_UC = 0x150, 82a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_MC_NULL = 0x151, 83a812cedbSIdo Schimmel MLXSW_TRAP_ID_DISCARD_LOOKUP_SWITCH_LB = 0x152, 84dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_NON_IP_PACKET = 0x160, 85dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_UC_DIP_MC_DMAC = 0x161, 86dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LB = 0x162, 87dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_MC = 0x163, 8862b0fb09SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_CLASS_E = 0x164, 89dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_LB = 0x165, 90dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_CORRUPTED_IP_HDR = 0x167, 91359ec566SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_MC_DMAC = 0x168, 92e317b0f7SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_SIP_DIP = 0x169, 93dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_SIP_BC = 0x16A, 94dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_IPV4_DIP_LOCAL_NET = 0x16B, 95ca360db4SAmit Cohen MLXSW_TRAP_ID_DISCARD_ING_ROUTER_DIP_LINK_LOCAL = 0x16C, 965b051621SAmit Cohen MLXSW_TRAP_ID_DISCARD_ROUTER_IRIF_EN = 0x178, 975b051621SAmit Cohen MLXSW_TRAP_ID_DISCARD_ROUTER_ERIF_EN = 0x179, 98fd74feebSAmit Cohen MLXSW_TRAP_ID_DISCARD_ROUTER_LPM4 = 0x17B, 99fd74feebSAmit Cohen MLXSW_TRAP_ID_DISCARD_ROUTER_LPM6 = 0x17C, 100a318bf62SAmit Cohen MLXSW_TRAP_ID_DISCARD_DEC_PKT = 0x188, 1013aed0722SAmit Cohen MLXSW_TRAP_ID_DISCARD_OVERLAY_SMAC_MC = 0x190, 102dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_RESERVED_SCOPE = 0x1B0, 103dbc684f1SAmit Cohen MLXSW_TRAP_ID_DISCARD_IPV6_MC_DIP_INTERFACE_LOCAL_SCOPE = 0x1B1, 1040db7b386SJiri Pirko MLXSW_TRAP_ID_ACL0 = 0x1C0, 105b48cfc80SYotam Gigi /* Multicast trap used for routes with trap action */ 106b48cfc80SYotam Gigi MLXSW_TRAP_ID_ACL1 = 0x1C1, 107a0040c8cSYotam Gigi /* Multicast trap used for routes with trap-and-forward action */ 108a0040c8cSYotam Gigi MLXSW_TRAP_ID_ACL2 = 0x1C2, 1093e6cacafSJiri Pirko MLXSW_TRAP_ID_DISCARD_INGRESS_ACL = 0x1C3, 1103e6cacafSJiri Pirko MLXSW_TRAP_ID_DISCARD_EGRESS_ACL = 0x1C4, 1110cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION0 = 0x220, 1120cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION1 = 0x221, 1130cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION2 = 0x222, 1140cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION3 = 0x223, 1150cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION4 = 0x224, 1160cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION5 = 0x225, 1170cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION6 = 0x226, 1180cc32c5bSIdo Schimmel MLXSW_TRAP_ID_MIRROR_SESSION7 = 0x227, 11993c1edb2SJiri Pirko 12047e4b162SAmit Cohen MLXSW_TRAP_ID_MAX = 0x3FF, 12193c1edb2SJiri Pirko }; 12293c1edb2SJiri Pirko 12393c1edb2SJiri Pirko enum mlxsw_event_trap_id { 1247d83ee11SJiri Pirko /* Fatal Event generated by FW */ 1257d83ee11SJiri Pirko MLXSW_TRAP_ID_MFDE = 0x3, 12693c1edb2SJiri Pirko /* Port Up/Down event generated by hardware */ 12793c1edb2SJiri Pirko MLXSW_TRAP_ID_PUDE = 0x8, 12805cf5828SAmit Cohen /* Port Module Plug/Unplug Event generated by hardware */ 12905cf5828SAmit Cohen MLXSW_TRAP_ID_PMPE = 0x9, 130943585c9SAmit Cohen /* Temperature Warning event generated by hardware */ 131943585c9SAmit Cohen MLXSW_TRAP_ID_MTWE = 0xC, 132d92e4e6eSPetr Machata /* PTP Ingress FIFO has a new entry */ 133d92e4e6eSPetr Machata MLXSW_TRAP_ID_PTP_ING_FIFO = 0x2D, 134d92e4e6eSPetr Machata /* PTP Egress FIFO has a new entry */ 135d92e4e6eSPetr Machata MLXSW_TRAP_ID_PTP_EGR_FIFO = 0x2E, 136*b217127eSJiri Pirko /* Downstream Device Status Change */ 137*b217127eSJiri Pirko MLXSW_TRAP_ID_DSDSC = 0x321, 138*b217127eSJiri Pirko /* Binary Code Transfer Operation Executed Event */ 139*b217127eSJiri Pirko MLXSW_TRAP_ID_BCTOE = 0x322, 140b0ec003eSJiri Pirko /* Port mapping change */ 141b0ec003eSJiri Pirko MLXSW_TRAP_ID_PMLPE = 0x32E, 14293c1edb2SJiri Pirko }; 14393c1edb2SJiri Pirko 14493c1edb2SJiri Pirko #endif /* _MLXSW_TRAP_H */ 145