Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/net/npf Fix locking issue: npf_default_pass needs to be ...
details: https://anonhg.NetBSD.org/src/rev/3c215382322b
branches: trunk
changeset: 1018200:3c215382322b
user: christos <christos%NetBSD.org@localhost>
date: Mon Jan 25 17:17:19 2021 +0000
description:
Fix locking issue: npf_default_pass needs to be called with the config lock
held.
diffstat:
sys/net/npf/npf_os.c | 12 ++++++++++--
1 files changed, 10 insertions(+), 2 deletions(-)
diffs (30 lines):
diff -r e0bc5594920b -r 3c215382322b sys/net/npf/npf_os.c
--- a/sys/net/npf/npf_os.c Mon Jan 25 16:21:41 2021 +0000
+++ b/sys/net/npf/npf_os.c Mon Jan 25 17:17:19 2021 +0000
@@ -33,7 +33,7 @@
#ifdef _KERNEL
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: npf_os.c,v 1.19 2020/08/18 07:53:24 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: npf_os.c,v 1.20 2021/01/25 17:17:19 christos Exp $");
#ifdef _KERNEL_OPT
#include "pf.h"
@@ -321,8 +321,16 @@
bool
npf_autounload_p(void)
{
+ if (npf_active_p())
+ return false;
+
npf_t *npf = npf_getkernctx();
- return !npf_active_p() && npf_default_pass(npf);
+
+ npf_config_enter(npf);
+ bool pass = npf_default_pass(npf);
+ npf_config_exit(npf);
+
+ return pass;
}
/*
Home |
Main Index |
Thread Index |
Old Index