diff options
Diffstat (limited to 'sys/netpfil')
| -rw-r--r-- | sys/netpfil/ipfilter/netinet/ip_htable.c | 2 | ||||
| -rw-r--r-- | sys/netpfil/ipfilter/netinet/ip_nat.c | 1 | ||||
| -rw-r--r-- | sys/netpfil/ipfw/ip_dummynet.c | 4 | ||||
| -rw-r--r-- | sys/netpfil/pf/pf.c | 1 | ||||
| -rw-r--r-- | sys/netpfil/pf/pf_lb.c | 1 | 
5 files changed, 7 insertions, 2 deletions
| diff --git a/sys/netpfil/ipfilter/netinet/ip_htable.c b/sys/netpfil/ipfilter/netinet/ip_htable.c index 91b375f80db1..3f765cfab947 100644 --- a/sys/netpfil/ipfilter/netinet/ip_htable.c +++ b/sys/netpfil/ipfilter/netinet/ip_htable.c @@ -230,6 +230,8 @@ ipf_htable_stats_get(ipf_main_softc_t *softc, void *arg, iplookupop_t *op)  		return (EINVAL);  	} +	bzero(&stats, sizeof(stats)); +  	stats.iphs_tables = softh->ipf_htables[op->iplo_unit + 1];  	stats.iphs_numtables = softh->ipf_nhtables[op->iplo_unit + 1];  	stats.iphs_numnodes = softh->ipf_nhtnodes[op->iplo_unit + 1]; diff --git a/sys/netpfil/ipfilter/netinet/ip_nat.c b/sys/netpfil/ipfilter/netinet/ip_nat.c index 972511f43bd5..53c180cdfbca 100644 --- a/sys/netpfil/ipfilter/netinet/ip_nat.c +++ b/sys/netpfil/ipfilter/netinet/ip_nat.c @@ -1771,6 +1771,7 @@ ipf_nat_getent(ipf_main_softc_t *softc, caddr_t data, int getlock)  		IPFERROR(60029);  		return (ENOMEM);  	} +	bzero(ipn, ipns.ipn_dsize);  	if (getlock) {  		READ_ENTER(&softc->ipf_nat); diff --git a/sys/netpfil/ipfw/ip_dummynet.c b/sys/netpfil/ipfw/ip_dummynet.c index b3f52322425f..d522f9da0fbe 100644 --- a/sys/netpfil/ipfw/ip_dummynet.c +++ b/sys/netpfil/ipfw/ip_dummynet.c @@ -1150,7 +1150,7 @@ copy_data_helper(void *_o, void *_arg)  		    return 0;	/* not a pipe */  		/* see if the object is within one of our ranges */ -		for (;r < lim; r += 2) { +		for (; r < lim; r += 2) {  			if (n < r[0] || n > r[1])  				continue;  			/* Found a valid entry, copy and we are done */ @@ -1183,7 +1183,7 @@ copy_data_helper(void *_o, void *_arg)  		if (n >= DN_MAX_ID)  			return 0;  		/* see if the object is within one of our ranges */ -		for (;r < lim; r += 2) { +		for (; r < lim; r += 2) {  			if (n < r[0] || n > r[1])  				continue;  			if (copy_flowset(a, fs, 0)) diff --git a/sys/netpfil/pf/pf.c b/sys/netpfil/pf/pf.c index d6fc24a23fe9..fd70fb1c8a36 100644 --- a/sys/netpfil/pf/pf.c +++ b/sys/netpfil/pf/pf.c @@ -5965,6 +5965,7 @@ pf_test_rule(struct pf_krule **rm, struct pf_kstate **sm,  		ctx.nat_pool = &(ctx.nr->rdr);  	} +	*ctx.rm = &V_pf_default_rule;  	if (ctx.nr && ctx.nr->natpass) {  		r = ctx.nr;  		ruleset = *ctx.rsm; diff --git a/sys/netpfil/pf/pf_lb.c b/sys/netpfil/pf/pf_lb.c index fb1b121d0bc0..5d85e16f18e3 100644 --- a/sys/netpfil/pf/pf_lb.c +++ b/sys/netpfil/pf/pf_lb.c @@ -216,6 +216,7 @@ pf_match_translation_rule(int rs_num, struct pf_test_ctx *ctx, struct pf_krulese  				 */  				ctx->arsm = ctx->aruleset;  			} +			break;  		} else {  			ctx->a = r;			/* remember anchor */  			ctx->aruleset = ruleset;	/* and its ruleset */ | 
