Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/net/npf - npf_mk_rules: enforce unique names for the dyn...



details:   https://anonhg.NetBSD.org/src/rev/c41f72f0a628
branches:  trunk
changeset: 358061:c41f72f0a628
user:      rmind <rmind%NetBSD.org@localhost>
date:      Sun Dec 10 01:18:21 2017 +0000

description:
- npf_mk_rules: enforce unique names for the dynamic rulesets.
- npf_worker_unregister: merge fix for the standalone NPF.

diffstat:

 sys/net/npf/npf_ctl.c     |  12 +++++++++---
 sys/net/npf/npf_impl.h    |   3 ++-
 sys/net/npf/npf_ruleset.c |   6 +++---
 sys/net/npf/npf_worker.c  |   9 ++++++---
 4 files changed, 20 insertions(+), 10 deletions(-)

diffs (114 lines):

diff -r 9fb5a00842d1 -r c41f72f0a628 sys/net/npf/npf_ctl.c
--- a/sys/net/npf/npf_ctl.c     Sun Dec 10 00:43:05 2017 +0000
+++ b/sys/net/npf/npf_ctl.c     Sun Dec 10 01:18:21 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: npf_ctl.c,v 1.49 2017/10/30 03:02:35 ozaki-r Exp $     */
+/*     $NetBSD: npf_ctl.c,v 1.50 2017/12/10 01:18:21 rmind Exp $       */
 
 /*-
  * Copyright (c) 2009-2014 The NetBSD Foundation, Inc.
@@ -38,7 +38,7 @@
 
 #ifdef _KERNEL
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: npf_ctl.c,v 1.49 2017/10/30 03:02:35 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: npf_ctl.c,v 1.50 2017/12/10 01:18:21 rmind Exp $");
 
 #include <sys/param.h>
 #include <sys/conf.h>
@@ -371,12 +371,18 @@
        it = prop_array_iterator(rules);
        while ((rldict = prop_object_iterator_next(it)) != NULL) {
                npf_rule_t *rl = NULL;
+               const char *name;
 
-               /* Generate a single rule. */
                error = npf_mk_singlerule(npf, rldict, rpset, &rl, errdict);
                if (error) {
                        break;
                }
+               if (prop_dictionary_get_cstring_nocopy(rldict, "name", &name) &&
+                   npf_ruleset_lookup(rlset, name) != NULL) {
+                       NPF_ERR_DEBUG(errdict);
+                       npf_rule_free(rl);
+                       return EEXIST;
+               }
                npf_ruleset_insert(rlset, rl);
        }
        prop_object_iterator_release(it);
diff -r 9fb5a00842d1 -r c41f72f0a628 sys/net/npf/npf_impl.h
--- a/sys/net/npf/npf_impl.h    Sun Dec 10 00:43:05 2017 +0000
+++ b/sys/net/npf/npf_impl.h    Sun Dec 10 01:18:21 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: npf_impl.h,v 1.69 2017/02/19 02:11:19 christos Exp $   */
+/*     $NetBSD: npf_impl.h,v 1.70 2017/12/10 01:18:21 rmind Exp $      */
 
 /*-
  * Copyright (c) 2009-2014 The NetBSD Foundation, Inc.
@@ -330,6 +330,7 @@
 void           npf_ruleset_freealg(npf_ruleset_t *, npf_alg_t *);
 int            npf_ruleset_export(npf_t *, const npf_ruleset_t *, prop_array_t);
 
+npf_rule_t *   npf_ruleset_lookup(npf_ruleset_t *, const char *);
 int            npf_ruleset_add(npf_ruleset_t *, const char *, npf_rule_t *);
 int            npf_ruleset_remove(npf_ruleset_t *, const char *, uint64_t);
 int            npf_ruleset_remkey(npf_ruleset_t *, const char *,
diff -r 9fb5a00842d1 -r c41f72f0a628 sys/net/npf/npf_ruleset.c
--- a/sys/net/npf/npf_ruleset.c Sun Dec 10 00:43:05 2017 +0000
+++ b/sys/net/npf/npf_ruleset.c Sun Dec 10 01:18:21 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: npf_ruleset.c,v 1.45 2017/01/29 00:15:54 christos Exp $        */
+/*     $NetBSD: npf_ruleset.c,v 1.46 2017/12/10 01:18:21 rmind Exp $   */
 
 /*-
  * Copyright (c) 2009-2015 The NetBSD Foundation, Inc.
@@ -35,7 +35,7 @@
 
 #ifdef _KERNEL
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: npf_ruleset.c,v 1.45 2017/01/29 00:15:54 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: npf_ruleset.c,v 1.46 2017/12/10 01:18:21 rmind Exp $");
 
 #include <sys/param.h>
 #include <sys/types.h>
@@ -208,7 +208,7 @@
        }
 }
 
-static npf_rule_t *
+npf_rule_t *
 npf_ruleset_lookup(npf_ruleset_t *rlset, const char *name)
 {
        npf_rule_t *rl;
diff -r 9fb5a00842d1 -r c41f72f0a628 sys/net/npf/npf_worker.c
--- a/sys/net/npf/npf_worker.c  Sun Dec 10 00:43:05 2017 +0000
+++ b/sys/net/npf/npf_worker.c  Sun Dec 10 01:18:21 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: npf_worker.c,v 1.3 2017/01/02 21:49:51 rmind Exp $     */
+/*     $NetBSD: npf_worker.c,v 1.4 2017/12/10 01:18:21 rmind Exp $     */
 
 /*-
  * Copyright (c) 2010-2015 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
 
 #ifdef _KERNEL
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: npf_worker.c,v 1.3 2017/01/02 21:49:51 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: npf_worker.c,v 1.4 2017/12/10 01:18:21 rmind Exp $");
 
 #include <sys/param.h>
 #include <sys/types.h>
@@ -148,9 +148,12 @@
 npf_worker_unregister(npf_t *npf, npf_workfunc_t func)
 {
        const unsigned idx = npf->worker_id;
-       npf_worker_t *wrk = &npf_workers[idx];
+       npf_worker_t *wrk;
        npf_t *instance;
 
+       if (!npf_worker_count)
+               return;
+       wrk = &npf_workers[idx];
        mutex_enter(&wrk->worker_lock);
        npf_worker_testset(wrk, func, NULL);
        if ((instance = wrk->instances) == npf) {



Home | Main Index | Thread Index | Old Index