summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/net/pf.c59
1 files changed, 36 insertions, 23 deletions
diff --git a/sys/net/pf.c b/sys/net/pf.c
index 38c392c5e02..091f0f60830 100644
--- a/sys/net/pf.c
+++ b/sys/net/pf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pf.c,v 1.378 2003/07/19 13:08:58 cedric Exp $ */
+/* $OpenBSD: pf.c,v 1.379 2003/07/29 00:51:32 cedric Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -205,6 +205,9 @@ u_int16_t pf_calc_mss(struct pf_addr *, sa_family_t,
u_int16_t);
int pf_check_proto_cksum(struct mbuf *, int, int,
u_int8_t, sa_family_t);
+int pf_addr_wrap_neq(struct pf_addr_wrap *,
+ struct pf_addr_wrap *);
+
struct pf_pool_limit pf_pool_limits[PF_LIMIT_MAX] =
{ { &pf_state_pl, PFSTATE_HIWAT }, { &pf_frent_pl, PFFRAG_FRENT_HIWAT } };
@@ -808,33 +811,15 @@ pf_calc_skip_steps(struct pf_rulequeue *rules)
PF_SET_SKIP_STEPS(PF_SKIP_AF);
if (cur->proto != prev->proto)
PF_SET_SKIP_STEPS(PF_SKIP_PROTO);
- if (cur->src.addr.type == PF_ADDR_DYNIFTL ||
- prev->src.addr.type == PF_ADDR_DYNIFTL ||
- cur->src.addr.type == PF_ADDR_TABLE ||
- prev->src.addr.type == PF_ADDR_TABLE ||
- cur->src.not != prev->src.not ||
- (cur->src.addr.type == PF_ADDR_NOROUTE) !=
- (prev->src.addr.type == PF_ADDR_NOROUTE) ||
- !PF_AEQ(&cur->src.addr.v.a.addr,
- &prev->src.addr.v.a.addr, 0) ||
- !PF_AEQ(&cur->src.addr.v.a.mask,
- &prev->src.addr.v.a.mask, 0))
+ if (cur->src.not != prev->src.not ||
+ pf_addr_wrap_neq(&cur->src.addr, &prev->src.addr))
PF_SET_SKIP_STEPS(PF_SKIP_SRC_ADDR);
if (cur->src.port[0] != prev->src.port[0] ||
cur->src.port[1] != prev->src.port[1] ||
cur->src.port_op != prev->src.port_op)
PF_SET_SKIP_STEPS(PF_SKIP_SRC_PORT);
- if (cur->dst.addr.type == PF_ADDR_DYNIFTL ||
- prev->dst.addr.type == PF_ADDR_DYNIFTL ||
- cur->dst.addr.type == PF_ADDR_TABLE ||
- prev->dst.addr.type == PF_ADDR_TABLE ||
- cur->dst.not != prev->dst.not ||
- (cur->dst.addr.type == PF_ADDR_NOROUTE) !=
- (prev->dst.addr.type == PF_ADDR_NOROUTE) ||
- !PF_AEQ(&cur->dst.addr.v.a.addr,
- &prev->dst.addr.v.a.addr, 0) ||
- !PF_AEQ(&cur->dst.addr.v.a.mask,
- &prev->dst.addr.v.a.mask, 0))
+ if (cur->dst.not != prev->dst.not ||
+ pf_addr_wrap_neq(&cur->dst.addr, &prev->dst.addr))
PF_SET_SKIP_STEPS(PF_SKIP_DST_ADDR);
if (cur->dst.port[0] != prev->dst.port[0] ||
cur->dst.port[1] != prev->dst.port[1] ||
@@ -848,6 +833,34 @@ pf_calc_skip_steps(struct pf_rulequeue *rules)
PF_SET_SKIP_STEPS(i);
}
+int
+pf_addr_wrap_neq(struct pf_addr_wrap *aw1, struct pf_addr_wrap *aw2)
+{
+ if (aw1->type != aw2->type)
+ return (1);
+ switch (aw1->type) {
+ case PF_ADDR_ADDRMASK:
+ if (PF_ANEQ(&aw1->v.a.addr, &aw2->v.a.addr, 0))
+ return (1);
+ if (PF_ANEQ(&aw1->v.a.mask, &aw2->v.a.mask, 0))
+ return (1);
+ return (0);
+ case PF_ADDR_DYNIFTL:
+ if (aw1->p.dyn->ifp != aw2->p.dyn->ifp)
+ return (1);
+ if (PF_ANEQ(&aw1->v.a.mask, &aw2->v.a.mask, 0))
+ return (1);
+ return (0);
+ case PF_ADDR_NOROUTE:
+ return (0);
+ case PF_ADDR_TABLE:
+ return (aw1->p.tbl != aw2->p.tbl);
+ default:
+ printf("invalid address type: %d\n", aw1->type);
+ return (1);
+ }
+}
+
void
pf_rule_set_qid(struct pf_rulequeue *rules)
{