summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/net/pf.c384
-rw-r--r--sys/net/pf_ioctl.c6
2 files changed, 166 insertions, 224 deletions
diff --git a/sys/net/pf.c b/sys/net/pf.c
index 275018039e8..970054a95c2 100644
--- a/sys/net/pf.c
+++ b/sys/net/pf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pf.c,v 1.333 2003/04/05 20:20:58 cedric Exp $ */
+/* $OpenBSD: pf.c,v 1.334 2003/04/05 20:24:58 cedric Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -220,7 +220,6 @@ struct pf_pool_limit pf_pool_limits[PF_LIMIT_MAX] =
if (*state == NULL) \
return (PF_DROP); \
if (direction == PF_OUT && \
- (*state)->rule.ptr != NULL && \
(((*state)->rule.ptr->rt == PF_ROUTETO && \
(*state)->rule.ptr->direction == PF_OUT) || \
((*state)->rule.ptr->rt == PF_REPLYTO && \
@@ -239,7 +238,7 @@ struct pf_pool_limit pf_pool_limits[PF_LIMIT_MAX] =
(s)->lan.port != (s)->gwy.port
#define TIMEOUT(r,i) \
- (((r) && (r)->timeout[(i)]) ? (r)->timeout[(i)] : pf_default_rule.timeout[(i)])
+ ((r)->timeout[(i)] ? (r)->timeout[(i)] : pf_default_rule.timeout[(i)])
static __inline int pf_state_compare(struct pf_tree_node *,
struct pf_tree_node *);
@@ -471,9 +470,8 @@ pf_purge_expired_states(void)
#if NPFSYNC
pfsync_delete_state(cur->state);
#endif
- if (cur->state->rule.ptr != NULL)
- if (--cur->state->rule.ptr->states <= 0)
- pf_rm_rule(NULL, cur->state->rule.ptr);
+ if (--cur->state->rule.ptr->states <= 0)
+ pf_rm_rule(NULL, cur->state->rule.ptr);
if (cur->state->nat_rule != NULL)
if (--cur->state->nat_rule->states <= 0)
pf_rm_rule(NULL, cur->state->nat_rule);
@@ -1084,7 +1082,7 @@ pf_send_reset(int off, struct tcphdr *th, struct pf_pdesc *pd, sa_family_t af,
th2->th_off = sizeof(*th2) >> 2;
#ifdef ALTQ
- if (r != NULL && r->qid) {
+ if (r->qid) {
struct altq_tag *atag;
mtag = m_tag_get(PACKET_TAG_PF_QID, sizeof(*atag), M_NOWAIT);
@@ -1152,7 +1150,7 @@ pf_send_icmp(struct mbuf *m, u_int8_t type, u_int8_t code, sa_family_t af,
m_tag_prepend(m0, mtag);
#ifdef ALTQ
- if (r != NULL && r->qid) {
+ if (r->qid) {
struct altq_tag *atag;
mtag = m_tag_get(PACKET_TAG_PF_QID, sizeof(*atag), M_NOWAIT);
@@ -1881,13 +1879,11 @@ pf_test_tcp(struct pf_rule **rm, struct pf_state **sm, int direction,
int lookup = -1;
uid_t uid;
gid_t gid;
- struct pf_rule *r, *rs = NULL, *anchorrule = NULL;
+ struct pf_rule *r, *rs = &pf_default_rule, *anchorrule = NULL;
struct pf_ruleset *ruleset = NULL;
u_short reason;
int rewrite = 0;
- *rm = NULL;
-
if (direction == PF_OUT) {
bport = nport = th->th_sport;
/* check outgoing packet for BINAT/NAT */
@@ -1971,60 +1967,56 @@ pf_test_tcp(struct pf_rule **rm, struct pf_state **sm, int direction,
}
r = *rm;
- if (r != NULL) {
- r->packets++;
- r->bytes += pd->tot_len;
- if (rs != r) {
- rs->packets++;
- rs->bytes += pd->tot_len;
- }
- REASON_SET(&reason, PFRES_MATCH);
+ r->packets++;
+ r->bytes += pd->tot_len;
+ if (rs != r) {
+ rs->packets++;
+ rs->bytes += pd->tot_len;
+ }
+ REASON_SET(&reason, PFRES_MATCH);
- if (r->log) {
- if (rewrite)
- m_copyback(m, off, sizeof(*th), (caddr_t)th);
- PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
- }
+ if (r->log) {
+ if (rewrite)
+ m_copyback(m, off, sizeof(*th), (caddr_t)th);
+ PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
+ }
- if ((r->action == PF_DROP) &&
- ((r->rule_flag & PFRULE_RETURNRST) ||
- (r->rule_flag & PFRULE_RETURNICMP) ||
- (r->rule_flag & PFRULE_RETURN))) {
- /* undo NAT/RST changes, if they have taken place */
- if (nat != NULL) {
- pf_change_ap(saddr, &th->th_sport, pd->ip_sum,
- &th->th_sum, &baddr, bport, 0, af);
- rewrite++;
- } else if (rdr != NULL) {
- pf_change_ap(daddr, &th->th_dport, pd->ip_sum,
- &th->th_sum, &baddr, bport, 0, af);
- rewrite++;
- }
- if ((r->rule_flag & PFRULE_RETURNRST) ||
- (r->rule_flag & PFRULE_RETURN))
- pf_send_reset(off, th, pd, af,
- r->return_ttl, r);
- else if ((af == AF_INET) && r->return_icmp)
- pf_send_icmp(m, r->return_icmp >> 8,
- r->return_icmp & 255, af, r);
- else if ((af == AF_INET6) && r->return_icmp6)
- pf_send_icmp(m, r->return_icmp6 >> 8,
- r->return_icmp6 & 255, af, r);
+ if ((r->action == PF_DROP) &&
+ ((r->rule_flag & PFRULE_RETURNRST) ||
+ (r->rule_flag & PFRULE_RETURNICMP) ||
+ (r->rule_flag & PFRULE_RETURN))) {
+ /* undo NAT/RST changes, if they have taken place */
+ if (nat != NULL) {
+ pf_change_ap(saddr, &th->th_sport, pd->ip_sum,
+ &th->th_sum, &baddr, bport, 0, af);
+ rewrite++;
+ } else if (rdr != NULL) {
+ pf_change_ap(daddr, &th->th_dport, pd->ip_sum,
+ &th->th_sum, &baddr, bport, 0, af);
+ rewrite++;
}
-
- if (r->action == PF_DROP)
- return (PF_DROP);
+ if ((r->rule_flag & PFRULE_RETURNRST) ||
+ (r->rule_flag & PFRULE_RETURN))
+ pf_send_reset(off, th, pd, af,
+ r->return_ttl, r);
+ else if ((af == AF_INET) && r->return_icmp)
+ pf_send_icmp(m, r->return_icmp >> 8,
+ r->return_icmp & 255, af, r);
+ else if ((af == AF_INET6) && r->return_icmp6)
+ pf_send_icmp(m, r->return_icmp6 >> 8,
+ r->return_icmp6 & 255, af, r);
}
- if ((r != NULL && r->keep_state) ||
- nat != NULL || rdr != NULL) {
+ if (r->action == PF_DROP)
+ return (PF_DROP);
+
+ if (r->keep_state || nat != NULL || rdr != NULL) {
/* create new state */
u_int16_t len;
struct pf_state *s = NULL;
len = pd->tot_len - off - (th->th_off << 2);
- if (r == NULL || !r->max_states ||
- r->states < r->max_states)
+ if (!r->max_states || r->states < r->max_states)
s = pool_get(&pf_state_pl, PR_NOWAIT);
if (s == NULL) {
REASON_SET(&reason, PFRES_MEMORY);
@@ -2041,8 +2033,8 @@ pf_test_tcp(struct pf_rule **rm, struct pf_state **sm, int direction,
s->nat_rule = rdr;
if (s->nat_rule != NULL)
s->nat_rule->states++;
- s->allow_opts = r && r->allow_opts;
- s->log = r && (r->log & 2);
+ s->allow_opts = r->allow_opts;
+ s->log = r->log & 2;
s->proto = IPPROTO_TCP;
s->direction = direction;
s->af = af;
@@ -2076,7 +2068,7 @@ pf_test_tcp(struct pf_rule **rm, struct pf_state **sm, int direction,
s->src.seqlo = ntohl(th->th_seq);
s->src.seqhi = s->src.seqlo + len + 1;
if ((th->th_flags & (TH_SYN|TH_ACK)) == TH_SYN &&
- r != NULL && r->keep_state == PF_STATE_MODULATE) {
+ r->keep_state == PF_STATE_MODULATE) {
/* Generate sequence number modulator */
while ((s->src.seqdiff = arc4random()) == 0)
;
@@ -2131,13 +2123,11 @@ pf_test_udp(struct pf_rule **rm, struct pf_state **sm, int direction,
int lookup = -1;
uid_t uid;
gid_t gid;
- struct pf_rule *r, *rs = NULL, *anchorrule = NULL;
+ struct pf_rule *r, *rs = &pf_default_rule, *anchorrule = NULL;
struct pf_ruleset *ruleset = NULL;
u_short reason;
int rewrite = 0;
- *rm = NULL;
-
if (direction == PF_OUT) {
bport = nport = uh->uh_sport;
/* check outgoing packet for BINAT/NAT */
@@ -2219,53 +2209,49 @@ pf_test_udp(struct pf_rule **rm, struct pf_state **sm, int direction,
}
r = *rm;
- if (r != NULL) {
- r->packets++;
- r->bytes += pd->tot_len;
- if (rs != r) {
- rs->packets++;
- rs->bytes += pd->tot_len;
- }
- REASON_SET(&reason, PFRES_MATCH);
+ r->packets++;
+ r->bytes += pd->tot_len;
+ if (rs != r) {
+ rs->packets++;
+ rs->bytes += pd->tot_len;
+ }
+ REASON_SET(&reason, PFRES_MATCH);
- if (r->log) {
- if (rewrite)
- m_copyback(m, off, sizeof(*uh), (caddr_t)uh);
- PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
- }
+ if (r->log) {
+ if (rewrite)
+ m_copyback(m, off, sizeof(*uh), (caddr_t)uh);
+ PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
+ }
- if ((r->action == PF_DROP) &&
- ((r->rule_flag & PFRULE_RETURNICMP) ||
- (r->rule_flag & PFRULE_RETURN))) {
- /* undo NAT/RST changes, if they have taken place */
- if (nat != NULL) {
- pf_change_ap(saddr, &uh->uh_sport, pd->ip_sum,
- &uh->uh_sum, &baddr, bport, 1, af);
- rewrite++;
- } else if (rdr != NULL) {
- pf_change_ap(daddr, &uh->uh_dport, pd->ip_sum,
- &uh->uh_sum, &baddr, bport, 1, af);
- rewrite++;
- }
- if ((af == AF_INET) && r->return_icmp)
- pf_send_icmp(m, r->return_icmp >> 8,
- r->return_icmp & 255, af, r);
- else if ((af == AF_INET6) && r->return_icmp6)
- pf_send_icmp(m, r->return_icmp6 >> 8,
- r->return_icmp6 & 255, af, r);
+ if ((r->action == PF_DROP) &&
+ ((r->rule_flag & PFRULE_RETURNICMP) ||
+ (r->rule_flag & PFRULE_RETURN))) {
+ /* undo NAT/RST changes, if they have taken place */
+ if (nat != NULL) {
+ pf_change_ap(saddr, &uh->uh_sport, pd->ip_sum,
+ &uh->uh_sum, &baddr, bport, 1, af);
+ rewrite++;
+ } else if (rdr != NULL) {
+ pf_change_ap(daddr, &uh->uh_dport, pd->ip_sum,
+ &uh->uh_sum, &baddr, bport, 1, af);
+ rewrite++;
}
-
- if (r->action == PF_DROP)
- return (PF_DROP);
+ if ((af == AF_INET) && r->return_icmp)
+ pf_send_icmp(m, r->return_icmp >> 8,
+ r->return_icmp & 255, af, r);
+ else if ((af == AF_INET6) && r->return_icmp6)
+ pf_send_icmp(m, r->return_icmp6 >> 8,
+ r->return_icmp6 & 255, af, r);
}
- if ((r != NULL && r->keep_state) ||
- nat != NULL || rdr != NULL) {
+ if (r->action == PF_DROP)
+ return (PF_DROP);
+
+ if (r->keep_state || nat != NULL || rdr != NULL) {
/* create new state */
struct pf_state *s = NULL;
- if (r == NULL || !r->max_states ||
- r->states < r->max_states)
+ if (!r->max_states || r->states < r->max_states)
s = pool_get(&pf_state_pl, PR_NOWAIT);
if (s == NULL)
return (PF_DROP);
@@ -2280,8 +2266,8 @@ pf_test_udp(struct pf_rule **rm, struct pf_state **sm, int direction,
s->nat_rule = rdr;
if (s->nat_rule != NULL)
s->nat_rule->states++;
- s->allow_opts = r && r->allow_opts;
- s->log = r && (r->log & 2);
+ s->allow_opts = r->allow_opts;
+ s->log = r->log & 2;
s->proto = IPPROTO_UDP;
s->direction = direction;
s->af = af;
@@ -2347,7 +2333,7 @@ pf_test_icmp(struct pf_rule **rm, struct pf_state **sm, int direction,
struct pf_rule *nat = NULL, *rdr = NULL;
struct pf_addr *saddr = pd->src, *daddr = pd->dst;
struct pf_addr baddr, naddr;
- struct pf_rule *r, *rs = NULL, *anchorrule = NULL;
+ struct pf_rule *r, *rs = &pf_default_rule, *anchorrule = NULL;
struct pf_ruleset *ruleset = NULL;
u_short reason;
u_int16_t icmpid;
@@ -2358,8 +2344,6 @@ pf_test_icmp(struct pf_rule **rm, struct pf_state **sm, int direction,
int rewrite = 0;
#endif /* INET6 */
- *rm = NULL;
-
switch (pd->proto) {
#ifdef INET
case IPPROTO_ICMP:
@@ -2477,35 +2461,32 @@ pf_test_icmp(struct pf_rule **rm, struct pf_state **sm, int direction,
}
r = *rm;
- if (r != NULL) {
- r->packets++;
- r->bytes += pd->tot_len;
- if (rs != r) {
- rs->packets++;
- rs->bytes += pd->tot_len;
- }
- REASON_SET(&reason, PFRES_MATCH);
+ r->packets++;
+ r->bytes += pd->tot_len;
+ if (rs != r) {
+ rs->packets++;
+ rs->bytes += pd->tot_len;
+ }
+ REASON_SET(&reason, PFRES_MATCH);
- if (r->log) {
+ if (r->log) {
#ifdef INET6
- if (rewrite)
- m_copyback(m, off, ICMP_MINLEN,
- (caddr_t)pd->hdr.icmp6);
+ if (rewrite)
+ m_copyback(m, off, ICMP_MINLEN,
+ (caddr_t)pd->hdr.icmp6);
#endif /* INET6 */
- PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
- }
-
- if (r->action != PF_PASS)
- return (PF_DROP);
+ PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
}
- if (!state_icmp && ((r != NULL && r->keep_state) ||
+ if (r->action != PF_PASS)
+ return (PF_DROP);
+
+ if (!state_icmp && (r->keep_state ||
nat != NULL || rdr != NULL)) {
/* create new state */
struct pf_state *s = NULL;
- if (r == NULL || !r->max_states ||
- r->states < r->max_states)
+ if (!r->max_states || r->states < r->max_states)
s = pool_get(&pf_state_pl, PR_NOWAIT);
if (s == NULL)
return (PF_DROP);
@@ -2520,8 +2501,8 @@ pf_test_icmp(struct pf_rule **rm, struct pf_state **sm, int direction,
s->nat_rule = rdr;
if (s->nat_rule != NULL)
s->nat_rule->states++;
- s->allow_opts = r && r->allow_opts;
- s->log = r && (r->log & 2);
+ s->allow_opts = r->allow_opts;
+ s->log = r->log & 2;
s->proto = pd->proto;
s->direction = direction;
s->af = af;
@@ -2583,15 +2564,13 @@ pf_test_other(struct pf_rule **rm, struct pf_state **sm, int direction,
struct ifnet *ifp, struct mbuf *m, void *h, struct pf_pdesc *pd)
{
struct pf_rule *nat = NULL, *rdr = NULL;
- struct pf_rule *r, *rs = NULL, *anchorrule = NULL;
+ struct pf_rule *r, *rs = &pf_default_rule, *anchorrule = NULL;
struct pf_ruleset *ruleset = NULL;
struct pf_addr *saddr = pd->src, *daddr = pd->dst;
struct pf_addr baddr, naddr;
sa_family_t af = pd->af;
u_short reason;
- *rm = NULL;
-
if (direction == PF_OUT) {
/* check outgoing packet for BINAT/NAT */
if ((nat = pf_get_translation(PF_OUT, ifp, pd->proto,
@@ -2670,28 +2649,24 @@ pf_test_other(struct pf_rule **rm, struct pf_state **sm, int direction,
}
r = *rm;
- if (r != NULL) {
- r->packets++;
- r->bytes += pd->tot_len;
- if (rs != r) {
- rs->packets++;
- rs->bytes += pd->tot_len;
- }
- REASON_SET(&reason, PFRES_MATCH);
- if (r->log)
- PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
-
- if (r->action != PF_PASS)
- return (PF_DROP);
+ r->packets++;
+ r->bytes += pd->tot_len;
+ if (rs != r) {
+ rs->packets++;
+ rs->bytes += pd->tot_len;
}
+ REASON_SET(&reason, PFRES_MATCH);
+ if (r->log)
+ PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
- if ((r != NULL && r->keep_state) || nat != NULL ||
- rdr != NULL) {
+ if (r->action != PF_PASS)
+ return (PF_DROP);
+
+ if (r->keep_state || nat != NULL || rdr != NULL) {
/* create new state */
struct pf_state *s = NULL;
- if (r == NULL || !r->max_states ||
- r->states < r->max_states)
+ if (!r->max_states || r->states < r->max_states)
s = pool_get(&pf_state_pl, PR_NOWAIT);
if (s == NULL)
return (PF_DROP);
@@ -2706,8 +2681,8 @@ pf_test_other(struct pf_rule **rm, struct pf_state **sm, int direction,
s->nat_rule = rdr;
if (s->nat_rule != NULL)
s->nat_rule->states++;
- s->allow_opts = r && r->allow_opts;
- s->log = r && (r->log & 2);
+ s->allow_opts = r->allow_opts;
+ s->log = r->log & 2;
s->proto = pd->proto;
s->direction = direction;
s->af = af;
@@ -2748,7 +2723,7 @@ pf_test_other(struct pf_rule **rm, struct pf_state **sm, int direction,
s->bytes = pd->tot_len;
if (pf_insert_state(s)) {
REASON_SET(&reason, PFRES_MEMORY);
- if (r && r->log)
+ if (r->log)
PFLOG_PACKET(ifp, h, m, af, direction, reason,
rs);
pool_put(&pf_state_pl, s);
@@ -2764,11 +2739,10 @@ int
pf_test_fragment(struct pf_rule **rm, int direction, struct ifnet *ifp,
struct mbuf *m, void *h, struct pf_pdesc *pd)
{
- struct pf_rule *r, *rs = NULL, *anchorrule = NULL;
+ struct pf_rule *r, *rs = &pf_default_rule, *anchorrule = NULL;
struct pf_ruleset *ruleset = NULL;
sa_family_t af = pd->af;
-
- *rm = NULL;
+ u_short reason;
r = TAILQ_FIRST(pf_main_ruleset.rules[PF_RULESET_FILTER].active.ptr);
while (r != NULL) {
@@ -2810,22 +2784,18 @@ pf_test_fragment(struct pf_rule **rm, int direction, struct ifnet *ifp,
}
r = *rm;
- if (r != NULL) {
- u_short reason;
-
- r->packets++;
- r->bytes += pd->tot_len;
- if (rs != r) {
- rs->packets++;
- rs->bytes += pd->tot_len;
- }
- REASON_SET(&reason, PFRES_MATCH);
- if (r->log)
- PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
-
- if (r->action != PF_PASS)
- return (PF_DROP);
+ r->packets++;
+ r->bytes += pd->tot_len;
+ if (rs != r) {
+ rs->packets++;
+ rs->bytes += pd->tot_len;
}
+ REASON_SET(&reason, PFRES_MATCH);
+ if (r->log)
+ PFLOG_PACKET(ifp, h, m, af, direction, reason, rs);
+
+ if (r->action != PF_PASS)
+ return (PF_DROP);
return (PF_PASS);
}
@@ -3121,10 +3091,8 @@ pf_test_state_tcp(struct pf_state **state, int direction, struct ifnet *ifp,
m_copyback(m, off, sizeof(*th), (caddr_t)th);
}
- if ((*state)->rule.ptr != NULL) {
- (*state)->rule.ptr->packets++;
- (*state)->rule.ptr->bytes += pd->tot_len;
- }
+ (*state)->rule.ptr->packets++;
+ (*state)->rule.ptr->bytes += pd->tot_len;
if ((*state)->nat_rule != NULL) {
(*state)->nat_rule->packets++;
(*state)->nat_rule->bytes += pd->tot_len;
@@ -3187,10 +3155,8 @@ pf_test_state_udp(struct pf_state **state, int direction, struct ifnet *ifp,
m_copyback(m, off, sizeof(*uh), (caddr_t)uh);
}
- if ((*state)->rule.ptr != NULL) {
- (*state)->rule.ptr->packets++;
- (*state)->rule.ptr->bytes += pd->tot_len;
- }
+ (*state)->rule.ptr->packets++;
+ (*state)->rule.ptr->bytes += pd->tot_len;
if ((*state)->nat_rule != NULL) {
(*state)->nat_rule->packets++;
(*state)->nat_rule->bytes += pd->tot_len;
@@ -3743,10 +3709,8 @@ pf_test_state_other(struct pf_state **state, int direction, struct ifnet *ifp,
}
}
- if ((*state)->rule.ptr != NULL) {
- (*state)->rule.ptr->packets++;
- (*state)->rule.ptr->bytes += pd->tot_len;
- }
+ (*state)->rule.ptr->packets++;
+ (*state)->rule.ptr->bytes += pd->tot_len;
if ((*state)->nat_rule != NULL) {
(*state)->nat_rule->packets++;
(*state)->nat_rule->bytes += pd->tot_len;
@@ -4216,7 +4180,7 @@ pf_test(int dir, struct ifnet *ifp, struct mbuf **m0)
u_short action, reason = 0, log = 0;
struct mbuf *m = *m0;
struct ip *h;
- struct pf_rule *r = NULL;
+ struct pf_rule *r = &pf_default_rule;
struct pf_state *s = NULL;
struct pf_pdesc pd;
int off;
@@ -4341,10 +4305,8 @@ pf_test(int dir, struct ifnet *ifp, struct mbuf **m0)
action = pf_test_state_icmp(&s, dir, ifp, m, 0, off, h, &pd);
if (action == PF_PASS) {
r = s->rule.ptr;
- if (r != NULL) {
- r->packets++;
- r->bytes += h->ip_len;
- }
+ r->packets++;
+ r->bytes += h->ip_len;
log = s->log;
} else if (s == NULL)
action = pf_test_icmp(&r, &s, dir, ifp,
@@ -4368,19 +4330,19 @@ pf_test(int dir, struct ifnet *ifp, struct mbuf **m0)
}
done:
- if (r != NULL && r->src.addr.type == PF_ADDR_TABLE)
+ if (r->src.addr.type == PF_ADDR_TABLE)
pfr_update_stats(r->src.addr.p.tbl,
(s == NULL || s->direction == dir) ? pd.src : pd.dst, pd.af,
pd.tot_len, dir == PF_OUT, r->action == PF_PASS,
r->src.not);
- if (r != NULL && r->dst.addr.type == PF_ADDR_TABLE)
+ if (r->dst.addr.type == PF_ADDR_TABLE)
pfr_update_stats(r->dst.addr.p.tbl,
(s == NULL || s->direction == dir) ? pd.dst : pd.src, pd.af,
pd.tot_len, dir == PF_OUT, r->action == PF_PASS,
r->dst.not);
if (action != PF_DROP && h->ip_hl > 5 &&
- !((s && s->allow_opts) || (r && r->allow_opts))) {
+ !((s && s->allow_opts) || r->allow_opts)) {
action = PF_DROP;
REASON_SET(&reason, PFRES_SHORT);
log = 1;
@@ -4389,7 +4351,7 @@ done:
}
#ifdef ALTQ
- if (action != PF_DROP && r != NULL && r->qid) {
+ if (action != PF_DROP && r->qid) {
struct m_tag *mtag;
struct altq_tag *atag;
@@ -4408,20 +4370,11 @@ done:
}
#endif
- if (log) {
- if (r == NULL) {
- struct pf_rule r0;
-
- r0.ifp = ifp;
- r0.action = action;
- r0.nr = -1;
- PFLOG_PACKET(ifp, h, m, AF_INET, dir, reason, &r0);
- } else
- PFLOG_PACKET(ifp, h, m, AF_INET, dir, reason, r);
- }
+ if (log)
+ PFLOG_PACKET(ifp, h, m, AF_INET, dir, reason, r);
/* pf_route can free the mbuf causing *m0 to become NULL */
- if (r != NULL && r->rt)
+ if (r->rt)
pf_route(m0, r, dir, ifp, s);
return (action);
@@ -4435,7 +4388,7 @@ pf_test6(int dir, struct ifnet *ifp, struct mbuf **m0)
u_short action, reason = 0, log = 0;
struct mbuf *m = *m0;
struct ip6_hdr *h;
- struct pf_rule *r = NULL;
+ struct pf_rule *r = &pf_default_rule;
struct pf_state *s = NULL;
struct pf_pdesc pd;
int off, terminal = 0;
@@ -4577,10 +4530,8 @@ pf_test6(int dir, struct ifnet *ifp, struct mbuf **m0)
m, 0, off, h, &pd);
if (action == PF_PASS) {
r = s->rule.ptr;
- if (r != NULL) {
- r->packets++;
- r->bytes += h->ip6_plen;
- }
+ r->packets++;
+ r->bytes += h->ip6_plen;
log = s->log;
} else if (s == NULL)
action = pf_test_icmp(&r, &s, dir, ifp,
@@ -4599,12 +4550,12 @@ pf_test6(int dir, struct ifnet *ifp, struct mbuf **m0)
}
done:
- if (r != NULL && r->src.addr.type == PF_ADDR_TABLE)
+ if (r->src.addr.type == PF_ADDR_TABLE)
pfr_update_stats(r->src.addr.p.tbl,
(s == NULL || s->direction == dir) ? pd.src : pd.dst, pd.af,
pd.tot_len, dir == PF_OUT, r->action == PF_PASS,
r->src.not);
- if (r != NULL && r->dst.addr.type == PF_ADDR_TABLE)
+ if (r->dst.addr.type == PF_ADDR_TABLE)
pfr_update_stats(r->dst.addr.p.tbl,
(s == NULL || s->direction == dir) ? pd.dst : pd.src, pd.af,
pd.tot_len, dir == PF_OUT, r->action == PF_PASS,
@@ -4613,7 +4564,7 @@ done:
/* XXX handle IPv6 options, if not allowed. not implemented. */
#ifdef ALTQ
- if (action != PF_DROP && r != NULL && r->qid) {
+ if (action != PF_DROP && r->qid) {
struct m_tag *mtag;
struct altq_tag *atag;
@@ -4632,20 +4583,11 @@ done:
}
#endif
- if (log) {
- if (r == NULL) {
- struct pf_rule r0;
-
- r0.ifp = ifp;
- r0.action = action;
- r0.nr = -1;
- PFLOG_PACKET(ifp, h, m, AF_INET6, dir, reason, &r0);
- } else
- PFLOG_PACKET(ifp, h, m, AF_INET6, dir, reason, r);
- }
+ if (log)
+ PFLOG_PACKET(ifp, h, m, AF_INET6, dir, reason, r);
/* pf_route6 can free the mbuf causing *m0 to become NULL */
- if (r != NULL && r->rt)
+ if (r->rt)
pf_route6(m0, r, dir, ifp, s);
return (action);
diff --git a/sys/net/pf_ioctl.c b/sys/net/pf_ioctl.c
index 62103d60612..c8c29cf6097 100644
--- a/sys/net/pf_ioctl.c
+++ b/sys/net/pf_ioctl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pf_ioctl.c,v 1.54 2003/04/05 20:20:58 cedric Exp $ */
+/* $OpenBSD: pf_ioctl.c,v 1.55 2003/04/05 20:24:58 cedric Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -990,7 +990,7 @@ pfioctl(dev_t dev, u_long cmd, caddr_t addr, int flags, struct proc *p)
break;
}
bcopy(n->state, &ps->state, sizeof(struct pf_state));
- if (n->state->rule.ptr == NULL)
+ if (n->state->rule.ptr->entries.tqe_prev == NULL)
ps->state.rule.nr = -1;
else
ps->state.rule.nr = n->state->rule.ptr->nr;
@@ -1029,7 +1029,7 @@ pfioctl(dev_t dev, u_long cmd, caddr_t addr, int flags, struct proc *p)
break;
bcopy(n->state, &pstore, sizeof(pstore));
- if (n->state->rule.ptr == NULL)
+ if (n->state->rule.ptr->entries.tqe_prev == NULL)
pstore.rule.nr = -1;
else
pstore.rule.nr = n->state->rule.ptr->nr;