1fc518953SFlorian Westphal // SPDX-License-Identifier: GPL-2.0-or-later 2fc518953SFlorian Westphal 3fc518953SFlorian Westphal #include <linux/seq_file.h> 4fc518953SFlorian Westphal #include <net/ip.h> 5fc518953SFlorian Westphal #include <net/mptcp.h> 6fc518953SFlorian Westphal #include <net/snmp.h> 7fc518953SFlorian Westphal #include <net/net_namespace.h> 8fc518953SFlorian Westphal 9fc518953SFlorian Westphal #include "mib.h" 10fc518953SFlorian Westphal 11fc518953SFlorian Westphal static const struct snmp_mib mptcp_snmp_list[] = { 12fc518953SFlorian Westphal SNMP_MIB_ITEM("MPCapableSYNRX", MPTCP_MIB_MPCAPABLEPASSIVE), 135695eb88SPaolo Abeni SNMP_MIB_ITEM("MPCapableSYNTX", MPTCP_MIB_MPCAPABLEACTIVE), 145695eb88SPaolo Abeni SNMP_MIB_ITEM("MPCapableSYNACKRX", MPTCP_MIB_MPCAPABLEACTIVEACK), 15fc518953SFlorian Westphal SNMP_MIB_ITEM("MPCapableACKRX", MPTCP_MIB_MPCAPABLEPASSIVEACK), 16fc518953SFlorian Westphal SNMP_MIB_ITEM("MPCapableFallbackACK", MPTCP_MIB_MPCAPABLEPASSIVEFALLBACK), 17fc518953SFlorian Westphal SNMP_MIB_ITEM("MPCapableFallbackSYNACK", MPTCP_MIB_MPCAPABLEACTIVEFALLBACK), 186982826fSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPCapableSYNTXDrop", MPTCP_MIB_MPCAPABLEACTIVEDROP), 1927069e7cSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPCapableSYNTXDisabled", MPTCP_MIB_MPCAPABLEACTIVEDISABLED), 20*3d041393SPaolo Abeni SNMP_MIB_ITEM("MPCapableEndpAttempt", MPTCP_MIB_MPCAPABLEENDPATTEMPT), 21a16195e3SPaolo Abeni SNMP_MIB_ITEM("MPFallbackTokenInit", MPTCP_MIB_TOKENFALLBACKINIT), 22fc518953SFlorian Westphal SNMP_MIB_ITEM("MPTCPRetrans", MPTCP_MIB_RETRANSSEGS), 23fc518953SFlorian Westphal SNMP_MIB_ITEM("MPJoinNoTokenFound", MPTCP_MIB_JOINNOTOKEN), 24fc518953SFlorian Westphal SNMP_MIB_ITEM("MPJoinSynRx", MPTCP_MIB_JOINSYNRX), 254dde0d72SMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPJoinSynBackupRx", MPTCP_MIB_JOINSYNBACKUPRX), 26fc518953SFlorian Westphal SNMP_MIB_ITEM("MPJoinSynAckRx", MPTCP_MIB_JOINSYNACKRX), 274dde0d72SMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPJoinSynAckBackupRx", MPTCP_MIB_JOINSYNACKBACKUPRX), 28fc518953SFlorian Westphal SNMP_MIB_ITEM("MPJoinSynAckHMacFailure", MPTCP_MIB_JOINSYNACKMAC), 29fc518953SFlorian Westphal SNMP_MIB_ITEM("MPJoinAckRx", MPTCP_MIB_JOINACKRX), 30fc518953SFlorian Westphal SNMP_MIB_ITEM("MPJoinAckHMacFailure", MPTCP_MIB_JOINACKMAC), 311bd1788bSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPJoinSynTx", MPTCP_MIB_JOINSYNTX), 321bd1788bSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPJoinSynTxCreatSkErr", MPTCP_MIB_JOINSYNTXCREATSKERR), 331bd1788bSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPJoinSynTxBindErr", MPTCP_MIB_JOINSYNTXBINDERR), 341bd1788bSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("MPJoinSynTxConnectErr", MPTCP_MIB_JOINSYNTXCONNECTERR), 35fc518953SFlorian Westphal SNMP_MIB_ITEM("DSSNotMatching", MPTCP_MIB_DSSNOMATCH), 36e32d262cSPaolo Abeni SNMP_MIB_ITEM("DSSCorruptionFallback", MPTCP_MIB_DSSCORRUPTIONFALLBACK), 37e32d262cSPaolo Abeni SNMP_MIB_ITEM("DSSCorruptionReset", MPTCP_MIB_DSSCORRUPTIONRESET), 38104125b8SGeliang Tang SNMP_MIB_ITEM("InfiniteMapTx", MPTCP_MIB_INFINITEMAPTX), 39fc518953SFlorian Westphal SNMP_MIB_ITEM("InfiniteMapRx", MPTCP_MIB_INFINITEMAPRX), 4006285da9SPaolo Abeni SNMP_MIB_ITEM("DSSNoMatchTCP", MPTCP_MIB_DSSTCPMISMATCH), 41fe3ab1cbSGeliang Tang SNMP_MIB_ITEM("DataCsumErr", MPTCP_MIB_DATACSUMERR), 4206242e44SPaolo Abeni SNMP_MIB_ITEM("OFOQueueTail", MPTCP_MIB_OFOQUEUETAIL), 4306242e44SPaolo Abeni SNMP_MIB_ITEM("OFOQueue", MPTCP_MIB_OFOQUEUE), 4406242e44SPaolo Abeni SNMP_MIB_ITEM("OFOMerge", MPTCP_MIB_OFOMERGE), 4506242e44SPaolo Abeni SNMP_MIB_ITEM("NoDSSInWindow", MPTCP_MIB_NODSSWINDOW), 4606242e44SPaolo Abeni SNMP_MIB_ITEM("DuplicateData", MPTCP_MIB_DUPDATA), 47a877de06SGeliang Tang SNMP_MIB_ITEM("AddAddr", MPTCP_MIB_ADDADDR), 4845b1a122SPaolo Abeni SNMP_MIB_ITEM("AddAddrTx", MPTCP_MIB_ADDADDRTX), 4945b1a122SPaolo Abeni SNMP_MIB_ITEM("AddAddrTxDrop", MPTCP_MIB_ADDADDRTXDROP), 50a877de06SGeliang Tang SNMP_MIB_ITEM("EchoAdd", MPTCP_MIB_ECHOADD), 5145b1a122SPaolo Abeni SNMP_MIB_ITEM("EchoAddTx", MPTCP_MIB_ECHOADDTX), 5245b1a122SPaolo Abeni SNMP_MIB_ITEM("EchoAddTxDrop", MPTCP_MIB_ECHOADDTXDROP), 532fbdd9eaSGeliang Tang SNMP_MIB_ITEM("PortAdd", MPTCP_MIB_PORTADD), 54f73c1194SPaolo Abeni SNMP_MIB_ITEM("AddAddrDrop", MPTCP_MIB_ADDADDRDROP), 552fbdd9eaSGeliang Tang SNMP_MIB_ITEM("MPJoinPortSynRx", MPTCP_MIB_JOINPORTSYNRX), 562fbdd9eaSGeliang Tang SNMP_MIB_ITEM("MPJoinPortSynAckRx", MPTCP_MIB_JOINPORTSYNACKRX), 572fbdd9eaSGeliang Tang SNMP_MIB_ITEM("MPJoinPortAckRx", MPTCP_MIB_JOINPORTACKRX), 582fbdd9eaSGeliang Tang SNMP_MIB_ITEM("MismatchPortSynRx", MPTCP_MIB_MISMATCHPORTSYNRX), 592fbdd9eaSGeliang Tang SNMP_MIB_ITEM("MismatchPortAckRx", MPTCP_MIB_MISMATCHPORTACKRX), 607a7e52e3SGeliang Tang SNMP_MIB_ITEM("RmAddr", MPTCP_MIB_RMADDR), 61f73c1194SPaolo Abeni SNMP_MIB_ITEM("RmAddrDrop", MPTCP_MIB_RMADDRDROP), 6245b1a122SPaolo Abeni SNMP_MIB_ITEM("RmAddrTx", MPTCP_MIB_RMADDRTX), 6345b1a122SPaolo Abeni SNMP_MIB_ITEM("RmAddrTxDrop", MPTCP_MIB_RMADDRTXDROP), 647a7e52e3SGeliang Tang SNMP_MIB_ITEM("RmSubflow", MPTCP_MIB_RMSUBFLOW), 650be2ac28SGeliang Tang SNMP_MIB_ITEM("MPPrioTx", MPTCP_MIB_MPPRIOTX), 660be2ac28SGeliang Tang SNMP_MIB_ITEM("MPPrioRx", MPTCP_MIB_MPPRIORX), 67eb7f3365SGeliang Tang SNMP_MIB_ITEM("MPFailTx", MPTCP_MIB_MPFAILTX), 68eb7f3365SGeliang Tang SNMP_MIB_ITEM("MPFailRx", MPTCP_MIB_MPFAILRX), 691e75629cSGeliang Tang SNMP_MIB_ITEM("MPFastcloseTx", MPTCP_MIB_MPFASTCLOSETX), 701e75629cSGeliang Tang SNMP_MIB_ITEM("MPFastcloseRx", MPTCP_MIB_MPFASTCLOSERX), 71e40dd439SGeliang Tang SNMP_MIB_ITEM("MPRstTx", MPTCP_MIB_MPRSTTX), 72e40dd439SGeliang Tang SNMP_MIB_ITEM("MPRstRx", MPTCP_MIB_MPRSTRX), 73ce599c51SPaolo Abeni SNMP_MIB_ITEM("RcvPruned", MPTCP_MIB_RCVPRUNED), 74fc1b4e3bSPaolo Abeni SNMP_MIB_ITEM("SubflowStale", MPTCP_MIB_SUBFLOWSTALE), 75fc1b4e3bSPaolo Abeni SNMP_MIB_ITEM("SubflowRecover", MPTCP_MIB_SUBFLOWRECOVER), 7692be2f52SPaolo Abeni SNMP_MIB_ITEM("SndWndShared", MPTCP_MIB_SNDWNDSHARED), 7738acb626SPaolo Abeni SNMP_MIB_ITEM("RcvWndShared", MPTCP_MIB_RCVWNDSHARED), 7838acb626SPaolo Abeni SNMP_MIB_ITEM("RcvWndConflictUpdate", MPTCP_MIB_RCVWNDCONFLICTUPDATE), 7938acb626SPaolo Abeni SNMP_MIB_ITEM("RcvWndConflict", MPTCP_MIB_RCVWNDCONFLICT), 80d9cd27b8SGeliang Tang SNMP_MIB_ITEM("MPCurrEstab", MPTCP_MIB_CURRESTAB), 8127069e7cSMatthieu Baerts (NGI0) SNMP_MIB_ITEM("Blackhole", MPTCP_MIB_BLACKHOLE), 82fc518953SFlorian Westphal SNMP_MIB_SENTINEL 83fc518953SFlorian Westphal }; 84fc518953SFlorian Westphal 85fc518953SFlorian Westphal /* mptcp_mib_alloc - allocate percpu mib counters 86fc518953SFlorian Westphal * 87fc518953SFlorian Westphal * These are allocated when the first mptcp socket is created so 88fc518953SFlorian Westphal * we do not waste percpu memory if mptcp isn't in use. 89fc518953SFlorian Westphal */ 90fc518953SFlorian Westphal bool mptcp_mib_alloc(struct net *net) 91fc518953SFlorian Westphal { 92fc518953SFlorian Westphal struct mptcp_mib __percpu *mib = alloc_percpu(struct mptcp_mib); 93fc518953SFlorian Westphal 94fc518953SFlorian Westphal if (!mib) 95fc518953SFlorian Westphal return false; 96fc518953SFlorian Westphal 97fc518953SFlorian Westphal if (cmpxchg(&net->mib.mptcp_statistics, NULL, mib)) 98fc518953SFlorian Westphal free_percpu(mib); 99fc518953SFlorian Westphal 100fc518953SFlorian Westphal return true; 101fc518953SFlorian Westphal } 102fc518953SFlorian Westphal 103fc518953SFlorian Westphal void mptcp_seq_show(struct seq_file *seq) 104fc518953SFlorian Westphal { 105acbd0c81SEric Dumazet unsigned long sum[ARRAY_SIZE(mptcp_snmp_list) - 1]; 106fc518953SFlorian Westphal struct net *net = seq->private; 107fc518953SFlorian Westphal int i; 108fc518953SFlorian Westphal 109fc518953SFlorian Westphal seq_puts(seq, "MPTcpExt:"); 110fc518953SFlorian Westphal for (i = 0; mptcp_snmp_list[i].name; i++) 111fc518953SFlorian Westphal seq_printf(seq, " %s", mptcp_snmp_list[i].name); 112fc518953SFlorian Westphal 113fc518953SFlorian Westphal seq_puts(seq, "\nMPTcpExt:"); 114fc518953SFlorian Westphal 115acbd0c81SEric Dumazet memset(sum, 0, sizeof(sum)); 116acbd0c81SEric Dumazet if (net->mib.mptcp_statistics) 117acbd0c81SEric Dumazet snmp_get_cpu_field_batch(sum, mptcp_snmp_list, 118acbd0c81SEric Dumazet net->mib.mptcp_statistics); 119fc518953SFlorian Westphal 120fc518953SFlorian Westphal for (i = 0; mptcp_snmp_list[i].name; i++) 121acbd0c81SEric Dumazet seq_printf(seq, " %lu", sum[i]); 122acbd0c81SEric Dumazet 123fc518953SFlorian Westphal seq_putc(seq, '\n'); 124fc518953SFlorian Westphal } 125