Minor change to the macros to make sure that if an AF is passed that is neither AF_INET6 nor AF_INET that we don't touch random bits of memory.
Differential Revision: https://reviews.freebsd.org/D2291
This commit is contained in:
parent
731b28fb31
commit
6332e4cc38
@ -192,21 +192,20 @@ extern struct rwlock pf_rules_lock;
|
||||
|
||||
#define PF_AEQ(a, b, c) \
|
||||
((c == AF_INET && (a)->addr32[0] == (b)->addr32[0]) || \
|
||||
((a)->addr32[3] == (b)->addr32[3] && \
|
||||
(c == AF_INET6 && (a)->addr32[3] == (b)->addr32[3] && \
|
||||
(a)->addr32[2] == (b)->addr32[2] && \
|
||||
(a)->addr32[1] == (b)->addr32[1] && \
|
||||
(a)->addr32[0] == (b)->addr32[0])) \
|
||||
|
||||
#define PF_ANEQ(a, b, c) \
|
||||
((c == AF_INET && (a)->addr32[0] != (b)->addr32[0]) || \
|
||||
((a)->addr32[3] != (b)->addr32[3] || \
|
||||
(a)->addr32[2] != (b)->addr32[2] || \
|
||||
((a)->addr32[0] != (b)->addr32[0] || \
|
||||
(a)->addr32[1] != (b)->addr32[1] || \
|
||||
(a)->addr32[0] != (b)->addr32[0])) \
|
||||
(a)->addr32[2] != (b)->addr32[2] || \
|
||||
(a)->addr32[3] != (b)->addr32[3]) \
|
||||
|
||||
#define PF_AZERO(a, c) \
|
||||
((c == AF_INET && !(a)->addr32[0]) || \
|
||||
(!(a)->addr32[0] && !(a)->addr32[1] && \
|
||||
(c == AF_INET6 && !(a)->addr32[0] && !(a)->addr32[1] && \
|
||||
!(a)->addr32[2] && !(a)->addr32[3] )) \
|
||||
|
||||
#define PF_MATCHA(n, a, m, b, f) \
|
||||
|
Loading…
Reference in New Issue
Block a user