diff options
| author | 2011-11-23 09:28:17 -0800 | |
|---|---|---|
| committer | 2011-11-23 09:28:17 -0800 | |
| commit | 24b7ead3fb0bae267c2ee50898eb4c13aedd1e9f (patch) | |
| tree | 899a48d29daebb6e2eb9398797304985e5961fc8 /fs/btrfs/async-thread.c | |
| parent | freezer: kill unused set_freezable_with_signal() (diff) | |
| download | wireguard-linux-24b7ead3fb0bae267c2ee50898eb4c13aedd1e9f.tar.xz wireguard-linux-24b7ead3fb0bae267c2ee50898eb4c13aedd1e9f.zip | |
freezer: fix wait_event_freezable/__thaw_task races
wait_event_freezable() and friends stop the waiting if try_to_freeze()
fails. This is not right, we can race with __thaw_task() and in this
case
- wait_event_freezable() returns the wrong ERESTARTSYS
- wait_event_freezable_timeout() can return the positive
value while condition == F
Change the code to always check __retval/condition before return.
Note: with or without this patch the timeout logic looks strange,
probably we should recalc timeout if try_to_freeze() returns T.
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'fs/btrfs/async-thread.c')
0 files changed, 0 insertions, 0 deletions
