Source-Changes-HG archive

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

[src/trunk]: src/sys/kern - move quadruplicated code into a function



details:   https://anonhg.NetBSD.org/src/rev/5f70dbb2b278
branches:  trunk
changeset: 454167:5f70dbb2b278
user:      christos <christos%NetBSD.org@localhost>
date:      Sat Sep 07 15:34:44 2019 +0000

description:
- move quadruplicated code into a function
- delete #if 1 and #if 0 code

diffstat:

 sys/kern/kern_exec.c |  39 ++++++++++++++-------------------------
 1 files changed, 14 insertions(+), 25 deletions(-)

diffs (103 lines):

diff -r 3660eb907197 -r 5f70dbb2b278 sys/kern/kern_exec.c
--- a/sys/kern/kern_exec.c      Sat Sep 07 13:45:30 2019 +0000
+++ b/sys/kern/kern_exec.c      Sat Sep 07 15:34:44 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kern_exec.c,v 1.478 2019/07/05 17:14:48 maxv Exp $     */
+/*     $NetBSD: kern_exec.c,v 1.479 2019/09/07 15:34:44 christos Exp $ */
 
 /*-
  * Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -59,7 +59,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_exec.c,v 1.478 2019/07/05 17:14:48 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_exec.c,v 1.479 2019/09/07 15:34:44 christos Exp $");
 
 #include "opt_exec.h"
 #include "opt_execfmt.h"
@@ -304,6 +304,14 @@
        .pa_pagesz = NCARGS
 };
 
+static void
+exec_path_free(struct execve_data *data)
+{              
+       pathbuf_stringcopy_put(data->ed_pathbuf, data->ed_pathstring);
+       pathbuf_destroy(data->ed_pathbuf);
+       PNBUF_PUT(data->ed_resolvedpathbuf);
+}
+
 /*
  * check exec:
  * given an "executable" described in the exec package's namei info,
@@ -338,25 +346,14 @@
        struct nameidata nd;
        size_t          resid;
 
-#if 1
        // grab the absolute pathbuf here before namei() trashes it.
        pathbuf_copystring(pb, epp->ep_resolvedname, PATH_MAX);
-#endif
        NDINIT(&nd, LOOKUP, FOLLOW | LOCKLEAF | TRYEMULROOT, pb);
 
        /* first get the vnode */
        if ((error = namei(&nd)) != 0)
                return error;
        epp->ep_vp = vp = nd.ni_vp;
-#if 0
-       /*
-        * XXX: can't use nd.ni_pnbuf, because although pb contains an
-        * absolute path, nd.ni_pnbuf does not if the path contains symlinks.
-        */
-       /* normally this can't fail */
-       error = copystr(nd.ni_pnbuf, epp->ep_resolvedname, PATH_MAX, NULL);
-       KASSERT(error == 0);
-#endif
 
 #ifdef DIAGNOSTIC
        /* paranoia (take this out once namei stuff stabilizes) */
@@ -843,9 +840,7 @@
 
        rw_exit(&exec_lock);
 
-       pathbuf_stringcopy_put(data->ed_pathbuf, data->ed_pathstring);
-       pathbuf_destroy(data->ed_pathbuf);
-       PNBUF_PUT(data->ed_resolvedpathbuf);
+       exec_path_free(data);
 
  clrflg:
        rw_exit(&p->p_reflock);
@@ -941,9 +936,7 @@
        if (epp->ep_interp != NULL)
                vrele(epp->ep_interp);
 
-       pathbuf_stringcopy_put(data->ed_pathbuf, data->ed_pathstring);
-       pathbuf_destroy(data->ed_pathbuf);
-       PNBUF_PUT(data->ed_resolvedpathbuf);
+       exec_path_free(data);
 }
 
 static void
@@ -1313,9 +1306,7 @@
                mutex_exit(proc_lock);
        }
 
-       pathbuf_stringcopy_put(data->ed_pathbuf, data->ed_pathstring);
-       pathbuf_destroy(data->ed_pathbuf);
-       PNBUF_PUT(data->ed_resolvedpathbuf);
+       exec_path_free(data);
 #ifdef TRACE_EXEC
        DPRINTF(("%s finished\n", __func__));
 #endif
@@ -1327,9 +1318,7 @@
        if (!no_local_exec_lock)
                rw_exit(&exec_lock);
 
-       pathbuf_stringcopy_put(data->ed_pathbuf, data->ed_pathstring);
-       pathbuf_destroy(data->ed_pathbuf);
-       PNBUF_PUT(data->ed_resolvedpathbuf);
+       exec_path_free(data);
 
        /*
         * the old process doesn't exist anymore.  exit gracefully.



Home | Main Index | Thread Index | Old Index