aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/sys.c33
1 files changed, 20 insertions, 13 deletions
diff --git a/kernel/sys.c b/kernel/sys.c
index 5d0b44cd435c..ddd28e261f3a 100644
--- a/kernel/sys.c
+++ b/kernel/sys.c
@@ -1022,23 +1022,30 @@ asmlinkage long sys_getpgrp(void)
1022 1022
1023asmlinkage long sys_getsid(pid_t pid) 1023asmlinkage long sys_getsid(pid_t pid)
1024{ 1024{
1025 struct task_struct *p;
1026 struct pid *sid;
1027 int retval;
1028
1029 rcu_read_lock();
1025 if (!pid) 1030 if (!pid)
1026 return task_session_vnr(current); 1031 sid = task_session(current);
1027 else { 1032 else {
1028 int retval;
1029 struct task_struct *p;
1030
1031 rcu_read_lock();
1032 p = find_task_by_vpid(pid);
1033 retval = -ESRCH; 1033 retval = -ESRCH;
1034 if (p) { 1034 p = find_task_by_vpid(pid);
1035 retval = security_task_getsid(p); 1035 if (!p)
1036 if (!retval) 1036 goto out;
1037 retval = task_session_vnr(p); 1037 sid = task_session(p);
1038 } 1038 if (!sid)
1039 rcu_read_unlock(); 1039 goto out;
1040 return retval; 1040
1041 retval = security_task_getsid(p);
1042 if (retval)
1043 goto out;
1041 } 1044 }
1045 retval = pid_vnr(sid);
1046out:
1047 rcu_read_unlock();
1048 return retval;
1042} 1049}
1043 1050
1044asmlinkage long sys_setsid(void) 1051asmlinkage long sys_setsid(void)