1 /* SPDX-License-Identifier: GPL-2.0-or-later */ 2 3 #include <net/inet_common.h> 4 5 enum linux_mptcp_mib_field { 6 MPTCP_MIB_NUM = 0, 7 MPTCP_MIB_MPCAPABLEPASSIVE, /* Received SYN with MP_CAPABLE */ 8 MPTCP_MIB_MPCAPABLEACTIVE, /* Sent SYN with MP_CAPABLE */ 9 MPTCP_MIB_MPCAPABLEACTIVEACK, /* Received SYN/ACK with MP_CAPABLE */ 10 MPTCP_MIB_MPCAPABLEPASSIVEACK, /* Received third ACK with MP_CAPABLE */ 11 MPTCP_MIB_MPCAPABLEPASSIVEFALLBACK,/* Server-side fallback during 3-way handshake */ 12 MPTCP_MIB_MPCAPABLEACTIVEFALLBACK, /* Client-side fallback during 3-way handshake */ 13 MPTCP_MIB_MPCAPABLEACTIVEDROP, /* Client-side fallback due to a MPC drop */ 14 MPTCP_MIB_MPCAPABLEACTIVEDISABLED, /* Client-side disabled due to past issues */ 15 MPTCP_MIB_MPCAPABLEENDPATTEMPT, /* Prohibited MPC to port-based endp */ 16 MPTCP_MIB_TOKENFALLBACKINIT, /* Could not init/allocate token */ 17 MPTCP_MIB_RETRANSSEGS, /* Segments retransmitted at the MPTCP-level */ 18 MPTCP_MIB_JOINNOTOKEN, /* Received MP_JOIN but the token was not found */ 19 MPTCP_MIB_JOINSYNRX, /* Received a SYN + MP_JOIN */ 20 MPTCP_MIB_JOINSYNBACKUPRX, /* Received a SYN + MP_JOIN + backup flag */ 21 MPTCP_MIB_JOINSYNACKRX, /* Received a SYN/ACK + MP_JOIN */ 22 MPTCP_MIB_JOINSYNACKBACKUPRX, /* Received a SYN/ACK + MP_JOIN + backup flag */ 23 MPTCP_MIB_JOINSYNACKMAC, /* HMAC was wrong on SYN/ACK + MP_JOIN */ 24 MPTCP_MIB_JOINACKRX, /* Received an ACK + MP_JOIN */ 25 MPTCP_MIB_JOINACKMAC, /* HMAC was wrong on ACK + MP_JOIN */ 26 MPTCP_MIB_JOINREJECTED, /* The PM rejected the JOIN request */ 27 MPTCP_MIB_JOINSYNTX, /* Sending a SYN + MP_JOIN */ 28 MPTCP_MIB_JOINSYNTXCREATSKERR, /* Not able to create a socket when sending a SYN + MP_JOIN */ 29 MPTCP_MIB_JOINSYNTXBINDERR, /* Not able to bind() the address when sending a SYN + MP_JOIN */ 30 MPTCP_MIB_JOINSYNTXCONNECTERR, /* Not able to connect() when sending a SYN + MP_JOIN */ 31 MPTCP_MIB_DSSNOMATCH, /* Received a new mapping that did not match the previous one */ 32 MPTCP_MIB_DSSCORRUPTIONFALLBACK,/* DSS corruption detected, fallback */ 33 MPTCP_MIB_DSSCORRUPTIONRESET, /* DSS corruption detected, MPJ subflow reset */ 34 MPTCP_MIB_INFINITEMAPTX, /* Sent an infinite mapping */ 35 MPTCP_MIB_INFINITEMAPRX, /* Received an infinite mapping */ 36 MPTCP_MIB_DSSTCPMISMATCH, /* DSS-mapping did not map with TCP's sequence numbers */ 37 MPTCP_MIB_DATACSUMERR, /* The data checksum fail */ 38 MPTCP_MIB_OFOQUEUETAIL, /* Segments inserted into OoO queue tail */ 39 MPTCP_MIB_OFOQUEUE, /* Segments inserted into OoO queue */ 40 MPTCP_MIB_OFOMERGE, /* Segments merged in OoO queue */ 41 MPTCP_MIB_NODSSWINDOW, /* Segments not in MPTCP windows */ 42 MPTCP_MIB_DUPDATA, /* Segments discarded due to duplicate DSS */ 43 MPTCP_MIB_ADDADDR, /* Received ADD_ADDR with echo-flag=0 */ 44 MPTCP_MIB_ADDADDRTX, /* Sent ADD_ADDR with echo-flag=0 */ 45 MPTCP_MIB_ADDADDRTXDROP, /* ADD_ADDR with echo-flag=0 not send due to 46 * resource exhaustion 47 */ 48 MPTCP_MIB_ECHOADD, /* Received ADD_ADDR with echo-flag=1 */ 49 MPTCP_MIB_ECHOADDTX, /* Send ADD_ADDR with echo-flag=1 */ 50 MPTCP_MIB_ECHOADDTXDROP, /* ADD_ADDR with echo-flag=1 not send due 51 * to resource exhaustion 52 */ 53 MPTCP_MIB_PORTADD, /* Received ADD_ADDR with a port-number */ 54 MPTCP_MIB_ADDADDRDROP, /* Dropped incoming ADD_ADDR */ 55 MPTCP_MIB_JOINPORTSYNRX, /* Received a SYN MP_JOIN with a different port-number */ 56 MPTCP_MIB_JOINPORTSYNACKRX, /* Received a SYNACK MP_JOIN with a different port-number */ 57 MPTCP_MIB_JOINPORTACKRX, /* Received an ACK MP_JOIN with a different port-number */ 58 MPTCP_MIB_MISMATCHPORTSYNRX, /* Received a SYN MP_JOIN with a mismatched port-number */ 59 MPTCP_MIB_MISMATCHPORTACKRX, /* Received an ACK MP_JOIN with a mismatched port-number */ 60 MPTCP_MIB_RMADDR, /* Received RM_ADDR */ 61 MPTCP_MIB_RMADDRDROP, /* Dropped incoming RM_ADDR */ 62 MPTCP_MIB_RMADDRTX, /* Sent RM_ADDR */ 63 MPTCP_MIB_RMADDRTXDROP, /* RM_ADDR not sent due to resource exhaustion */ 64 MPTCP_MIB_RMSUBFLOW, /* Remove a subflow */ 65 MPTCP_MIB_MPPRIOTX, /* Transmit a MP_PRIO */ 66 MPTCP_MIB_MPPRIORX, /* Received a MP_PRIO */ 67 MPTCP_MIB_MPFAILTX, /* Transmit a MP_FAIL */ 68 MPTCP_MIB_MPFAILRX, /* Received a MP_FAIL */ 69 MPTCP_MIB_MPFASTCLOSETX, /* Transmit a MP_FASTCLOSE */ 70 MPTCP_MIB_MPFASTCLOSERX, /* Received a MP_FASTCLOSE */ 71 MPTCP_MIB_MPRSTTX, /* Transmit a MP_RST */ 72 MPTCP_MIB_MPRSTRX, /* Received a MP_RST */ 73 MPTCP_MIB_RCVPRUNED, /* Incoming packet dropped due to memory limit */ 74 MPTCP_MIB_SUBFLOWSTALE, /* Subflows entered 'stale' status */ 75 MPTCP_MIB_SUBFLOWRECOVER, /* Subflows returned to active status after being stale */ 76 MPTCP_MIB_SNDWNDSHARED, /* Subflow snd wnd is overridden by msk's one */ 77 MPTCP_MIB_RCVWNDSHARED, /* Subflow rcv wnd is overridden by msk's one */ 78 MPTCP_MIB_RCVWNDCONFLICTUPDATE, /* subflow rcv wnd is overridden by msk's one due to 79 * conflict with another subflow while updating msk rcv wnd 80 */ 81 MPTCP_MIB_RCVWNDCONFLICT, /* Conflict with while updating msk rcv wnd */ 82 MPTCP_MIB_CURRESTAB, /* Current established MPTCP connections */ 83 MPTCP_MIB_BLACKHOLE, /* A blackhole has been detected */ 84 __MPTCP_MIB_MAX 85 }; 86 87 #define LINUX_MIB_MPTCP_MAX __MPTCP_MIB_MAX 88 struct mptcp_mib { 89 unsigned long mibs[LINUX_MIB_MPTCP_MAX]; 90 }; 91 92 static inline void MPTCP_ADD_STATS(struct net *net, 93 enum linux_mptcp_mib_field field, 94 int val) 95 { 96 if (likely(net->mib.mptcp_statistics)) 97 SNMP_ADD_STATS(net->mib.mptcp_statistics, field, val); 98 } 99 100 static inline void MPTCP_INC_STATS(struct net *net, 101 enum linux_mptcp_mib_field field) 102 { 103 if (likely(net->mib.mptcp_statistics)) 104 SNMP_INC_STATS(net->mib.mptcp_statistics, field); 105 } 106 107 static inline void __MPTCP_INC_STATS(struct net *net, 108 enum linux_mptcp_mib_field field) 109 { 110 if (likely(net->mib.mptcp_statistics)) 111 __SNMP_INC_STATS(net->mib.mptcp_statistics, field); 112 } 113 114 static inline void MPTCP_DEC_STATS(struct net *net, 115 enum linux_mptcp_mib_field field) 116 { 117 if (likely(net->mib.mptcp_statistics)) 118 SNMP_DEC_STATS(net->mib.mptcp_statistics, field); 119 } 120 121 bool mptcp_mib_alloc(struct net *net); 122