git: 32271c4d383e - main - pf: clean up syncookie callout on vnet shutdown
Kristof Provost
kp at FreeBSD.org
Tue Jul 20 19:18:43 UTC 2021
The branch main has been updated by kp:
URL: https://cgit.FreeBSD.org/src/commit/?id=32271c4d383effeac7878201ef5cbdfaeedc3755
commit 32271c4d383effeac7878201ef5cbdfaeedc3755
Author: Kristof Provost <kp at FreeBSD.org>
AuthorDate: 2021-07-20 19:03:08 +0000
Commit: Kristof Provost <kp at FreeBSD.org>
CommitDate: 2021-07-20 19:13:25 +0000
pf: clean up syncookie callout on vnet shutdown
Ensure that we cancel any outstanding callouts for syncookies when we
terminate the vnet.
MFC after: 1 week
Sponsored by: Modirum MDPay
---
sys/net/pfvar.h | 1 +
sys/netpfil/pf/pf_ioctl.c | 1 +
sys/netpfil/pf/pf_syncookies.c | 6 ++++++
3 files changed, 8 insertions(+)
diff --git a/sys/net/pfvar.h b/sys/net/pfvar.h
index 70fde0aa7380..1dfc769b197d 100644
--- a/sys/net/pfvar.h
+++ b/sys/net/pfvar.h
@@ -1852,6 +1852,7 @@ void pf_send_tcp(const struct pf_krule *, sa_family_t,
u_int16_t);
void pf_syncookies_init(void);
+void pf_syncookies_cleanup(void);
int pf_get_syncookies(struct pfioc_nv *);
int pf_set_syncookies(struct pfioc_nv *);
int pf_synflood_check(struct pf_pdesc *);
diff --git a/sys/netpfil/pf/pf_ioctl.c b/sys/netpfil/pf/pf_ioctl.c
index a9f5b2c18041..27e1a145f3ec 100644
--- a/sys/netpfil/pf/pf_ioctl.c
+++ b/sys/netpfil/pf/pf_ioctl.c
@@ -5573,6 +5573,7 @@ pf_unload_vnet(void)
dehook_pf();
PF_RULES_WLOCK();
+ pf_syncookies_cleanup();
shutdown_pf();
PF_RULES_WUNLOCK();
diff --git a/sys/netpfil/pf/pf_syncookies.c b/sys/netpfil/pf/pf_syncookies.c
index 0313b817ad6d..8699ae855ec8 100644
--- a/sys/netpfil/pf/pf_syncookies.c
+++ b/sys/netpfil/pf/pf_syncookies.c
@@ -127,6 +127,12 @@ pf_syncookies_init(void)
PF_RULES_WUNLOCK();
}
+void
+pf_syncookies_cleanup(void)
+{
+ callout_stop(&V_pf_syncookie_status.keytimeout);
+}
+
int
pf_get_syncookies(struct pfioc_nv *nv)
{
More information about the dev-commits-src-main
mailing list