MFC:
Dummynet has a limit of 100 slots queue size (or 1MB, if you give the limit in bytes) hard coded into both the kernel and userland. Make both these limits a sysctl, so it is easy to change the limit.
This commit is contained in:
parent
6fadc1ed53
commit
bdf655b82e
@ -1937,6 +1937,13 @@ or 20s of queue on a 30Kbit/s pipe.
|
||||
Even worse effects can result if you get packets from an
|
||||
interface with a much larger MTU, e.g.\& the loopback interface
|
||||
with its 16KB packets.
|
||||
The
|
||||
.Xr sysctl 8
|
||||
variables
|
||||
.Em net.inet.ip.dummynet.pipe_byte_limit
|
||||
and
|
||||
.Em net.inet.ip.dummynet.pipe_slot_limit
|
||||
control the maximum lengths that can be specified.
|
||||
.Pp
|
||||
.It Cm red | gred Ar w_q Ns / Ns Ar min_th Ns / Ns Ar max_th Ns / Ns Ar max_p
|
||||
Make use of the RED (Random Early Detection) queue management algorithm.
|
||||
@ -2092,6 +2099,13 @@ will be expired even when
|
||||
.It Em net.inet.ip.dummynet.red_max_pkt_size : No 1500
|
||||
Parameters used in the computations of the drop probability
|
||||
for the RED algorithm.
|
||||
.It Va net.inet.ip.dummynet.pipe_byte_limit : No 1048576
|
||||
.It Va net.inet.ip.dummynet.pipe_slot_limit : No 100
|
||||
The maximum queue size that can be specified in bytes or packets.
|
||||
These limits prevent accidental exhaustion of resources such as mbufs.
|
||||
If you raise these limits,
|
||||
you should make sure the system is configured so that sufficient resources
|
||||
are available.
|
||||
.It Em net.inet.ip.fw.autoinc_step : No 100
|
||||
Delta between rule numbers when auto-generating them.
|
||||
The value must be in the range 1..1000.
|
||||
|
@ -3485,11 +3485,25 @@ config_pipe(int ac, char **av)
|
||||
errx(EX_DATAERR, "weight must be <= 100");
|
||||
}
|
||||
if (p.fs.flags_fs & DN_QSIZE_IS_BYTES) {
|
||||
if (p.fs.qsize > 1024*1024)
|
||||
errx(EX_DATAERR, "queue size must be < 1MB");
|
||||
size_t len;
|
||||
long limit;
|
||||
|
||||
len = sizeof(limit);
|
||||
if (sysctlbyname("net.inet.ip.dummynet.pipe_byte_limit",
|
||||
&limit, &len, NULL, 0) == -1)
|
||||
limit = 1024*1024;
|
||||
if (p.fs.qsize > limit)
|
||||
errx(EX_DATAERR, "queue size must be < %ldB", limit);
|
||||
} else {
|
||||
if (p.fs.qsize > 100)
|
||||
errx(EX_DATAERR, "2 <= queue size <= 100");
|
||||
size_t len;
|
||||
long limit;
|
||||
|
||||
len = sizeof(limit);
|
||||
if (sysctlbyname("net.inet.ip.dummynet.pipe_slot_limit",
|
||||
&limit, &len, NULL, 0) == -1)
|
||||
limit = 100;
|
||||
if (p.fs.qsize > limit)
|
||||
errx(EX_DATAERR, "2 <= queue size <= %ld", limit);
|
||||
}
|
||||
if (p.fs.flags_fs & DN_IS_RED) {
|
||||
size_t len;
|
||||
@ -3507,7 +3521,6 @@ config_pipe(int ac, char **av)
|
||||
len = sizeof(int);
|
||||
if (sysctlbyname("net.inet.ip.dummynet.red_lookup_depth",
|
||||
&lookup_depth, &len, NULL, 0) == -1)
|
||||
|
||||
errx(1, "sysctlbyname(\"%s\")",
|
||||
"net.inet.ip.dummynet.red_lookup_depth");
|
||||
if (lookup_depth == 0)
|
||||
|
@ -98,6 +98,9 @@ static long searches, search_steps ;
|
||||
static int pipe_expire = 1 ; /* expire queue if empty */
|
||||
static int dn_max_ratio = 16 ; /* max queues/buckets ratio */
|
||||
|
||||
static long pipe_slot_limit = 100; /* Foot shooting limit for pipe queues. */
|
||||
static long pipe_byte_limit = 1024 * 1024;
|
||||
|
||||
static int red_lookup_depth = 256; /* RED - default lookup table depth */
|
||||
static int red_avg_pkt_size = 512; /* RED - default medium packet size */
|
||||
static int red_max_pkt_size = 1500; /* RED - default max packet size */
|
||||
@ -198,6 +201,10 @@ SYSCTL_ULONG(_net_inet_ip_dummynet, OID_AUTO, io_pkt_fast,
|
||||
SYSCTL_ULONG(_net_inet_ip_dummynet, OID_AUTO, io_pkt_drop,
|
||||
CTLFLAG_RD, &io_pkt_drop, 0,
|
||||
"Number of packets dropped by dummynet.");
|
||||
SYSCTL_LONG(_net_inet_ip_dummynet, OID_AUTO, pipe_slot_limit,
|
||||
CTLFLAG_RW, &pipe_slot_limit, 0, "Upper limit in slots for pipe queue.");
|
||||
SYSCTL_LONG(_net_inet_ip_dummynet, OID_AUTO, pipe_byte_limit,
|
||||
CTLFLAG_RW, &pipe_byte_limit, 0, "Upper limit in bytes for pipe queue.");
|
||||
#endif
|
||||
|
||||
#ifdef DUMMYNET_DEBUG
|
||||
@ -1725,12 +1732,12 @@ set_fs_parms(struct dn_flow_set *x, struct dn_flow_set *src)
|
||||
x->plr = src->plr;
|
||||
x->flow_mask = src->flow_mask;
|
||||
if (x->flags_fs & DN_QSIZE_IS_BYTES) {
|
||||
if (x->qsize > 1024 * 1024)
|
||||
if (x->qsize > pipe_byte_limit)
|
||||
x->qsize = 1024 * 1024;
|
||||
} else {
|
||||
if (x->qsize == 0)
|
||||
x->qsize = 50;
|
||||
if (x->qsize > 100)
|
||||
if (x->qsize > pipe_slot_limit)
|
||||
x->qsize = 50;
|
||||
}
|
||||
/* Configuring RED. */
|
||||
|
Loading…
Reference in New Issue
Block a user