Hi!
> If the freezing of tasks fails and a task is preempted in refrigerator()
> before
> calling frozen_process(), then thaw_tasks() may run before this task is
> frozen.
> In that case the task will freeze and no one will thaw it.
>
> To fix this race we can call freezing(current) in refrigerator() along with
> frozen_process(current) under the task_lock() which also should be taken in
> the error path of try_to_freeze_tasks() as well as in thaw_process().
> Moreover,
> if thaw_process() additionally clears TIF_FREEZE for tasks that are not
> frozen,
> we can be sure that all tasks are thawed and there are no pending "freeze"
> requests after thaw_tasks() has run.
>
> Signed-off-by: Rafael J. Wysocki <[EMAIL PROTECTED]>
Looks ok to me.
Pavel
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures)
http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/