diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2022-12-24 05:20:33 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2022-12-24 05:20:33 +0000 |
commit | 3f6dae067c1ad76e20904883d299500b16e65074 (patch) | |
tree | 9f5b7bee3b4d5bae01fd87ff816220506b69d82c /sys | |
parent | b18a297464b18b8640090d84c05f1512adfba199 (diff) |
fix and enable toeplitz hashing of pf_state_keys again.
the hash generated when setting up the pf pdesc struct uses outer
addresses, while the addresses used in the state table goes through
pf_state_key_addr_setup(), which does interesting things with some
ipv6 icmp values. state lookups used pf_state_key_addr_setup(), but
pf_state_key_setup copied the pdesc value, causing an inconsistency.
pf_state_key_setup now calls pf_state_key_addr_setup().
found by anton@
tested by anton@ florian@
Diffstat (limited to 'sys')
-rw-r--r-- | sys/net/pf.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/sys/net/pf.c b/sys/net/pf.c index 96fbbe22526..1ee69b734e7 100644 --- a/sys/net/pf.c +++ b/sys/net/pf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pf.c,v 1.1162 2022/12/23 07:14:55 dlg Exp $ */ +/* $OpenBSD: pf.c,v 1.1163 2022/12/24 05:20:32 dlg Exp $ */ /* * Copyright (c) 2001 Daniel Hartmeier @@ -694,10 +694,8 @@ pf_state_compare_key(struct pf_state_key *a, struct pf_state_key *b) { int diff; -#if 0 if ((diff = a->hash - b->hash) != 0) return (diff); -#endif if ((diff = a->proto - b->proto) != 0) return (diff); if ((diff = a->af - b->af) != 0) @@ -952,7 +950,8 @@ pf_state_key_setup(struct pf_pdesc *pd, struct pf_state_key **skw, sk1->proto = pd->proto; sk1->af = pd->af; sk1->rdomain = pd->rdomain; - sk1->hash = pd->hash; + sk1->hash = pf_pkt_hash(sk1->af, sk1->proto, + &sk1->addr[0], &sk1->addr[1], sk1->port[0], sk1->port[1]); if (rtableid >= 0) wrdom = rtable_l2(rtableid); @@ -5327,8 +5326,8 @@ pf_icmp_state_lookup(struct pf_pdesc *pd, struct pf_state_key_cmp *key, pd->dst, pd->af, multi)) return (PF_DROP); - key->hash = pf_pkt_hash(pd->af, pd->proto, - pd->src, pd->dst, 0, 0); + key->hash = pf_pkt_hash(key->af, key->proto, + &key->addr[0], &key->addr[1], 0, 0); action = pf_find_state(pd, key, state); if (action != PF_MATCH) |