Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Canonicalize the interpreter path in #! scripts since ch...
details: https://anonhg.NetBSD.org/src/rev/a197c9d1964a
branches: trunk
changeset: 361391:a197c9d1964a
user: christos <christos%NetBSD.org@localhost>
date: Fri Apr 27 18:33:24 2018 +0000
description:
Canonicalize the interpreter path in #! scripts since check_exec() expects
an absolute path, and we KASSERT if that's not the case later.
diffstat:
sys/kern/exec_script.c | 10 ++++------
sys/kern/kern_exec.c | 25 ++++++++++++++++---------
sys/sys/exec.h | 6 ++++--
3 files changed, 24 insertions(+), 17 deletions(-)
diffs (125 lines):
diff -r b64363d12b1a -r a197c9d1964a sys/kern/exec_script.c
--- a/sys/kern/exec_script.c Fri Apr 27 16:50:56 2018 +0000
+++ b/sys/kern/exec_script.c Fri Apr 27 18:33:24 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: exec_script.c,v 1.74 2014/09/05 09:20:59 matt Exp $ */
+/* $NetBSD: exec_script.c,v 1.75 2018/04/27 18:33:24 christos Exp $ */
/*
* Copyright (c) 1993, 1994, 1996 Christopher G. Demetriou
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: exec_script.c,v 1.74 2014/09/05 09:20:59 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: exec_script.c,v 1.75 2018/04/27 18:33:24 christos Exp $");
#if defined(SETUIDSCRIPTS) && !defined(FDSCRIPTS)
#define FDSCRIPTS /* Need this for safe set-id scripts. */
@@ -280,10 +280,8 @@
epp->ep_hdrvalid = 0;
/* try loading the interpreter */
- shell_pathbuf = pathbuf_create(shellname);
- if (shell_pathbuf == NULL) {
- error = ENOMEM;
- } else {
+ if ((error = exec_makepathbuf(l, shellname, UIO_SYSSPACE,
+ &shell_pathbuf, NULL)) == 0) {
error = check_exec(l, epp, shell_pathbuf);
pathbuf_destroy(shell_pathbuf);
}
diff -r b64363d12b1a -r a197c9d1964a sys/kern/kern_exec.c
--- a/sys/kern/kern_exec.c Fri Apr 27 16:50:56 2018 +0000
+++ b/sys/kern/kern_exec.c Fri Apr 27 18:33:24 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_exec.c,v 1.456 2018/02/23 19:43:08 maxv Exp $ */
+/* $NetBSD: kern_exec.c,v 1.457 2018/04/27 18:33:24 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.456 2018/02/23 19:43:08 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_exec.c,v 1.457 2018/04/27 18:33:24 christos Exp $");
#include "opt_exec.h"
#include "opt_execfmt.h"
@@ -607,9 +607,9 @@
#endif
}
-static int
-makepathbuf(struct lwp *l, const char *upath, struct pathbuf **pbp,
- size_t *offs)
+int
+exec_makepathbuf(struct lwp *l, const char *upath, enum uio_seg seg,
+ struct pathbuf **pbp, size_t *offs)
{
char *path, *bp;
size_t len, tlen;
@@ -617,7 +617,11 @@
struct cwdinfo *cwdi;
path = PNBUF_GET();
- error = copyinstr(upath, path, MAXPATHLEN, &len);
+ if (seg == UIO_SYSSPACE) {
+ error = copystr(upath, path, MAXPATHLEN, &len);
+ } else {
+ error = copyinstr(upath, path, MAXPATHLEN, &len);
+ }
if (error) {
PNBUF_PUT(path);
DPRINTF(("%s: copyin path @%p %d\n", __func__, upath, error));
@@ -625,7 +629,8 @@
}
if (path[0] == '/') {
- *offs = 0;
+ if (offs)
+ *offs = 0;
goto out;
}
@@ -651,7 +656,8 @@
memmove(path, bp, tlen);
path[tlen] = '\0';
- *offs = tlen - len;
+ if (offs)
+ *offs = tlen - len;
out:
*pbp = pathbuf_assimilate(path);
return 0;
@@ -730,7 +736,8 @@
* functions call check_exec() recursively - for example,
* see exec_script_makecmds().
*/
- if ((error = makepathbuf(l, path, &data->ed_pathbuf, &offs)) != 0)
+ if ((error = exec_makepathbuf(l, path, UIO_USERSPACE,
+ &data->ed_pathbuf, &offs)) != 0)
goto clrflg;
data->ed_pathstring = pathbuf_stringcopy_get(data->ed_pathbuf);
data->ed_resolvedpathbuf = PNBUF_GET();
diff -r b64363d12b1a -r a197c9d1964a sys/sys/exec.h
--- a/sys/sys/exec.h Fri Apr 27 16:50:56 2018 +0000
+++ b/sys/sys/exec.h Fri Apr 27 18:33:24 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: exec.h,v 1.152 2017/11/07 19:44:05 christos Exp $ */
+/* $NetBSD: exec.h,v 1.153 2018/04/27 18:33:24 christos Exp $ */
/*-
* Copyright (c) 1992, 1993
@@ -310,7 +310,9 @@
void posix_spawn_fa_free(struct posix_spawn_file_actions *, size_t);
int do_posix_spawn(struct lwp *, pid_t *, bool*, const char *,
struct posix_spawn_file_actions *, struct posix_spawnattr *,
- char *const *argv, char *const *, execve_fetch_element_t);
+ char *const *, char *const *, execve_fetch_element_t);
+int exec_makepathbuf(struct lwp *, const char *, enum uio_seg,
+ struct pathbuf **, size_t *);
extern int maxexec;
Home |
Main Index |
Thread Index |
Old Index