From 35bab364c6e6dd8848006d0d0c1b42e94e01997f Mon Sep 17 00:00:00 2001 From: Marcelo Araujo Date: Mon, 16 Nov 2015 02:24:57 +0000 Subject: [PATCH] - Add support for ALTQ FairQ and Codel protocols. - Bump PORTREVISION to 5. PR: ports/204405 Submitted by: Renato Botelho Obtained from: pfSense Sponsored by: Rubicon Communications (Netgate) --- sysutils/pftop/Makefile | 7 +- .../pftop/files/extra-patch-fairq_codel.diff | 102 ++++++++++++++++++ 2 files changed, 108 insertions(+), 1 deletion(-) create mode 100644 sysutils/pftop/files/extra-patch-fairq_codel.diff diff --git a/sysutils/pftop/Makefile b/sysutils/pftop/Makefile index 292c2c75e05d..d4e5b7ea18bd 100644 --- a/sysutils/pftop/Makefile +++ b/sysutils/pftop/Makefile @@ -3,7 +3,7 @@ PORTNAME= pftop PORTVERSION= 0.7 -PORTREVISION= 4 +PORTREVISION= 5 CATEGORIES= sysutils net MASTER_SITES= http://www.eee.metu.edu.tr/~canacar/ @@ -36,6 +36,11 @@ MAKE_ENV+= __MAKE_CONF=/dev/null PLIST_FILES= sbin/pftop man/man8/pftop.8.gz post-patch: +.if ${OSVERSION} >= 1100000 + @${ECHO_MSG} "===> Applying FairQ/Codel patches to ${PORTNAME}." + @${CAT} ${FILESDIR}/extra-patch-fairq_codel.diff | \ + ${PATCH} ${PATCH_ARGS} +.endif @${REINPLACE_CMD} -e 's||"${FILESDIR}/queue.h"|g' \ ${WRKSRC}/engine.c @${REINPLACE_CMD} -e 's|__dead|__dead2|g' ${WRKSRC}/sf-gencode.h diff --git a/sysutils/pftop/files/extra-patch-fairq_codel.diff b/sysutils/pftop/files/extra-patch-fairq_codel.diff new file mode 100644 index 000000000000..3c501b15f501 --- /dev/null +++ b/sysutils/pftop/files/extra-patch-fairq_codel.diff @@ -0,0 +1,102 @@ +--- pftop.c.orig 2013-05-11 12:53:55.000000000 +0000 ++++ pftop.c 2013-05-11 12:54:00.000000000 +0000 +@@ -48,6 +48,8 @@ + #include + #include + #include ++#include ++#include + #endif + + #include +@@ -371,6 +373,8 @@ + class_stats_t cbq_stats; + struct priq_classstats priq_stats; + struct hfsc_classstats hfsc_stats; ++ struct fairq_classstats fairq_stats; ++ struct codel_ifstats codel_stats; + }; + + struct queue_stats { +@@ -1764,6 +1768,8 @@ + return (-1); + } + num_queues = nr_queues = pa.nr; ++ if (pa.altq.scheduler == ALTQT_CODEL) ++ num_queues = 1; + for (nr = 0; nr < nr_queues; ++nr) { + pa.nr = nr; + if (ioctl(pf_dev, DIOCGETALTQ, &pa)) { +@@ -1772,10 +1778,10 @@ + return (-1); + } + #ifdef PFALTQ_FLAG_IF_REMOVED +- if (pa.altq.qid > 0 && ++ if ((pa.altq.qid > 0 || pa.altq.scheduler == ALTQT_CODEL) && + !(pa.altq.local_flags & PFALTQ_FLAG_IF_REMOVED)) { + #else +- if (pa.altq.qid > 0) { ++ if (pa.altq.qid > 0 || pa.altq.scheduler == ALTQT_CODEL) { + #endif + pq.nr = nr; + pq.ticket = pa.ticket; +@@ -1928,11 +1934,14 @@ + tb_start(); + for (d = 0; d < node->depth; d++) + tbprintf(" "); +- tbprintf(node->altq.qname); ++ if (node->altq.qname[0] != '\0') ++ tbprintf(node->altq.qname); ++ else ++ tbprintf("root"); + print_fld_tb(FLD_QUEUE); + + if (node->altq.scheduler == ALTQT_CBQ || +- node->altq.scheduler == ALTQT_HFSC ++ node->altq.scheduler == ALTQT_HFSC || node->altq.scheduler == ALTQT_FAIRQ || node->altq.scheduler == ALTQT_CODEL + ) + print_fld_bw(FLD_BANDW, (double)node->altq.bandwidth); + +@@ -2003,6 +2012,42 @@ + node->qstats_last.data.hfsc_stats.xmit_cnt.bytes, interval); + } + break; ++ case ALTQT_FAIRQ: ++ print_fld_str(FLD_SCHED, "fairq"); ++ print_fld_size(FLD_PKTS, ++ node->qstats.data.fairq_stats.xmit_cnt.packets); ++ print_fld_size(FLD_BYTES, ++ node->qstats.data.fairq_stats.xmit_cnt.bytes); ++ print_fld_size(FLD_DROPP, ++ node->qstats.data.fairq_stats.drop_cnt.packets); ++ print_fld_size(FLD_DROPB, ++ node->qstats.data.fairq_stats.drop_cnt.bytes); ++ print_fld_size(FLD_QLEN, node->qstats.data.fairq_stats.qlength); ++ if (interval > 0) { ++ pps = calc_pps(node->qstats.data.fairq_stats.xmit_cnt.packets, ++ node->qstats_last.data.fairq_stats.xmit_cnt.packets, interval); ++ bps = calc_rate(node->qstats.data.fairq_stats.xmit_cnt.bytes, ++ node->qstats_last.data.fairq_stats.xmit_cnt.bytes, interval); ++ } ++ break; ++ case ALTQT_CODEL: ++ print_fld_str(FLD_SCHED, "codel"); ++ print_fld_size(FLD_PKTS, ++ node->qstats.data.codel_stats.cl_xmitcnt.packets); ++ print_fld_size(FLD_BYTES, ++ node->qstats.data.codel_stats.cl_xmitcnt.bytes); ++ print_fld_size(FLD_DROPP, ++ node->qstats.data.codel_stats.cl_dropcnt.packets); ++ print_fld_size(FLD_DROPB, ++ node->qstats.data.codel_stats.cl_dropcnt.bytes); ++ print_fld_size(FLD_QLEN, node->qstats.data.codel_stats.qlength); ++ if (interval > 0) { ++ pps = calc_pps(node->qstats.data.codel_stats.cl_xmitcnt.packets, ++ node->qstats_last.data.codel_stats.cl_xmitcnt.packets, interval); ++ bps = calc_rate(node->qstats.data.codel_stats.cl_xmitcnt.bytes, ++ node->qstats_last.data.codel_stats.cl_xmitcnt.bytes, interval); ++ } ++ break; + } + + /* if (node->altq.scheduler != ALTQT_HFSC && interval > 0) { */