Re: [PATCH] autofs4: Use wait_event_killable

From: Ian Kent
Date: Mon Mar 19 2018 - 22:53:25 EST


On 20/03/18 03:25, David Rientjes wrote:
> On Mon, 19 Mar 2018, Matthew Wilcox wrote:
>
>> diff --git a/fs/autofs4/waitq.c b/fs/autofs4/waitq.c
>> index a0c57c37fa21..c160e9b3aa0f 100644
>> --- a/fs/autofs4/waitq.c
>> +++ b/fs/autofs4/waitq.c
>> @@ -19,9 +19,6 @@
>> */
>> static autofs_wqt_t autofs4_next_wait_queue = 1;
>>
>> -/* These are the signals we allow interrupting a pending mount */
>> -#define SHUTDOWN_SIGS (sigmask(SIGKILL) | sigmask(SIGINT) | sigmask(SIGQUIT))
>> -
>> void autofs4_catatonic_mode(struct autofs_sb_info *sbi)
>> {
>> struct autofs_wait_queue *wq, *nwq;
>> @@ -486,29 +483,7 @@ int autofs4_wait(struct autofs_sb_info *sbi,
>> * wq->name.name is NULL iff the lock is already released
>> * or the mount has been made catatonic.
>> */
>> - if (wq->name.name) {
>> - /* Block all but "shutdown" signals while waiting */
>> - unsigned long shutdown_sigs_mask;
>> - unsigned long irqflags;
>> - sigset_t oldset;
>> -
>> - spin_lock_irqsave(&current->sighand->siglock, irqflags);
>> - oldset = current->blocked;
>> - shutdown_sigs_mask = SHUTDOWN_SIGS & ~oldset.sig[0];
>> - siginitsetinv(&current->blocked, shutdown_sigs_mask);
>> - recalc_sigpending();
>> - spin_unlock_irqrestore(&current->sighand->siglock, irqflags);
>> -
>> - wait_event_interruptible(wq->queue, wq->name.name == NULL);
>> -
>> - spin_lock_irqsave(&current->sighand->siglock, irqflags);
>> - current->blocked = oldset;
>> - recalc_sigpending();
>> - spin_unlock_irqrestore(&current->sighand->siglock, irqflags);
>> - } else {
>> - pr_debug("skipped sleeping\n");
>> - }
>> -
>> + wait_event_killable(wq->queue, wq->name.name == NULL);
>> status = wq->status;
>>
>> /*
>
> I understand converting the wait_event_interruptible() to
> wait_event_killable(), but why was the above wait_event_interruptible()
> only called when wq->name.name != NULL?

The code pre-dates my involvement in autofs too.

I always thought it was because wq->name.name can become NULL before
the wait is reached. Such as if the user space daemon manages to invoke
autofs4_wait_release() before the wait call.

And if the autofs mount is made catatonic before the wait is reached
wq->name.name will be set to NULL and wake up called for each waiter
so that doesn't seem to require the if conditional either.

Both of these cases to fit with what Matthew has already said and I
can't think of any others.

There may have been other reasons at some point, a lot has changed
over (a long) time.

Ian