summaryrefslogtreecommitdiff
path: root/sbin/pfctl
diff options
context:
space:
mode:
Diffstat (limited to 'sbin/pfctl')
-rw-r--r--sbin/pfctl/parse.y132
-rw-r--r--sbin/pfctl/pf_print_state.c22
-rw-r--r--sbin/pfctl/pfctl.c17
-rw-r--r--sbin/pfctl/pfctl_parser.c36
4 files changed, 106 insertions, 101 deletions
diff --git a/sbin/pfctl/parse.y b/sbin/pfctl/parse.y
index c3ecf67540d..6524ab90b54 100644
--- a/sbin/pfctl/parse.y
+++ b/sbin/pfctl/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.276 2003/01/04 17:40:51 dhartmei Exp $ */
+/* $OpenBSD: parse.y,v 1.277 2003/01/05 22:14:23 dhartmei Exp $ */
/*
* Copyright (c) 2001 Markus Friedl. All rights reserved.
@@ -1513,9 +1513,9 @@ address : '(' STRING ')' {
err(1, "address: calloc");
$$->af = 0;
set_ipmask($$, 128);
- $$->addr.addr_dyn = (struct pf_addr_dyn *)1;
- strlcpy($$->addr.addr.pfa.ifname, $2,
- sizeof($$->addr.addr.pfa.ifname));
+ $$->addr.type = PF_ADDR_DYNIFTL;
+ strlcpy($$->addr.v.ifname, $2,
+ sizeof($$->addr.v.ifname));
$$->next = NULL;
$$->tail = $$;
}
@@ -2219,10 +2219,10 @@ natrule : no NAT interface af proto fromto redirpool pooltype staticport
}
} else {
if ((nat.af == AF_INET &&
- unmask(&$7->host->addr.mask,
+ unmask(&$7->host->addr.v.a.mask,
nat.af) == 32) ||
(nat.af == AF_INET6 &&
- unmask(&$7->host->addr.mask,
+ unmask(&$7->host->addr.v.a.mask,
nat.af) == 128)) {
nat.rpool.opts = PF_POOL_NONE;
} else {
@@ -2282,7 +2282,7 @@ binatrule : no BINAT interface af proto FROM host TO ipspec redirection
yyerror("multiple binat ip addresses");
YYERROR;
}
- if ($7->addr.addr_dyn != NULL) {
+ if ($7->addr.type == PF_ADDR_DYNIFTL) {
if (!binat.af) {
yyerror("address family (inet/"
"inet6) undefined");
@@ -2295,10 +2295,12 @@ binatrule : no BINAT interface af proto FROM host TO ipspec redirection
YYERROR;
}
binat.af = $7->af;
- memcpy(&binat.src.addr.addr, &$7->addr.addr,
- sizeof(binat.src.addr.addr));
- memcpy(&binat.src.addr.mask, &$7->addr.mask,
- sizeof(binat.src.addr.mask));
+ memcpy(&binat.src.addr.v.a.addr,
+ &$7->addr.v.a.addr,
+ sizeof(binat.src.addr.v.a.addr));
+ memcpy(&binat.src.addr.v.a.mask,
+ &$7->addr.v.a.mask,
+ sizeof(binat.src.addr.v.a.mask));
free($7);
}
if ($9 != NULL) {
@@ -2306,7 +2308,7 @@ binatrule : no BINAT interface af proto FROM host TO ipspec redirection
yyerror("multiple binat ip addresses");
YYERROR;
}
- if ($9->addr.addr_dyn != NULL) {
+ if ($9->addr.type == PF_ADDR_DYNIFTL) {
if (!binat.af) {
yyerror("address family (inet/"
"inet6) undefined");
@@ -2319,10 +2321,12 @@ binatrule : no BINAT interface af proto FROM host TO ipspec redirection
YYERROR;
}
binat.af = $9->af;
- memcpy(&binat.dst.addr.addr, &$9->addr.addr,
- sizeof(binat.dst.addr.addr));
- memcpy(&binat.dst.addr.mask, &$9->addr.mask,
- sizeof(binat.dst.addr.mask));
+ memcpy(&binat.dst.addr.v.a.addr,
+ &$9->addr.v.a.addr,
+ sizeof(binat.dst.addr.v.a.addr));
+ memcpy(&binat.dst.addr.v.a.mask,
+ &$9->addr.v.a.mask,
+ sizeof(binat.dst.addr.v.a.mask));
binat.dst.not = $9->not;
free($9);
}
@@ -2349,9 +2353,9 @@ binatrule : no BINAT interface af proto FROM host TO ipspec redirection
YYERROR;
}
- if (!PF_AZERO(&binat.src.addr.mask, binat.af) &&
- !PF_AEQ(&binat.src.addr.mask,
- &$10->host->addr.mask, binat.af)) {
+ if (!PF_AZERO(&binat.src.addr.v.a.mask, binat.af) &&
+ !PF_AEQ(&binat.src.addr.v.a.mask,
+ &$10->host->addr.v.a.mask, binat.af)) {
yyerror("'binat' source mask and "
"redirect mask must be the same");
YYERROR;
@@ -2392,19 +2396,23 @@ rdrrule : no RDR interface af proto FROM ipspec TO ipspec dport
rdr.af = $4;
if ($7 != NULL) {
- memcpy(&rdr.src.addr.addr, &$7->addr.addr,
- sizeof(rdr.src.addr.addr));
- memcpy(&rdr.src.addr.mask, &$7->addr.mask,
- sizeof(rdr.src.addr.mask));
+ memcpy(&rdr.src.addr.v.a.addr,
+ &$7->addr.v.a.addr,
+ sizeof(rdr.src.addr.v.a.addr));
+ memcpy(&rdr.src.addr.v.a.mask,
+ &$7->addr.v.a.mask,
+ sizeof(rdr.src.addr.v.a.mask));
rdr.src.not = $7->not;
if (!rdr.af && !$7->ifindex)
rdr.af = $7->af;
}
if ($9 != NULL) {
- memcpy(&rdr.dst.addr.addr, &$9->addr.addr,
- sizeof(rdr.dst.addr.addr));
- memcpy(&rdr.dst.addr.mask, &$9->addr.mask,
- sizeof(rdr.dst.addr.mask));
+ memcpy(&rdr.dst.addr.v.a.addr,
+ &$9->addr.v.a.addr,
+ sizeof(rdr.dst.addr.v.a.addr));
+ memcpy(&rdr.dst.addr.v.a.mask,
+ &$9->addr.v.a.mask,
+ sizeof(rdr.dst.addr.v.a.mask));
rdr.dst.not = $9->not;
if (!rdr.af && !$9->ifindex)
rdr.af = $9->af;
@@ -2453,10 +2461,10 @@ rdrrule : no RDR interface af proto FROM ipspec TO ipspec dport
}
} else {
if ((rdr.af == AF_INET &&
- unmask(&$11->host->addr.mask,
+ unmask(&$11->host->addr.v.a.mask,
rdr.af) == 32) ||
(rdr.af == AF_INET6 &&
- unmask(&$11->host->addr.mask,
+ unmask(&$11->host->addr.v.a.mask,
rdr.af) == 128)) {
rdr.rpool.opts = PF_POOL_NONE;
} else {
@@ -2668,8 +2676,8 @@ rule_consistent(struct pf_rule *r)
yyerror("allow-opts can only be specified for pass rules");
problems++;
}
- if (!r->af && (r->src.addr.addr_dyn != NULL ||
- r->dst.addr.addr_dyn != NULL)) {
+ if (!r->af && (r->src.addr.type == PF_ADDR_DYNIFTL ||
+ r->dst.addr.type == PF_ADDR_DYNIFTL)) {
yyerror("dynamic addresses require address family "
"(inet/inet6)");
problems++;
@@ -2698,7 +2706,7 @@ nat_consistent(struct pf_rule *r)
if (!r->af) {
TAILQ_FOREACH(pa, &r->rpool.list, entries) {
- if (pa->addr.addr.addr_dyn != NULL) {
+ if (pa->addr.addr.type == PF_ADDR_DYNIFTL) {
yyerror("dynamic addresses require "
"address family (inet/inet6)");
problems++;
@@ -2721,14 +2729,14 @@ rdr_consistent(struct pf_rule *r)
problems++;
}
if (!r->af) {
- if (r->src.addr.addr_dyn != NULL ||
- r->dst.addr.addr_dyn != NULL) {
+ if (r->src.addr.type == PF_ADDR_DYNIFTL ||
+ r->dst.addr.type == PF_ADDR_DYNIFTL) {
yyerror("dynamic addresses require address family "
"(inet/inet6)");
problems++;
} else {
TAILQ_FOREACH(pa, &r->rpool.list, entries) {
- if (pa->addr.addr.addr_dyn != NULL) {
+ if (pa->addr.addr.type == PF_ADDR_DYNIFTL) {
yyerror("dynamic addresses require "
"address family (inet/inet6)");
problems++;
@@ -2807,23 +2815,23 @@ expand_label_addr(const char *name, char *label, sa_family_t af,
if (h->not)
strlcat(tmp, "! ", PF_RULE_LABEL_SIZE);
- if (h->addr.addr_dyn != NULL) {
+ if (h->addr.type == PF_ADDR_DYNIFTL) {
strlcat(tmp, "(", PF_RULE_LABEL_SIZE);
- strlcat(tmp, h->addr.addr.pfa.ifname,
+ strlcat(tmp, h->addr.v.ifname,
PF_RULE_LABEL_SIZE);
strlcat(tmp, ")", PF_RULE_LABEL_SIZE);
- } else if (!af || (PF_AZERO(&h->addr.addr, af) &&
- PF_AZERO(&h->addr.mask, af)))
+ } else if (!af || (PF_AZERO(&h->addr.v.a.addr, af) &&
+ PF_AZERO(&h->addr.v.a.mask, af)))
strlcat(tmp, "any", PF_RULE_LABEL_SIZE);
else {
char a[48];
int bits;
- if (inet_ntop(af, &h->addr.addr, a,
+ if (inet_ntop(af, &h->addr.v.a.addr, a,
sizeof(a)) == NULL)
strlcat(a, "?", sizeof(a));
strlcat(tmp, a, PF_RULE_LABEL_SIZE);
- bits = unmask(&h->addr.mask, af);
+ bits = unmask(&h->addr.v.a.mask, af);
a[0] = 0;
if ((af == AF_INET && bits < 32) ||
(af == AF_INET6 && bits < 128))
@@ -3784,7 +3792,7 @@ set_ipmask(struct node_host *h, u_int8_t b)
struct pf_addr *m, *n;
int i, j = 0;
- m = &h->addr.mask;
+ m = &h->addr.v.a.mask;
for (i = 0; i < 4; i++)
m->addr32[i] = 0;
@@ -3799,7 +3807,7 @@ set_ipmask(struct node_host *h, u_int8_t b)
m->addr32[j] = htonl(m->addr32[j]);
/* Mask off bits of the address that will never be used. */
- n = &h->addr.addr;
+ n = &h->addr.v.a.addr;
for (i = 0; i < 4; i++)
n->addr32[i] = n->addr32[i] & m->addr32[i];
}
@@ -3868,7 +3876,6 @@ ifa_load(void)
if (n == NULL)
err(1, "address: calloc");
n->af = ifa->ifa_addr->sa_family;
- n->addr.addr_dyn = NULL;
n->ifa_flags = ifa->ifa_flags;
#ifdef __KAME__
if (n->af == AF_INET6 &&
@@ -3886,10 +3893,10 @@ ifa_load(void)
#endif
n->ifindex = 0;
if (n->af == AF_INET) {
- memcpy(&n->addr.addr, &((struct sockaddr_in *)
+ memcpy(&n->addr.v.a.addr, &((struct sockaddr_in *)
ifa->ifa_addr)->sin_addr.s_addr,
sizeof(struct in_addr));
- memcpy(&n->addr.mask, &((struct sockaddr_in *)
+ memcpy(&n->addr.v.a.mask, &((struct sockaddr_in *)
ifa->ifa_netmask)->sin_addr.s_addr,
sizeof(struct in_addr));
if (ifa->ifa_broadaddr != NULL)
@@ -3897,10 +3904,10 @@ ifa_load(void)
ifa->ifa_broadaddr)->sin_addr.s_addr,
sizeof(struct in_addr));
} else if (n->af == AF_INET6) {
- memcpy(&n->addr.addr, &((struct sockaddr_in6 *)
+ memcpy(&n->addr.v.a.addr, &((struct sockaddr_in6 *)
ifa->ifa_addr)->sin6_addr.s6_addr,
sizeof(struct in6_addr));
- memcpy(&n->addr.mask, &((struct sockaddr_in6 *)
+ memcpy(&n->addr.v.a.mask, &((struct sockaddr_in6 *)
ifa->ifa_netmask)->sin6_addr.s6_addr,
sizeof(struct in6_addr));
if (ifa->ifa_broadaddr != NULL)
@@ -3966,20 +3973,20 @@ ifa_lookup(char *ifa_name, enum pfctl_iflookup_mode mode)
if (n == NULL)
err(1, "address: calloc");
n->af = p->af;
- n->addr.addr_dyn = NULL;
- if (mode == PFCTL_IFLOOKUP_BCAST) {
- memcpy(&n->addr.addr, &p->bcast,
- sizeof(struct pf_addr));
- } else
- memcpy(&n->addr.addr, &p->addr.addr,
+ if (mode == PFCTL_IFLOOKUP_BCAST)
+ memcpy(&n->addr.v.a.addr, &p->bcast,
+ sizeof(struct pf_addr));
+ else
+ memcpy(&n->addr.v.a.addr, &p->addr.v.a.addr,
sizeof(struct pf_addr));
if (mode == PFCTL_IFLOOKUP_NET)
- set_ipmask(n, unmask(&p->addr.mask, n->af));
+ set_ipmask(n, unmask(&p->addr.v.a.mask, n->af));
else {
if (n->af == AF_INET) {
if (p->ifa_flags & IFF_LOOPBACK &&
p->ifa_flags & IFF_LINK1)
- memcpy(&n->addr.mask, &p->addr.mask,
+ memcpy(&n->addr.v.a.mask,
+ &p->addr.v.a.mask,
sizeof(struct pf_addr));
else
set_ipmask(n, 32);
@@ -4098,8 +4105,7 @@ host(char *s, int mask)
err(1, "address: calloc");
h->ifname = NULL;
h->af = AF_INET;
- h->addr.addr_dyn = NULL;
- h->addr.addr.addr32[0] = ina.s_addr;
+ h->addr.v.a.addr.addr32[0] = ina.s_addr;
set_ipmask(h, bits);
h->next = NULL;
h->tail = h;
@@ -4118,10 +4124,9 @@ host(char *s, int mask)
err(1, "address: calloc");
n->ifname = NULL;
n->af = AF_INET6;
- n->addr.addr_dyn = NULL;
- memcpy(&n->addr.addr,
+ memcpy(&n->addr.v.a.addr,
&((struct sockaddr_in6 *)res->ai_addr)->sin6_addr,
- sizeof(n->addr.addr));
+ sizeof(n->addr.v.a.addr));
n->ifindex = ((struct sockaddr_in6 *)res->ai_addr)->sin6_scope_id;
set_ipmask(n, v6mask);
freeaddrinfo(res);
@@ -4148,14 +4153,13 @@ host(char *s, int mask)
err(1, "address: calloc");
n->ifname = NULL;
n->af = res->ai_family;
- n->addr.addr_dyn = NULL;
if (res->ai_family == AF_INET) {
- memcpy(&n->addr.addr,
+ memcpy(&n->addr.v.a.addr,
&((struct sockaddr_in *)res->ai_addr)->sin_addr.s_addr,
sizeof(struct in_addr));
set_ipmask(n, v4mask);
} else {
- memcpy(&n->addr.addr,
+ memcpy(&n->addr.v.a.addr,
&((struct sockaddr_in6 *)res->ai_addr)->sin6_addr.s6_addr,
sizeof(struct in6_addr));
n->ifindex =
diff --git a/sbin/pfctl/pf_print_state.c b/sbin/pfctl/pf_print_state.c
index dabece9756d..bafcc1166b5 100644
--- a/sbin/pfctl/pf_print_state.c
+++ b/sbin/pfctl/pf_print_state.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pf_print_state.c,v 1.16 2003/01/04 00:01:34 deraadt Exp $ */
+/* $OpenBSD: pf_print_state.c,v 1.17 2003/01/05 22:14:23 dhartmei Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -62,25 +62,25 @@ print_addr(struct pf_addr_wrap *addr, sa_family_t af)
{
char buf[48];
- if (addr->mask.addr32[0] == PF_TABLE_MASK) {
+ if (addr->v.a.mask.addr32[0] == PF_TABLE_MASK) {
struct pfr_table tbl = { "?" };
if (pfr_unwrap_table(&tbl, addr, 0))
- printf("<0x%08X>", addr->addr.addr32[0]);
+ printf("<0x%08X>", addr->v.a.addr.addr32[0]);
else
printf("<%s>", tbl.pfrt_name);
return;
}
- if (addr->addr_dyn != NULL)
- printf("(%s)", addr->addr.pfa.ifname);
+ if (addr->type == PF_ADDR_DYNIFTL)
+ printf("(%s)", addr->v.ifname);
else {
- if (inet_ntop(af, &addr->addr, buf, sizeof(buf)) == NULL)
+ if (inet_ntop(af, &addr->v.a.addr, buf, sizeof(buf)) == NULL)
printf("?");
else
printf("%s", buf);
}
- if (! PF_AZERO(&addr->mask, af)) {
- int bits = unmask(&addr->mask, af);
+ if (! PF_AZERO(&addr->v.a.mask, af)) {
+ int bits = unmask(&addr->v.a.mask, af);
if (bits != (af == AF_INET ? 32 : 128))
printf("/%d", bits);
@@ -130,9 +130,9 @@ print_host(struct pf_state_host *h, sa_family_t af, int opts)
else {
struct pf_addr_wrap aw;
- aw.addr = h->addr;
- memset(&aw.mask, 0xff, sizeof(aw.mask));
- aw.addr_dyn = NULL;
+ memset(&aw, 0, sizeof(aw));
+ aw.v.a.addr = h->addr;
+ memset(&aw.v.a.mask, 0xff, sizeof(aw.v.a.mask));
print_addr(&aw, af);
}
diff --git a/sbin/pfctl/pfctl.c b/sbin/pfctl/pfctl.c
index 147359db81d..924737b25e8 100644
--- a/sbin/pfctl/pfctl.c
+++ b/sbin/pfctl/pfctl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pfctl.c,v 1.122 2003/01/04 00:01:34 deraadt Exp $ */
+/* $OpenBSD: pfctl.c,v 1.123 2003/01/05 22:14:23 dhartmei Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -326,7 +326,8 @@ pfctl_kill_states(int dev, int opts)
killed = sources = dests = 0;
memset(&psk, 0, sizeof(psk));
- memset(&psk.psk_src.addr.mask, 0xff, sizeof(psk.psk_src.addr.mask));
+ memset(&psk.psk_src.addr.v.a.mask, 0xff,
+ sizeof(psk.psk_src.addr.v.a.mask));
memset(&last_src, 0xff, sizeof(last_src));
memset(&last_dst, 0xff, sizeof(last_dst));
@@ -346,10 +347,10 @@ pfctl_kill_states(int dev, int opts)
sources++;
if (psk.psk_af == AF_INET)
- psk.psk_src.addr.addr.v4 =
+ psk.psk_src.addr.v.a.addr.v4 =
((struct sockaddr_in *)resp[0]->ai_addr)->sin_addr;
else if (psk.psk_af == AF_INET6)
- psk.psk_src.addr.addr.v6 =
+ psk.psk_src.addr.v.a.addr.v6 =
((struct sockaddr_in6 *)resp[0]->ai_addr)->
sin6_addr;
else
@@ -357,8 +358,8 @@ pfctl_kill_states(int dev, int opts)
if (state_killers > 1) {
dests = 0;
- memset(&psk.psk_dst.addr.mask, 0xff,
- sizeof(psk.psk_dst.addr.mask));
+ memset(&psk.psk_dst.addr.v.a.mask, 0xff,
+ sizeof(psk.psk_dst.addr.v.a.mask));
memset(&last_dst, 0xff, sizeof(last_dst));
if ((ret_ga = getaddrinfo(state_kill[1], NULL, NULL,
&res[1]))) {
@@ -380,11 +381,11 @@ pfctl_kill_states(int dev, int opts)
dests++;
if (psk.psk_af == AF_INET)
- psk.psk_dst.addr.addr.v4 =
+ psk.psk_dst.addr.v.a.addr.v4 =
((struct sockaddr_in *)resp[1]->
ai_addr)->sin_addr;
else if (psk.psk_af == AF_INET6)
- psk.psk_dst.addr.addr.v6 =
+ psk.psk_dst.addr.v.a.addr.v6 =
((struct sockaddr_in6 *)resp[1]->
ai_addr)->sin6_addr;
else
diff --git a/sbin/pfctl/pfctl_parser.c b/sbin/pfctl/pfctl_parser.c
index f85c3c06255..ad0d6774e86 100644
--- a/sbin/pfctl/pfctl_parser.c
+++ b/sbin/pfctl/pfctl_parser.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pfctl_parser.c,v 1.126 2003/01/04 17:40:51 dhartmei Exp $ */
+/* $OpenBSD: pfctl_parser.c,v 1.127 2003/01/05 22:14:23 dhartmei Exp $ */
/*
* Copyright (c) 2001 Daniel Hartmeier
@@ -354,17 +354,17 @@ print_fromto(struct pf_rule_addr *src, struct pf_rule_addr *dst,
{
if (src->addr.type != PF_ADDR_NOROUTE &&
dst->addr.type != PF_ADDR_NOROUTE &&
- PF_AZERO(&src->addr.addr, AF_INET6) &&
- PF_AZERO(&src->addr.mask, AF_INET6) &&
- !src->port_op && PF_AZERO(&dst->addr.addr, AF_INET6) &&
- PF_AZERO(&dst->addr.mask, AF_INET6) && !dst->port_op)
+ PF_AZERO(&src->addr.v.a.addr, AF_INET6) &&
+ PF_AZERO(&src->addr.v.a.mask, AF_INET6) &&
+ !src->port_op && PF_AZERO(&dst->addr.v.a.addr, AF_INET6) &&
+ PF_AZERO(&dst->addr.v.a.mask, AF_INET6) && !dst->port_op)
printf("all ");
else {
printf("from ");
if (src->addr.type == PF_ADDR_NOROUTE)
printf("no-route ");
- else if (PF_AZERO(&src->addr.addr, AF_INET6) &&
- PF_AZERO(&src->addr.mask, AF_INET6))
+ else if (PF_AZERO(&src->addr.v.a.addr, AF_INET6) &&
+ PF_AZERO(&src->addr.v.a.mask, AF_INET6))
printf("any ");
else {
if (src->not)
@@ -380,8 +380,8 @@ print_fromto(struct pf_rule_addr *src, struct pf_rule_addr *dst,
printf("to ");
if (dst->addr.type == PF_ADDR_NOROUTE)
printf("no-route ");
- else if (PF_AZERO(&dst->addr.addr, AF_INET6) &&
- PF_AZERO(&dst->addr.mask, AF_INET6))
+ else if (PF_AZERO(&dst->addr.v.a.addr, AF_INET6) &&
+ PF_AZERO(&dst->addr.v.a.mask, AF_INET6))
printf("any ");
else {
if (dst->not)
@@ -438,7 +438,7 @@ print_pool(struct pf_pool *pool, u_int16_t p1, u_int16_t p2,
print_addr(&pooladdr->addr.addr, af);
break;
case PF_PASS:
- if (PF_AZERO(&pooladdr->addr.addr.addr, af))
+ if (PF_AZERO(&pooladdr->addr.addr.v.a.addr, af))
printf("%s", pooladdr->ifname);
else {
printf("(%s ", pooladdr->ifname);
@@ -568,15 +568,15 @@ print_binat(struct pf_rule *b, int verbose)
printf("proto %u ", b->proto);
}
printf("from ");
- if (!PF_AZERO(&b->src.addr.addr, b->af) ||
- !PF_AZERO(&b->src.addr.mask, b->af)) {
+ if (!PF_AZERO(&b->src.addr.v.a.addr, b->af) ||
+ !PF_AZERO(&b->src.addr.v.a.mask, b->af)) {
print_addr(&b->src.addr, b->af);
printf(" ");
} else
printf("any ");
printf("to ");
- if (!PF_AZERO(&b->dst.addr.addr, b->af) ||
- !PF_AZERO(&b->dst.addr.mask, b->af)) {
+ if (!PF_AZERO(&b->dst.addr.v.a.addr, b->af) ||
+ !PF_AZERO(&b->dst.addr.v.a.mask, b->af)) {
if (b->dst.not)
printf("! ");
print_addr(&b->dst.addr, b->af);
@@ -623,8 +623,8 @@ print_rdr(struct pf_rule *r, int verbose)
printf("proto %u ", r->proto);
}
printf("from ");
- if (!PF_AZERO(&r->src.addr.addr, r->af) ||
- !PF_AZERO(&r->src.addr.mask, r->af)) {
+ if (!PF_AZERO(&r->src.addr.v.a.addr, r->af) ||
+ !PF_AZERO(&r->src.addr.v.a.mask, r->af)) {
if (r->src.not)
printf("! ");
print_addr(&r->src.addr, r->af);
@@ -632,8 +632,8 @@ print_rdr(struct pf_rule *r, int verbose)
} else
printf("any ");
printf("to ");
- if (!PF_AZERO(&r->dst.addr.addr, r->af) ||
- !PF_AZERO(&r->dst.addr.mask, r->af)) {
+ if (!PF_AZERO(&r->dst.addr.v.a.addr, r->af) ||
+ !PF_AZERO(&r->dst.addr.v.a.mask, r->af)) {
if (r->dst.not)
printf("! ");
print_addr(&r->dst.addr, r->af);