diff options
author | Daniel Hartmeier <dhartmei@cvs.openbsd.org> | 2001-09-27 17:49:13 +0000 |
---|---|---|
committer | Daniel Hartmeier <dhartmei@cvs.openbsd.org> | 2001-09-27 17:49:13 +0000 |
commit | c5c8f3e992a12807e021c397d336fe2da0fcbefe (patch) | |
tree | 14d9c67ec17bada49eb505b2152fc040d604439f | |
parent | 13527fa356aaa4a28ed573a411ec715a61c32ff0 (diff) |
The skip steps array was one element short (since adding steps for af).
This invoked undefined behaviour under the proper circumstances.
-rw-r--r-- | sys/net/pf.c | 4 | ||||
-rw-r--r-- | sys/net/pfvar.h | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/sys/net/pf.c b/sys/net/pf.c index 4b71d49c851..e695f369413 100644 --- a/sys/net/pf.c +++ b/sys/net/pf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pf.c,v 1.158 2001/09/27 15:15:17 dhartmei Exp $ */ +/* $OpenBSD: pf.c,v 1.159 2001/09/27 17:49:12 dhartmei Exp $ */ /* * Copyright (c) 2001 Daniel Hartmeier @@ -2100,7 +2100,7 @@ pf_calc_skip_steps(struct pf_rulequeue *rules) r = TAILQ_FIRST(rules); while (r != NULL) { a = 0; - for (i = 0; i < 6; ++i) { + for (i = 0; i < 7; ++i) { a |= 1 << i; r->skip[i] = TAILQ_NEXT(r, entries); } diff --git a/sys/net/pfvar.h b/sys/net/pfvar.h index 15ac11dbf05..69137a4835d 100644 --- a/sys/net/pfvar.h +++ b/sys/net/pfvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pfvar.h,v 1.52 2001/09/15 16:47:07 dhartmei Exp $ */ +/* $OpenBSD: pfvar.h,v 1.53 2001/09/27 17:49:12 dhartmei Exp $ */ /* * Copyright (c) 2001 Daniel Hartmeier @@ -191,7 +191,7 @@ struct pf_rule { struct ifnet *ifp; struct pf_rule_addr src; struct pf_rule_addr dst; - struct pf_rule *skip[6]; + struct pf_rule *skip[7]; TAILQ_ENTRY(pf_rule) entries; u_int64_t evaluations; |