1. NAME

journal_lock_updates - establish a transaction barrier.

2. SYNOPSIS

void journal_lock_updates(journal_t *  journal );

3. ARGUMENTS

journal
    Journal to establish a barrier on.

4. DESCRIPTION

This locks out any further updates from being started, and blocks until all existing updates have completed, returning only once the journal is in a quiescent state with no updates running.

We do not use simple mutex for synchronization as there are syscalls which want to return with filesystem locked and that trips up lockdep. Also hibernate needs to lock filesystem but locked mutex then blocks hibernation. Since locking filesystem is rare operation, we use simple counter and waitqueue for locking.

5. AUTHORS

Roger Gammans <>
    Author.

Stephen Tweedie <>
    Author.

6. COPYRIGHT