Loading kernel/exit.c +10 −13 Original line number Diff line number Diff line Loading @@ -1600,12 +1600,10 @@ SYSCALL_DEFINE5(waitid, int, which, pid_t, upid, struct siginfo __user *, struct waitid_info info = {.status = 0}; long err = kernel_waitid(which, upid, &info, options, ru ? &r : NULL); int signo = 0; if (err > 0) { signo = SIGCHLD; err = 0; } if (!err) { if (ru && copy_to_user(ru, &r, sizeof(struct rusage))) return -EFAULT; } Loading Loading @@ -1723,9 +1721,7 @@ COMPAT_SYSCALL_DEFINE5(waitid, if (err > 0) { signo = SIGCHLD; err = 0; } if (!err && uru) { if (uru) { /* kernel_waitid() overwrites everything in ru */ if (COMPAT_USE_64BIT_TIME) err = copy_to_user(uru, &ru, sizeof(ru)); Loading @@ -1734,6 +1730,7 @@ COMPAT_SYSCALL_DEFINE5(waitid, if (err) return -EFAULT; } } if (!infop) return err; Loading Loading
kernel/exit.c +10 −13 Original line number Diff line number Diff line Loading @@ -1600,12 +1600,10 @@ SYSCALL_DEFINE5(waitid, int, which, pid_t, upid, struct siginfo __user *, struct waitid_info info = {.status = 0}; long err = kernel_waitid(which, upid, &info, options, ru ? &r : NULL); int signo = 0; if (err > 0) { signo = SIGCHLD; err = 0; } if (!err) { if (ru && copy_to_user(ru, &r, sizeof(struct rusage))) return -EFAULT; } Loading Loading @@ -1723,9 +1721,7 @@ COMPAT_SYSCALL_DEFINE5(waitid, if (err > 0) { signo = SIGCHLD; err = 0; } if (!err && uru) { if (uru) { /* kernel_waitid() overwrites everything in ru */ if (COMPAT_USE_64BIT_TIME) err = copy_to_user(uru, &ru, sizeof(ru)); Loading @@ -1734,6 +1730,7 @@ COMPAT_SYSCALL_DEFINE5(waitid, if (err) return -EFAULT; } } if (!infop) return err; Loading