summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Watson <rwatson@FreeBSD.org>2001-04-12 19:39:00 +0000
committerRobert Watson <rwatson@FreeBSD.org>2001-04-12 19:39:00 +0000
commiteb9e5c1d72f970bb078dfd279a9771d737a7fc8c (patch)
tree0bd604571518c0263a35e9ed549762f429b7162f
parentbacff58c0e8a24a142fb34ea4b001bea9eba7d4d (diff)
Notes
-rw-r--r--sys/kern/kern_prot.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/sys/kern/kern_prot.c b/sys/kern/kern_prot.c
index 8db2fb65be85..46512d9477d5 100644
--- a/sys/kern/kern_prot.c
+++ b/sys/kern/kern_prot.c
@@ -143,6 +143,7 @@ getpgid(p, uap)
struct getpgid_args *uap;
{
struct proc *pt;
+ int error;
pt = p;
if (uap->pid == 0)
@@ -150,6 +151,8 @@ getpgid(p, uap)
if ((pt = pfind(uap->pid)) == 0)
return ESRCH;
+ if ((error = p_can(p, pt, P_CAN_SEE, NULL)))
+ return (error);
found:
p->p_retval[0] = pt->p_pgrp->pg_id;
return 0;
@@ -170,6 +173,7 @@ getsid(p, uap)
struct getsid_args *uap;
{
struct proc *pt;
+ int error;
pt = p;
if (uap->pid == 0)
@@ -177,6 +181,8 @@ getsid(p, uap)
if ((pt = pfind(uap->pid)) == 0)
return ESRCH;
+ if ((error = p_can(p, pt, P_CAN_SEE, NULL)))
+ return (error);
found:
p->p_retval[0] = pt->p_session->s_sid;
return 0;
@@ -349,12 +355,15 @@ setpgid(curp, uap)
{
register struct proc *targp; /* target process */
register struct pgrp *pgrp; /* target pgrp */
+ int error;
if (uap->pgid < 0)
return (EINVAL);
if (uap->pid != 0 && uap->pid != curp->p_pid) {
if ((targp = pfind(uap->pid)) == 0 || !inferior(targp))
return (ESRCH);
+ if ((error = p_can(curproc, targp, P_CAN_SEE, NULL)))
+ return (error);
if (targp->p_pgrp == NULL || targp->p_session != curp->p_session)
return (EPERM);
if (targp->p_flag & P_EXEC)