do_wait: simplify retval/tsk_result/notask_error mess
Now that we don't pass &retval down to other helpers we can simplify the code more. - kill tsk_result, just use retval - add the "notask" label right after the main loop, and s/got end/goto notask/ after the fastpath pid check. This way we don't need to initialize retval before this check and the code becomes a bit more clean, if this pid has no attached tasks we should just skip the list search. Signed-off-by: Oleg Nesterov <oleg@redhat.com> Cc: Ingo Molnar <mingo@elte.hu> Acked-by: Roland McGrath <roland@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
9e8ae01d1c
commit
64a16caf5e
@ -1576,27 +1576,22 @@ repeat:
|
|||||||
* might later match our criteria, even if we are not able to reap
|
* might later match our criteria, even if we are not able to reap
|
||||||
* it yet.
|
* it yet.
|
||||||
*/
|
*/
|
||||||
retval = wo->notask_error = -ECHILD;
|
wo->notask_error = -ECHILD;
|
||||||
if ((wo->wo_type < PIDTYPE_MAX) &&
|
if ((wo->wo_type < PIDTYPE_MAX) &&
|
||||||
(!wo->wo_pid || hlist_empty(&wo->wo_pid->tasks[wo->wo_type])))
|
(!wo->wo_pid || hlist_empty(&wo->wo_pid->tasks[wo->wo_type])))
|
||||||
goto end;
|
goto notask;
|
||||||
|
|
||||||
current->state = TASK_INTERRUPTIBLE;
|
current->state = TASK_INTERRUPTIBLE;
|
||||||
read_lock(&tasklist_lock);
|
read_lock(&tasklist_lock);
|
||||||
tsk = current;
|
tsk = current;
|
||||||
do {
|
do {
|
||||||
int tsk_result = do_wait_thread(wo, tsk);
|
retval = do_wait_thread(wo, tsk);
|
||||||
|
if (retval)
|
||||||
if (!tsk_result)
|
goto end;
|
||||||
tsk_result = ptrace_do_wait(wo, tsk);
|
|
||||||
|
retval = ptrace_do_wait(wo, tsk);
|
||||||
if (tsk_result) {
|
if (retval)
|
||||||
/*
|
|
||||||
* tasklist_lock is unlocked and we have a final result.
|
|
||||||
*/
|
|
||||||
retval = tsk_result;
|
|
||||||
goto end;
|
goto end;
|
||||||
}
|
|
||||||
|
|
||||||
if (wo->wo_flags & __WNOTHREAD)
|
if (wo->wo_flags & __WNOTHREAD)
|
||||||
break;
|
break;
|
||||||
@ -1605,6 +1600,7 @@ repeat:
|
|||||||
} while (tsk != current);
|
} while (tsk != current);
|
||||||
read_unlock(&tasklist_lock);
|
read_unlock(&tasklist_lock);
|
||||||
|
|
||||||
|
notask:
|
||||||
retval = wo->notask_error;
|
retval = wo->notask_error;
|
||||||
if (!retval && !(wo->wo_flags & WNOHANG)) {
|
if (!retval && !(wo->wo_flags & WNOHANG)) {
|
||||||
retval = -ERESTARTSYS;
|
retval = -ERESTARTSYS;
|
||||||
|
Loading…
Reference in New Issue
Block a user