66#define DEFINE_DROP_REASON (FN , FNe ) \
77 FN(NOT_SPECIFIED) \
88 FN(NO_SOCKET) \
9+ FN(SOCKET_CLOSE) \
10+ FN(SOCKET_FILTER) \
11+ FN(SOCKET_RCVBUFF) \
12+ FN(UNIX_DISCONNECT) \
13+ FN(UNIX_SKIP_OOB) \
914 FN(PKT_TOO_SMALL) \
1015 FN(TCP_CSUM) \
11- FN(SOCKET_FILTER) \
1216 FN(UDP_CSUM) \
1317 FN(NETFILTER_DROP) \
1418 FN(OTHERHOST) \
1822 FN(UNICAST_IN_L2_MULTICAST) \
1923 FN(XFRM_POLICY) \
2024 FN(IP_NOPROTO) \
21- FN(SOCKET_RCVBUFF) \
2225 FN(PROTO_MEM) \
2326 FN(TCP_AUTH_HDR) \
2427 FN(TCP_MD5NOTFOUND) \
3639 FN(TCP_OVERWINDOW) \
3740 FN(TCP_OFOMERGE) \
3841 FN(TCP_RFC7323_PAWS) \
42+ FN(TCP_RFC7323_PAWS_ACK) \
43+ FN(TCP_RFC7323_TW_PAWS) \
44+ FN(TCP_RFC7323_TSECR) \
45+ FN(TCP_LISTEN_OVERFLOW) \
3946 FN(TCP_OLD_SEQUENCE) \
4047 FN(TCP_INVALID_SEQUENCE) \
4148 FN(TCP_INVALID_ACK_SEQUENCE) \
5865 FN(TC_EGRESS) \
5966 FN(SECURITY_HOOK) \
6067 FN(QDISC_DROP) \
68+ FN(QDISC_OVERLIMIT) \
69+ FN(QDISC_CONGESTED) \
70+ FN(CAKE_FLOOD) \
71+ FN(FQ_BAND_LIMIT) \
72+ FN(FQ_HORIZON_LIMIT) \
73+ FN(FQ_FLOW_LIMIT) \
6174 FN(CPU_BACKLOG) \
6275 FN(XDP) \
6376 FN(TC_INGRESS) \
7689 FN(INVALID_PROTO) \
7790 FN(IP_INADDRERRORS) \
7891 FN(IP_INNOROUTES) \
92+ FN(IP_LOCAL_SOURCE) \
93+ FN(IP_INVALID_SOURCE) \
94+ FN(IP_LOCALNET) \
95+ FN(IP_INVALID_DEST) \
7996 FN(PKT_TOO_BIG) \
8097 FN(DUP_FRAG) \
8198 FN(FRAG_REASM_TIMEOUT) \
96113 FN(VXLAN_VNI_NOT_FOUND) \
97114 FN(MAC_INVALID_SOURCE) \
98115 FN(VXLAN_ENTRY_EXISTS) \
99- FN(VXLAN_NO_REMOTE ) \
116+ FN(NO_TX_TARGET ) \
100117 FN(IP_TUNNEL_ECN) \
101118 FN(TUNNEL_TXINFO) \
102119 FN(LOCAL_MAC) \
120+ FN(ARP_PVLAN_DISABLE) \
121+ FN(MAC_IEEE_MAC_CONTROL) \
122+ FN(BRIDGE_INGRESS_STP_STATE) \
103123 FNe(MAX)
104124
105125/**
@@ -124,12 +144,27 @@ enum skb_drop_reason {
124144 * 3) no valid child socket during 3WHS process
125145 */
126146 SKB_DROP_REASON_NO_SOCKET ,
147+ /** @SKB_DROP_REASON_SOCKET_CLOSE: socket is close()d */
148+ SKB_DROP_REASON_SOCKET_CLOSE ,
149+ /** @SKB_DROP_REASON_SOCKET_FILTER: dropped by socket filter */
150+ SKB_DROP_REASON_SOCKET_FILTER ,
151+ /** @SKB_DROP_REASON_SOCKET_RCVBUFF: socket receive buff is full */
152+ SKB_DROP_REASON_SOCKET_RCVBUFF ,
153+ /**
154+ * @SKB_DROP_REASON_UNIX_DISCONNECT: recv queue is purged when SOCK_DGRAM
155+ * or SOCK_SEQPACKET socket re-connect()s to another socket or notices
156+ * during send() that the peer has been close()d.
157+ */
158+ SKB_DROP_REASON_UNIX_DISCONNECT ,
159+ /**
160+ * @SKB_DROP_REASON_UNIX_SKIP_OOB: Out-Of-Band data is skipped by
161+ * recv() without MSG_OOB so dropped.
162+ */
163+ SKB_DROP_REASON_UNIX_SKIP_OOB ,
127164 /** @SKB_DROP_REASON_PKT_TOO_SMALL: packet size is too small */
128165 SKB_DROP_REASON_PKT_TOO_SMALL ,
129166 /** @SKB_DROP_REASON_TCP_CSUM: TCP checksum error */
130167 SKB_DROP_REASON_TCP_CSUM ,
131- /** @SKB_DROP_REASON_SOCKET_FILTER: dropped by socket filter */
132- SKB_DROP_REASON_SOCKET_FILTER ,
133168 /** @SKB_DROP_REASON_UDP_CSUM: UDP checksum error */
134169 SKB_DROP_REASON_UDP_CSUM ,
135170 /** @SKB_DROP_REASON_NETFILTER_DROP: dropped by netfilter */
@@ -160,8 +195,6 @@ enum skb_drop_reason {
160195 SKB_DROP_REASON_XFRM_POLICY ,
161196 /** @SKB_DROP_REASON_IP_NOPROTO: no support for IP protocol */
162197 SKB_DROP_REASON_IP_NOPROTO ,
163- /** @SKB_DROP_REASON_SOCKET_RCVBUFF: socket receive buff is full */
164- SKB_DROP_REASON_SOCKET_RCVBUFF ,
165198 /**
166199 * @SKB_DROP_REASON_PROTO_MEM: proto memory limitation, such as
167200 * udp packet drop out of udp_memory_allocated.
@@ -246,6 +279,24 @@ enum skb_drop_reason {
246279 * LINUX_MIB_PAWSESTABREJECTED, LINUX_MIB_PAWSACTIVEREJECTED
247280 */
248281 SKB_DROP_REASON_TCP_RFC7323_PAWS ,
282+ /**
283+ * @SKB_DROP_REASON_TCP_RFC7323_PAWS_ACK: PAWS check, old ACK packet.
284+ * Corresponds to LINUX_MIB_PAWS_OLD_ACK.
285+ */
286+ SKB_DROP_REASON_TCP_RFC7323_PAWS_ACK ,
287+ /**
288+ * @SKB_DROP_REASON_TCP_RFC7323_TW_PAWS: PAWS check, socket is in
289+ * TIME_WAIT state.
290+ * Corresponds to LINUX_MIB_PAWS_TW_REJECTED.
291+ */
292+ SKB_DROP_REASON_TCP_RFC7323_TW_PAWS ,
293+ /**
294+ * @SKB_DROP_REASON_TCP_RFC7323_TSECR: PAWS check, invalid TSEcr.
295+ * Corresponds to LINUX_MIB_TSECRREJECTED.
296+ */
297+ SKB_DROP_REASON_TCP_RFC7323_TSECR ,
298+ /** @SKB_DROP_REASON_TCP_LISTEN_OVERFLOW: listener queue full. */
299+ SKB_DROP_REASON_TCP_LISTEN_OVERFLOW ,
249300 /** @SKB_DROP_REASON_TCP_OLD_SEQUENCE: Old SEQ field (duplicate packet) */
250301 SKB_DROP_REASON_TCP_OLD_SEQUENCE ,
251302 /** @SKB_DROP_REASON_TCP_INVALID_SEQUENCE: Not acceptable SEQ field */
@@ -306,6 +357,36 @@ enum skb_drop_reason {
306357 * failed to enqueue to current qdisc)
307358 */
308359 SKB_DROP_REASON_QDISC_DROP ,
360+ /**
361+ * @SKB_DROP_REASON_QDISC_OVERLIMIT: dropped by qdisc when a qdisc
362+ * instance exceeds its total buffer size limit.
363+ */
364+ SKB_DROP_REASON_QDISC_OVERLIMIT ,
365+ /**
366+ * @SKB_DROP_REASON_QDISC_CONGESTED: dropped by a qdisc AQM algorithm
367+ * due to congestion.
368+ */
369+ SKB_DROP_REASON_QDISC_CONGESTED ,
370+ /**
371+ * @SKB_DROP_REASON_CAKE_FLOOD: dropped by the flood protection part of
372+ * CAKE qdisc AQM algorithm (BLUE).
373+ */
374+ SKB_DROP_REASON_CAKE_FLOOD ,
375+ /**
376+ * @SKB_DROP_REASON_FQ_BAND_LIMIT: dropped by fq qdisc when per band
377+ * limit is reached.
378+ */
379+ SKB_DROP_REASON_FQ_BAND_LIMIT ,
380+ /**
381+ * @SKB_DROP_REASON_FQ_HORIZON_LIMIT: dropped by fq qdisc when packet
382+ * timestamp is too far in the future.
383+ */
384+ SKB_DROP_REASON_FQ_HORIZON_LIMIT ,
385+ /**
386+ * @SKB_DROP_REASON_FQ_FLOW_LIMIT: dropped by fq qdisc when a flow
387+ * exceeds its limits.
388+ */
389+ SKB_DROP_REASON_FQ_FLOW_LIMIT ,
309390 /**
310391 * @SKB_DROP_REASON_CPU_BACKLOG: failed to enqueue the skb to the per CPU
311392 * backlog queue. This can be caused by backlog queue full (see
@@ -373,6 +454,21 @@ enum skb_drop_reason {
373454 * IPSTATS_MIB_INADDRERRORS
374455 */
375456 SKB_DROP_REASON_IP_INNOROUTES ,
457+ /** @SKB_DROP_REASON_IP_LOCAL_SOURCE: the source ip is local */
458+ SKB_DROP_REASON_IP_LOCAL_SOURCE ,
459+ /**
460+ * @SKB_DROP_REASON_IP_INVALID_SOURCE: the source ip is invalid:
461+ * 1) source ip is multicast or limited broadcast
462+ * 2) source ip is zero and not IGMP
463+ */
464+ SKB_DROP_REASON_IP_INVALID_SOURCE ,
465+ /** @SKB_DROP_REASON_IP_LOCALNET: source or dest ip is local net */
466+ SKB_DROP_REASON_IP_LOCALNET ,
467+ /**
468+ * @SKB_DROP_REASON_IP_INVALID_DEST: the dest ip is invalid:
469+ * 1) dest ip is 0
470+ */
471+ SKB_DROP_REASON_IP_INVALID_DEST ,
376472 /**
377473 * @SKB_DROP_REASON_PKT_TOO_BIG: packet size is too big (maybe exceed the
378474 * MTU)
@@ -441,8 +537,8 @@ enum skb_drop_reason {
441537 * entry or an entry pointing to a nexthop.
442538 */
443539 SKB_DROP_REASON_VXLAN_ENTRY_EXISTS ,
444- /** @SKB_DROP_REASON_VXLAN_NO_REMOTE : no remote found for xmit */
445- SKB_DROP_REASON_VXLAN_NO_REMOTE ,
540+ /** @SKB_DROP_REASON_NO_TX_TARGET : no target found for xmit */
541+ SKB_DROP_REASON_NO_TX_TARGET ,
446542 /**
447543 * @SKB_DROP_REASON_IP_TUNNEL_ECN: skb is dropped according to
448544 * RFC 6040 4.2, see __INET_ECN_decapsulate() for detail.
@@ -458,6 +554,22 @@ enum skb_drop_reason {
458554 * the MAC address of the local netdev.
459555 */
460556 SKB_DROP_REASON_LOCAL_MAC ,
557+ /**
558+ * @SKB_DROP_REASON_ARP_PVLAN_DISABLE: packet which is not IP is
559+ * forwarded to the in_dev, and the proxy_arp_pvlan is not
560+ * enabled.
561+ */
562+ SKB_DROP_REASON_ARP_PVLAN_DISABLE ,
563+ /**
564+ * @SKB_DROP_REASON_MAC_IEEE_MAC_CONTROL: the destination MAC address
565+ * is an IEEE MAC Control address.
566+ */
567+ SKB_DROP_REASON_MAC_IEEE_MAC_CONTROL ,
568+ /**
569+ * @SKB_DROP_REASON_BRIDGE_INGRESS_STP_STATE: the STP state of the
570+ * ingress bridge port does not allow frames to be forwarded.
571+ */
572+ SKB_DROP_REASON_BRIDGE_INGRESS_STP_STATE ,
461573 /**
462574 * @SKB_DROP_REASON_MAX: the maximum of core drop reasons, which
463575 * shouldn't be used as a real 'reason' - only for tracing code gen
0 commit comments