Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/miscfs/procfs If the procfs mount is marked as linux-com...
details: https://anonhg.NetBSD.org/src/rev/0869e6000587
branches: trunk
changeset: 1009627:0869e6000587
user: thorpej <thorpej%NetBSD.org@localhost>
date: Wed Apr 29 01:56:54 2020 +0000
description:
If the procfs mount is marked as linux-compat, then allow proc lookup
by any LWP ID in the proc, not just the canonical PID.
diffstat:
sys/miscfs/procfs/procfs.h | 6 ++-
sys/miscfs/procfs/procfs_subr.c | 28 ++++++++++++++++---
sys/miscfs/procfs/procfs_vfsops.c | 6 ++--
sys/miscfs/procfs/procfs_vnops.c | 56 ++++++++++++++++++++++----------------
4 files changed, 63 insertions(+), 33 deletions(-)
diffs (296 lines):
diff -r d3da67e30b7a -r 0869e6000587 sys/miscfs/procfs/procfs.h
--- a/sys/miscfs/procfs/procfs.h Wed Apr 29 01:55:52 2020 +0000
+++ b/sys/miscfs/procfs/procfs.h Wed Apr 29 01:56:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: procfs.h,v 1.78 2020/01/17 20:08:09 ad Exp $ */
+/* $NetBSD: procfs.h,v 1.79 2020/04/29 01:56:54 thorpej Exp $ */
/*
* Copyright (c) 1993
@@ -209,7 +209,9 @@
int vfs_getuserstr(struct uio *, char *, int *);
const vfs_namemap_t *vfs_findname(const vfs_namemap_t *, const char *, int);
-int procfs_proc_lock(int, struct proc **, int);
+struct proc *procfs_proc_find(struct mount *, pid_t);
+bool procfs_use_linux_compat(struct mount *);
+int procfs_proc_lock(struct mount *, int, struct proc **, int);
void procfs_proc_unlock(struct proc *);
struct mount;
int procfs_allocvp(struct mount *, struct vnode **, pid_t, pfstype, int);
diff -r d3da67e30b7a -r 0869e6000587 sys/miscfs/procfs/procfs_subr.c
--- a/sys/miscfs/procfs/procfs_subr.c Wed Apr 29 01:55:52 2020 +0000
+++ b/sys/miscfs/procfs/procfs_subr.c Wed Apr 29 01:56:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: procfs_subr.c,v 1.114 2019/09/26 17:34:08 christos Exp $ */
+/* $NetBSD: procfs_subr.c,v 1.115 2020/04/29 01:56:54 thorpej Exp $ */
/*-
* Copyright (c) 2006, 2007, 2008 The NetBSD Foundation, Inc.
@@ -102,7 +102,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: procfs_subr.c,v 1.114 2019/09/26 17:34:08 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: procfs_subr.c,v 1.115 2020/04/29 01:56:54 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -152,7 +152,8 @@
if (uio->uio_offset < 0)
return EINVAL;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &p, ESRCH)) != 0)
+ if ((error =
+ procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &p, ESRCH)) != 0)
return error;
curl = curlwp;
@@ -408,8 +409,25 @@
vfs_vnode_iterator_destroy(marker);
}
+bool
+procfs_use_linux_compat(struct mount *mp)
+{
+ const int flags = VFSTOPROC(mp)->pmnt_flags;
+
+ return (flags & PROCFSMNT_LINUXCOMPAT) ? true : false;
+}
+
+struct proc *
+procfs_proc_find(struct mount *mp, pid_t pid)
+{
+ KASSERT(mutex_owned(proc_lock));
+ return procfs_use_linux_compat(mp) ? proc_find_lwpid(pid)
+ : proc_find(pid);
+}
+
int
-procfs_proc_lock(int pid, struct proc **bunghole, int notfound)
+procfs_proc_lock(struct mount *mp, int pid, struct proc **bunghole,
+ int notfound)
{
struct proc *tp;
int error = 0;
@@ -418,7 +436,7 @@
if (pid == 0)
tp = &proc0;
- else if ((tp = proc_find(pid)) == NULL)
+ else if ((tp = procfs_proc_find(mp, pid)) == NULL)
error = notfound;
if (tp != NULL && !rw_tryenter(&tp->p_reflock, RW_READER))
error = EBUSY;
diff -r d3da67e30b7a -r 0869e6000587 sys/miscfs/procfs/procfs_vfsops.c
--- a/sys/miscfs/procfs/procfs_vfsops.c Wed Apr 29 01:55:52 2020 +0000
+++ b/sys/miscfs/procfs/procfs_vfsops.c Wed Apr 29 01:56:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: procfs_vfsops.c,v 1.107 2020/04/20 05:22:28 htodd Exp $ */
+/* $NetBSD: procfs_vfsops.c,v 1.108 2020/04/29 01:56:54 thorpej Exp $ */
/*
* Copyright (c) 1993
@@ -76,7 +76,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: procfs_vfsops.c,v 1.107 2020/04/20 05:22:28 htodd Exp $");
+__KERNEL_RCSID(0, "$NetBSD: procfs_vfsops.c,v 1.108 2020/04/29 01:56:54 thorpej Exp $");
#if defined(_KERNEL_OPT)
#include "opt_compat_netbsd.h"
@@ -322,7 +322,7 @@
struct proc *p;
mutex_enter(proc_lock);
- p = proc_find(pfs->pfs_pid);
+ p = procfs_proc_find(mp, pfs->pfs_pid);
mutex_exit(proc_lock);
if (p == NULL) {
error = ENOENT;
diff -r d3da67e30b7a -r 0869e6000587 sys/miscfs/procfs/procfs_vnops.c
--- a/sys/miscfs/procfs/procfs_vnops.c Wed Apr 29 01:55:52 2020 +0000
+++ b/sys/miscfs/procfs/procfs_vnops.c Wed Apr 29 01:56:54 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: procfs_vnops.c,v 1.211 2020/04/21 21:42:47 ad Exp $ */
+/* $NetBSD: procfs_vnops.c,v 1.212 2020/04/29 01:56:54 thorpej Exp $ */
/*-
* Copyright (c) 2006, 2007, 2008, 2020 The NetBSD Foundation, Inc.
@@ -105,7 +105,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: procfs_vnops.c,v 1.211 2020/04/21 21:42:47 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: procfs_vnops.c,v 1.212 2020/04/29 01:56:54 thorpej Exp $");
#include <sys/param.h>
#include <sys/atomic.h>
@@ -318,12 +318,14 @@
int a_mode;
kauth_cred_t a_cred;
} */ *ap = v;
- struct pfsnode *pfs = VTOPFS(ap->a_vp);
+ struct vnode *vp = ap->a_vp;
+ struct pfsnode *pfs = VTOPFS(vp);
struct lwp *l1;
struct proc *p2;
int error;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &p2, ENOENT)) != 0)
+ if ((error =
+ procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &p2, ENOENT)) != 0)
return error;
l1 = curlwp; /* tracer */
@@ -428,7 +430,7 @@
struct pfsnode *pfs = VTOPFS(vp);
mutex_enter(proc_lock);
- *ap->a_recycle = (proc_find(pfs->pfs_pid) == NULL);
+ *ap->a_recycle = (procfs_proc_find(vp->v_mount, pfs->pfs_pid) == NULL);
mutex_exit(proc_lock);
return (0);
@@ -638,7 +640,8 @@
struct vattr *a_vap;
kauth_cred_t a_cred;
} */ *ap = v;
- struct pfsnode *pfs = VTOPFS(ap->a_vp);
+ struct vnode *vp = ap->a_vp;
+ struct pfsnode *pfs = VTOPFS(vp);
struct vattr *vap = ap->a_vap;
struct proc *procp;
char *path, *bp, bf[16];
@@ -653,7 +656,8 @@
break;
default:
- error = procfs_proc_lock(pfs->pfs_pid, &procp, ENOENT);
+ error =
+ procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &procp, ENOENT);
if (error != 0)
return (error);
break;
@@ -1074,7 +1078,7 @@
type = PFSproc;
}
- if (procfs_proc_lock(pid, &p, ESRCH) != 0)
+ if (procfs_proc_lock(dvp->v_mount, pid, &p, ESRCH) != 0)
break;
error = procfs_allocvp(dvp->v_mount, vpp, vnpid, type, -1);
procfs_proc_unlock(p);
@@ -1087,7 +1091,8 @@
return (error);
}
- if (procfs_proc_lock(pfs->pfs_pid, &p, ESRCH) != 0)
+ if (procfs_proc_lock(dvp->v_mount, pfs->pfs_pid, &p,
+ ESRCH) != 0)
break;
mutex_enter(p->p_lock);
@@ -1139,7 +1144,8 @@
int fd;
file_t *fp;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &p, ENOENT)) != 0)
+ if ((error = procfs_proc_lock(dvp->v_mount, pfs->pfs_pid, &p,
+ ENOENT)) != 0)
return error;
if (cnp->cn_flags & ISDOTDOT) {
@@ -1175,7 +1181,8 @@
case PFStask: {
int xpid;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &p, ENOENT)) != 0)
+ if ((error = procfs_proc_lock(dvp->v_mount, pfs->pfs_pid, &p,
+ ENOENT)) != 0)
return error;
if (cnp->cn_flags & ISDOTDOT) {
@@ -1211,10 +1218,7 @@
static int
procfs_validfile_linux(struct lwp *l, struct mount *mp)
{
- int flags;
-
- flags = VFSTOPROC(mp)->pmnt_flags;
- return (flags & PROCFSMNT_LINUXCOMPAT) &&
+ return procfs_use_linux_compat(mp) &&
(l == NULL || l->l_proc == NULL || procfs_validfile(l, mp));
}
@@ -1334,7 +1338,7 @@
if (i >= nproc_targets)
return 0;
- if (procfs_proc_lock(pfs->pfs_pid, &p, ESRCH) != 0)
+ if (procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &p, ESRCH) != 0)
break;
if (ap->a_ncookies) {
@@ -1376,7 +1380,8 @@
file_t *fp;
int lim, nc = 0;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &p, ESRCH)) != 0)
+ if ((error = procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &p,
+ ESRCH)) != 0)
return error;
/* XXX Should this be by file as well? */
@@ -1444,7 +1449,8 @@
struct proc *p;
int nc = 0;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &p, ESRCH)) != 0)
+ if ((error = procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &p,
+ ESRCH)) != 0)
return error;
nfd = 3; /* ., .., pid */
@@ -1617,7 +1623,8 @@
char *path = NULL;
int len = 0;
int error = 0;
- struct pfsnode *pfs = VTOPFS(ap->a_vp);
+ struct vnode *vp = ap->a_vp;
+ struct pfsnode *pfs = VTOPFS(vp);
struct proc *pown = NULL;
if (pfs->pfs_fileno == PROCFS_FILENO(0, PFScurproc, -1))
@@ -1627,13 +1634,15 @@
else if (pfs->pfs_fileno == PROCFS_FILENO(pfs->pfs_pid, PFStask, 0))
len = snprintf(bf, sizeof(bf), "..");
else if (pfs->pfs_fileno == PROCFS_FILENO(pfs->pfs_pid, PFSexe, -1)) {
- if ((error = procfs_proc_lock(pfs->pfs_pid, &pown, ESRCH)) != 0)
+ if ((error = procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &pown,
+ ESRCH)) != 0)
return error;
bp = pown->p_path;
len = strlen(bp);
} else if (pfs->pfs_fileno == PROCFS_FILENO(pfs->pfs_pid, PFScwd, -1) ||
pfs->pfs_fileno == PROCFS_FILENO(pfs->pfs_pid, PFSchroot, -1)) {
- if ((error = procfs_proc_lock(pfs->pfs_pid, &pown, ESRCH)) != 0)
+ if ((error = procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &pown,
+ ESRCH)) != 0)
return error;
path = malloc(MAXPATHLEN + 4, M_TEMP, M_WAITOK);
if (path == NULL) {
@@ -1647,9 +1656,10 @@
len = strlen(bp);
} else {
file_t *fp;
- struct vnode *vxp, *vp;
+ struct vnode *vxp;
- if ((error = procfs_proc_lock(pfs->pfs_pid, &pown, ESRCH)) != 0)
+ if ((error = procfs_proc_lock(vp->v_mount, pfs->pfs_pid, &pown,
+ ESRCH)) != 0)
return error;
fp = fd_getfile2(pown, pfs->pfs_fd);
Home |
Main Index |
Thread Index |
Old Index