Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/altq libaltq, cbq: add two options to interface
details: https://anonhg.NetBSD.org/src/rev/5f0545c470aa
branches: trunk
changeset: 1022359:5f0545c470aa
user: ozaki-r <ozaki-r%NetBSD.org@localhost>
date: Wed Jul 14 08:32:13 2021 +0000
description:
libaltq, cbq: add two options to interface
- no-control: don't create a control class automatically
- no-tbr: don't install TBR
diffstat:
usr.sbin/altq/altqd/altq.conf.5 | 13 +++++++++++--
usr.sbin/altq/libaltq/qop_cbq.c | 30 +++++++++++++++++++++---------
usr.sbin/altq/libaltq/qop_cbq.h | 7 ++++---
3 files changed, 36 insertions(+), 14 deletions(-)
diffs (167 lines):
diff -r 326e1a805eb1 -r 5f0545c470aa usr.sbin/altq/altqd/altq.conf.5
--- a/usr.sbin/altq/altqd/altq.conf.5 Wed Jul 14 08:31:15 2021 +0000
+++ b/usr.sbin/altq/altqd/altq.conf.5 Wed Jul 14 08:32:13 2021 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: altq.conf.5,v 1.18 2019/04/09 19:10:21 sevan Exp $
+.\" $NetBSD: altq.conf.5,v 1.19 2021/07/14 08:32:13 ozaki-r Exp $
.\" $KAME: altq.conf.5,v 1.15 2002/11/17 02:51:49 kjc Exp $
.\"
.\" Copyright (C) 2000
@@ -25,7 +25,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE.
.\"
-.Dd April 9, 2019
+.Dd July 14, 2021
.Dt ALTQ.CONF 5
.Os
.\"
@@ -281,6 +281,8 @@
.Op Cm tbrsize Ar bytes
.Op Ar sched_type
.Op Cm efficient
+.Op Cm no-control
+.Op Cm no-tbr
.El
.Bl -tag -width 8n -offset indent
.It Ar if_name
@@ -310,6 +312,13 @@
By adding the keyword
.Cm efficient
to the interface specification line, enables this mode.
+.It Cm no-control
+By default, the control class is automatically created when default class is
+created and one doesn't exist yet.
+This option suppresses the behavior on the interface.
+.It Cm no-tbr
+By default, a token bucket regulator is automatically created on each interface.
+This option suppresses the behavior on the interface.
.El
.Bl -tag -width class -offset indent
.It Cm class
diff -r 326e1a805eb1 -r 5f0545c470aa usr.sbin/altq/libaltq/qop_cbq.c
--- a/usr.sbin/altq/libaltq/qop_cbq.c Wed Jul 14 08:31:15 2021 +0000
+++ b/usr.sbin/altq/libaltq/qop_cbq.c Wed Jul 14 08:32:13 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: qop_cbq.c,v 1.10 2013/10/19 17:16:37 christos Exp $ */
+/* $NetBSD: qop_cbq.c,v 1.11 2021/07/14 08:32:13 ozaki-r Exp $ */
/* $KAME: qop_cbq.c,v 1.7 2002/05/31 06:03:35 kjc Exp $ */
/*
* Copyright (c) Sun Microsystems, Inc. 1993-1998 All rights reserved.
@@ -112,6 +112,8 @@
u_int tbrsize = 0;
u_int is_efficient = 0;
u_int is_wrr = 1; /* weighted round-robin is default */
+ bool no_control = false;
+ bool no_tbr = false;
/*
* process options
@@ -133,6 +135,10 @@
is_wrr = 1;
} else if (EQUAL(*argv, "cbq-prr")) {
is_wrr = 0;
+ } else if (EQUAL(*argv, "no-tbr")) {
+ no_tbr = true;
+ } else if (EQUAL(*argv, "no-control")) {
+ no_control = true;
} else {
LOG(LOG_ERR, 0, "Unknown keyword '%s'", *argv);
return (0);
@@ -140,12 +146,15 @@
argc--; argv++;
}
- if (qcmd_tbr_register(ifname, bandwidth, tbrsize) != 0)
+ if (!no_tbr) {
+ if (qcmd_tbr_register(ifname, bandwidth, tbrsize) != 0)
+ return (0);
+ }
+
+ if (qcmd_cbq_add_if(ifname, bandwidth,
+ is_wrr, is_efficient, no_control) != 0)
return (0);
- if (qcmd_cbq_add_if(ifname, bandwidth,
- is_wrr, is_efficient) != 0)
- return (0);
return (1);
}
@@ -296,11 +305,13 @@
* qcmd api
*/
int
-qcmd_cbq_add_if(const char *ifname, u_int bandwidth, int is_wrr, int efficient)
+qcmd_cbq_add_if(const char *ifname, u_int bandwidth, int is_wrr, int efficient,
+ bool no_control)
{
int error;
- error = qop_cbq_add_if(NULL, ifname, bandwidth, is_wrr, efficient);
+ error = qop_cbq_add_if(NULL, ifname, bandwidth, is_wrr, efficient,
+ no_control);
if (error != 0)
LOG(LOG_ERR, errno, "%s: can't add cbq on interface '%s'",
qoperror(error), ifname);
@@ -333,7 +344,7 @@
(borrow = clname2clinfo(ifinfo, borrow_name)) == NULL)
error = QOPERR_BADCLASS;
- if (flags & CBQCLF_DEFCLASS) {
+ if (flags & CBQCLF_DEFCLASS && !cbq_ifinfo->no_control) {
/*
* if this is a default class and no ctl_class is defined,
* we will create a ctl_class.
@@ -464,7 +475,7 @@
*/
int
qop_cbq_add_if(struct ifinfo **rp, const char *ifname,
- u_int bandwidth, int is_wrr, int efficient)
+ u_int bandwidth, int is_wrr, int efficient, bool no_control)
{
struct ifinfo *ifinfo = NULL;
struct cbq_ifinfo *cbq_ifinfo = NULL;
@@ -477,6 +488,7 @@
(1.0 / (double)bandwidth) * NS_PER_SEC * 8;
cbq_ifinfo->is_wrr = is_wrr;
cbq_ifinfo->is_efficient = efficient;
+ cbq_ifinfo->no_control = no_control;
error = qop_add_if(&ifinfo, ifname, bandwidth,
&cbq_qdisc, cbq_ifinfo);
diff -r 326e1a805eb1 -r 5f0545c470aa usr.sbin/altq/libaltq/qop_cbq.h
--- a/usr.sbin/altq/libaltq/qop_cbq.h Wed Jul 14 08:31:15 2021 +0000
+++ b/usr.sbin/altq/libaltq/qop_cbq.h Wed Jul 14 08:32:13 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: qop_cbq.h,v 1.2 2001/08/16 07:48:13 itojun Exp $ */
+/* $NetBSD: qop_cbq.h,v 1.3 2021/07/14 08:32:13 ozaki-r Exp $ */
/* $KAME: qop_cbq.h,v 1.2 2000/10/18 09:15:18 kjc Exp $ */
/*
* Copyright (c) Sun Microsystems, Inc. 1993-1998 All rights reserved.
@@ -53,6 +53,7 @@
double nsPerByte; /* bandwidth in ns per sec */
int is_wrr; /* use weighted-round robin */
int is_efficient; /* use work-conserving */
+ bool no_control; /* don't create a control class automatically */
};
/*
@@ -76,7 +77,7 @@
const char *parent_name, int argc, char **argv);
int qcmd_cbq_add_if(const char *ifname, u_int bandwidth,
- int is_wrr, int efficient);
+ int is_wrr, int efficient, bool no_control);
int qcmd_cbq_add_class(const char *ifname, const char *class_name,
const char *parent_name, const char *borrow_name,
u_int pri, u_int bandwidth,
@@ -89,7 +90,7 @@
u_int av_pkt_size, u_int max_pkt_size, int flags);
int qop_cbq_add_if(struct ifinfo **rp, const char *ifname,
- u_int bandwidth, int is_wrr, int efficient);
+ u_int bandwidth, int is_wrr, int efficient, bool no_control);
int qop_cbq_add_class(struct classinfo **rp, const char *class_name,
struct ifinfo *ifinfo, struct classinfo *parent,
struct classinfo *borrow, u_int pri, u_int bandwidth,
Home |
Main Index |
Thread Index |
Old Index