Skip to content

Commit

Permalink
dlm: use wait_event_timeout
Browse files Browse the repository at this point in the history
Use wait_event_timeout to avoid using a timer
directly.

Signed-off-by: David Teigland <[email protected]>
  • Loading branch information
teigland committed Jul 16, 2012
1 parent 05c32f4 commit 6d76817
Showing 1 changed file with 11 additions and 18 deletions.
29 changes: 11 additions & 18 deletions fs/dlm/recover.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,30 +36,23 @@
* (LS_RECOVERY_STOP set due to failure of a node in ls_nodes). When another
* function thinks it could have completed the waited-on task, they should wake
* up ls_wait_general to get an immediate response rather than waiting for the
* timer to detect the result. A timer wakes us up periodically while waiting
* to see if we should abort due to a node failure. This should only be called
* by the dlm_recoverd thread.
* timeout. This uses a timeout so it can check periodically if the wait
* should abort due to node failure (which doesn't cause a wake_up).
* This should only be called by the dlm_recoverd thread.
*/

static void dlm_wait_timer_fn(unsigned long data)
{
struct dlm_ls *ls = (struct dlm_ls *) data;
mod_timer(&ls->ls_timer, jiffies + (dlm_config.ci_recover_timer * HZ));
wake_up(&ls->ls_wait_general);
}

int dlm_wait_function(struct dlm_ls *ls, int (*testfn) (struct dlm_ls *ls))
{
int error = 0;
int rv;

init_timer(&ls->ls_timer);
ls->ls_timer.function = dlm_wait_timer_fn;
ls->ls_timer.data = (long) ls;
ls->ls_timer.expires = jiffies + (dlm_config.ci_recover_timer * HZ);
add_timer(&ls->ls_timer);

wait_event(ls->ls_wait_general, testfn(ls) || dlm_recovery_stopped(ls));
del_timer_sync(&ls->ls_timer);
while (1) {
rv = wait_event_timeout(ls->ls_wait_general,
testfn(ls) || dlm_recovery_stopped(ls),
dlm_config.ci_recover_timer * HZ);
if (rv)
break;
}

if (dlm_recovery_stopped(ls)) {
log_debug(ls, "dlm_wait_function aborted");
Expand Down

0 comments on commit 6d76817

Please sign in to comment.