Source-Changes-HG archive

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

[src/trunk]: src/sys/net - kmem_alloc(,KM_SLEEP) never return NULL, so remove...



details:   https://anonhg.NetBSD.org/src/rev/986b9308f5d6
branches:  trunk
changeset: 1002962:986b9308f5d6
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Fri Aug 23 02:33:15 2019 +0000

description:
- kmem_alloc(,KM_SLEEP) never return NULL, so remove NULL check.
- VLAN ID is never duplicated, so break the loop when found. Also move
  kmen_free() outside of ETHER_LOCK(ec)/ETHER_UNLOCK(ec) to reduce the hold
  time. suggested by ozaki-r.
- Whitespace fix.

diffstat:

 sys/net/if_vlan.c |  20 +++++++++-----------
 1 files changed, 9 insertions(+), 11 deletions(-)

diffs (71 lines):

diff -r f9bb6b6c92dd -r 986b9308f5d6 sys/net/if_vlan.c
--- a/sys/net/if_vlan.c Thu Aug 22 22:51:47 2019 +0000
+++ b/sys/net/if_vlan.c Fri Aug 23 02:33:15 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_vlan.c,v 1.145 2019/08/21 06:00:07 msaitoh Exp $    */
+/*     $NetBSD: if_vlan.c,v 1.146 2019/08/23 02:33:15 msaitoh Exp $    */
 
 /*
  * Copyright (c) 2000, 2001 The NetBSD Foundation, Inc.
@@ -78,7 +78,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.145 2019/08/21 06:00:07 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.146 2019/08/23 02:33:15 msaitoh Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -487,10 +487,6 @@
                }
                /* Add a vid to the list */
                vidmem = kmem_alloc(sizeof(struct vlanid_list), KM_SLEEP);
-               if (vidmem == NULL) {
-                       error = ENOMEM;
-                       goto viderr;
-               }
                vidmem->vid = vid;
                ETHER_LOCK(ec);
                SIMPLEQ_INSERT_TAIL(&ec->ec_vids, vidmem, vid_list);
@@ -502,7 +498,6 @@
                         * HW tagging function.
                         */
                        error = (*ec->ec_vlan_cb)(ec, vid, true);
-viderr:
                        if (error) {
                                ec->ec_nvlans--;
                                if (ec->ec_nvlans == 0) {
@@ -638,18 +633,21 @@
        case IFT_ETHER:
            {
                struct ethercom *ec = (void *)p;
-               struct vlanid_list *vlanidp, *tmpp;
+               struct vlanid_list *vlanidp;
                uint16_t vid = EVL_VLANOFTAG(nmib->ifvm_tag);
 
                ETHER_LOCK(ec);
-               SIMPLEQ_FOREACH_SAFE(vlanidp, &ec->ec_vids, vid_list, tmpp) {
+               SIMPLEQ_FOREACH(vlanidp, &ec->ec_vids, vid_list) {
                        if (vlanidp->vid == vid) {
                                SIMPLEQ_REMOVE(&ec->ec_vids, vlanidp,
                                    vlanid_list, vid_list);
-                               kmem_free(vlanidp, sizeof(*vlanidp));
+                               break;
                        }
                }
                ETHER_UNLOCK(ec);
+               if (vlanidp != NULL)
+                       kmem_free(vlanidp, sizeof(*vlanidp));
+
                if (ec->ec_vlan_cb != NULL) {
                        /*
                         * Call ec_vlan_cb(). It will setup VLAN HW filter or
@@ -1038,7 +1036,7 @@
                        error = ENOENT;
                        break;
                }
-               
+
                error = vlan_config(ifv, pr, vlr.vlr_tag);
                if (error != 0)
                        break;



Home | Main Index | Thread Index | Old Index