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