1 /* SPDX-License-Identifier: GPL-2.0-or-later * 1 /* SPDX-License-Identifier: GPL-2.0-or-later */ 2 2 3 #include <net/inet_common.h> << 4 << 5 enum linux_mptcp_mib_field { 3 enum linux_mptcp_mib_field { 6 MPTCP_MIB_NUM = 0, 4 MPTCP_MIB_NUM = 0, 7 MPTCP_MIB_MPCAPABLEPASSIVE, /* Rec 5 MPTCP_MIB_MPCAPABLEPASSIVE, /* Received SYN with MP_CAPABLE */ 8 MPTCP_MIB_MPCAPABLEACTIVE, /* Sen 6 MPTCP_MIB_MPCAPABLEACTIVE, /* Sent SYN with MP_CAPABLE */ 9 MPTCP_MIB_MPCAPABLEACTIVEACK, /* Rec 7 MPTCP_MIB_MPCAPABLEACTIVEACK, /* Received SYN/ACK with MP_CAPABLE */ 10 MPTCP_MIB_MPCAPABLEPASSIVEACK, /* Rec 8 MPTCP_MIB_MPCAPABLEPASSIVEACK, /* Received third ACK with MP_CAPABLE */ 11 MPTCP_MIB_MPCAPABLEPASSIVEFALLBACK,/* 9 MPTCP_MIB_MPCAPABLEPASSIVEFALLBACK,/* Server-side fallback during 3-way handshake */ 12 MPTCP_MIB_MPCAPABLEACTIVEFALLBACK, /* 10 MPTCP_MIB_MPCAPABLEACTIVEFALLBACK, /* Client-side fallback during 3-way handshake */ 13 MPTCP_MIB_MPCAPABLEACTIVEDROP, /* Cli << 14 MPTCP_MIB_MPCAPABLEACTIVEDISABLED, /* << 15 MPTCP_MIB_MPCAPABLEENDPATTEMPT, /* Pro << 16 MPTCP_MIB_TOKENFALLBACKINIT, /* Cou 11 MPTCP_MIB_TOKENFALLBACKINIT, /* Could not init/allocate token */ 17 MPTCP_MIB_RETRANSSEGS, /* Seg 12 MPTCP_MIB_RETRANSSEGS, /* Segments retransmitted at the MPTCP-level */ 18 MPTCP_MIB_JOINNOTOKEN, /* Rec 13 MPTCP_MIB_JOINNOTOKEN, /* Received MP_JOIN but the token was not found */ 19 MPTCP_MIB_JOINSYNRX, /* Rec 14 MPTCP_MIB_JOINSYNRX, /* Received a SYN + MP_JOIN */ 20 MPTCP_MIB_JOINSYNBACKUPRX, /* Rec << 21 MPTCP_MIB_JOINSYNACKRX, /* Rec 15 MPTCP_MIB_JOINSYNACKRX, /* Received a SYN/ACK + MP_JOIN */ 22 MPTCP_MIB_JOINSYNACKBACKUPRX, /* Rec << 23 MPTCP_MIB_JOINSYNACKMAC, /* HMA 16 MPTCP_MIB_JOINSYNACKMAC, /* HMAC was wrong on SYN/ACK + MP_JOIN */ 24 MPTCP_MIB_JOINACKRX, /* Rec 17 MPTCP_MIB_JOINACKRX, /* Received an ACK + MP_JOIN */ 25 MPTCP_MIB_JOINACKMAC, /* HMA 18 MPTCP_MIB_JOINACKMAC, /* HMAC was wrong on ACK + MP_JOIN */ 26 MPTCP_MIB_JOINSYNTX, /* Sen << 27 MPTCP_MIB_JOINSYNTXCREATSKERR, /* Not << 28 MPTCP_MIB_JOINSYNTXBINDERR, /* Not << 29 MPTCP_MIB_JOINSYNTXCONNECTERR, /* Not << 30 MPTCP_MIB_DSSNOMATCH, /* Rec 19 MPTCP_MIB_DSSNOMATCH, /* Received a new mapping that did not match the previous one */ 31 MPTCP_MIB_DSSCORRUPTIONFALLBACK,/* DSS << 32 MPTCP_MIB_DSSCORRUPTIONRESET, /* DSS << 33 MPTCP_MIB_INFINITEMAPTX, /* Sen << 34 MPTCP_MIB_INFINITEMAPRX, /* Rec 20 MPTCP_MIB_INFINITEMAPRX, /* Received an infinite mapping */ 35 MPTCP_MIB_DSSTCPMISMATCH, /* DSS 21 MPTCP_MIB_DSSTCPMISMATCH, /* DSS-mapping did not map with TCP's sequence numbers */ 36 MPTCP_MIB_DATACSUMERR, /* The 22 MPTCP_MIB_DATACSUMERR, /* The data checksum fail */ 37 MPTCP_MIB_OFOQUEUETAIL, /* Segments in 23 MPTCP_MIB_OFOQUEUETAIL, /* Segments inserted into OoO queue tail */ 38 MPTCP_MIB_OFOQUEUE, /* Seg 24 MPTCP_MIB_OFOQUEUE, /* Segments inserted into OoO queue */ 39 MPTCP_MIB_OFOMERGE, /* Seg 25 MPTCP_MIB_OFOMERGE, /* Segments merged in OoO queue */ 40 MPTCP_MIB_NODSSWINDOW, /* Seg 26 MPTCP_MIB_NODSSWINDOW, /* Segments not in MPTCP windows */ 41 MPTCP_MIB_DUPDATA, /* Seg 27 MPTCP_MIB_DUPDATA, /* Segments discarded due to duplicate DSS */ 42 MPTCP_MIB_ADDADDR, /* Rec 28 MPTCP_MIB_ADDADDR, /* Received ADD_ADDR with echo-flag=0 */ 43 MPTCP_MIB_ADDADDRTX, /* Sen << 44 MPTCP_MIB_ADDADDRTXDROP, /* ADD << 45 * res << 46 */ << 47 MPTCP_MIB_ECHOADD, /* Rec 29 MPTCP_MIB_ECHOADD, /* Received ADD_ADDR with echo-flag=1 */ 48 MPTCP_MIB_ECHOADDTX, /* Sen << 49 MPTCP_MIB_ECHOADDTXDROP, /* ADD << 50 * to << 51 */ << 52 MPTCP_MIB_PORTADD, /* Rec 30 MPTCP_MIB_PORTADD, /* Received ADD_ADDR with a port-number */ 53 MPTCP_MIB_ADDADDRDROP, /* Dro << 54 MPTCP_MIB_JOINPORTSYNRX, /* Rec 31 MPTCP_MIB_JOINPORTSYNRX, /* Received a SYN MP_JOIN with a different port-number */ 55 MPTCP_MIB_JOINPORTSYNACKRX, /* Rec 32 MPTCP_MIB_JOINPORTSYNACKRX, /* Received a SYNACK MP_JOIN with a different port-number */ 56 MPTCP_MIB_JOINPORTACKRX, /* Rec 33 MPTCP_MIB_JOINPORTACKRX, /* Received an ACK MP_JOIN with a different port-number */ 57 MPTCP_MIB_MISMATCHPORTSYNRX, /* Rec 34 MPTCP_MIB_MISMATCHPORTSYNRX, /* Received a SYN MP_JOIN with a mismatched port-number */ 58 MPTCP_MIB_MISMATCHPORTACKRX, /* Rec 35 MPTCP_MIB_MISMATCHPORTACKRX, /* Received an ACK MP_JOIN with a mismatched port-number */ 59 MPTCP_MIB_RMADDR, /* Rec 36 MPTCP_MIB_RMADDR, /* Received RM_ADDR */ 60 MPTCP_MIB_RMADDRDROP, /* Dro << 61 MPTCP_MIB_RMADDRTX, /* Sen << 62 MPTCP_MIB_RMADDRTXDROP, /* RM_ << 63 MPTCP_MIB_RMSUBFLOW, /* Rem 37 MPTCP_MIB_RMSUBFLOW, /* Remove a subflow */ 64 MPTCP_MIB_MPPRIOTX, /* Tra 38 MPTCP_MIB_MPPRIOTX, /* Transmit a MP_PRIO */ 65 MPTCP_MIB_MPPRIORX, /* Rec 39 MPTCP_MIB_MPPRIORX, /* Received a MP_PRIO */ 66 MPTCP_MIB_MPFAILTX, /* Tra << 67 MPTCP_MIB_MPFAILRX, /* Rec << 68 MPTCP_MIB_MPFASTCLOSETX, /* Tra << 69 MPTCP_MIB_MPFASTCLOSERX, /* Rec << 70 MPTCP_MIB_MPRSTTX, /* Tra << 71 MPTCP_MIB_MPRSTRX, /* Rec << 72 MPTCP_MIB_RCVPRUNED, /* Inc 40 MPTCP_MIB_RCVPRUNED, /* Incoming packet dropped due to memory limit */ 73 MPTCP_MIB_SUBFLOWSTALE, /* Sub << 74 MPTCP_MIB_SUBFLOWRECOVER, /* Sub << 75 MPTCP_MIB_SNDWNDSHARED, /* Sub << 76 MPTCP_MIB_RCVWNDSHARED, /* Sub << 77 MPTCP_MIB_RCVWNDCONFLICTUPDATE, /* sub << 78 * con << 79 */ << 80 MPTCP_MIB_RCVWNDCONFLICT, /* Con << 81 MPTCP_MIB_CURRESTAB, /* Cur << 82 MPTCP_MIB_BLACKHOLE, /* A b << 83 __MPTCP_MIB_MAX 41 __MPTCP_MIB_MAX 84 }; 42 }; 85 43 86 #define LINUX_MIB_MPTCP_MAX __MPTCP_MIB_MA 44 #define LINUX_MIB_MPTCP_MAX __MPTCP_MIB_MAX 87 struct mptcp_mib { 45 struct mptcp_mib { 88 unsigned long mibs[LINUX_MIB_MPTCP_MAX 46 unsigned long mibs[LINUX_MIB_MPTCP_MAX]; 89 }; 47 }; 90 48 91 static inline void MPTCP_ADD_STATS(struct net << 92 enum linux_ << 93 int val) << 94 { << 95 if (likely(net->mib.mptcp_statistics)) << 96 SNMP_ADD_STATS(net->mib.mptcp_ << 97 } << 98 << 99 static inline void MPTCP_INC_STATS(struct net 49 static inline void MPTCP_INC_STATS(struct net *net, 100 enum linux_ 50 enum linux_mptcp_mib_field field) 101 { 51 { 102 if (likely(net->mib.mptcp_statistics)) 52 if (likely(net->mib.mptcp_statistics)) 103 SNMP_INC_STATS(net->mib.mptcp_ 53 SNMP_INC_STATS(net->mib.mptcp_statistics, field); 104 } 54 } 105 55 106 static inline void __MPTCP_INC_STATS(struct ne 56 static inline void __MPTCP_INC_STATS(struct net *net, 107 enum linu 57 enum linux_mptcp_mib_field field) 108 { 58 { 109 if (likely(net->mib.mptcp_statistics)) 59 if (likely(net->mib.mptcp_statistics)) 110 __SNMP_INC_STATS(net->mib.mptc 60 __SNMP_INC_STATS(net->mib.mptcp_statistics, field); 111 } << 112 << 113 static inline void MPTCP_DEC_STATS(struct net << 114 enum linux_ << 115 { << 116 if (likely(net->mib.mptcp_statistics)) << 117 SNMP_DEC_STATS(net->mib.mptcp_ << 118 } 61 } 119 62 120 bool mptcp_mib_alloc(struct net *net); 63 bool mptcp_mib_alloc(struct net *net); 121 64
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.