From mboxrd@z Thu Jan 1 00:00:00 1970 From: raven@themaw.net Subject: [PATCH 1/3] autofs4 - expiring filesystem from under process Date: Sun, 10 Apr 2005 20:48:34 +0800 (WST) Message-ID: Mime-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: autofs mailing list , Michael Blandford , linux-fsdevel , Jeff Moyer Return-path: Received: from wombat.indigo.net.au ([202.0.185.19]:522 "EHLO wombat.indigo.net.au") by vger.kernel.org with ESMTP id S261488AbVDJMtC (ORCPT ); Sun, 10 Apr 2005 08:49:02 -0400 To: Andrew Morton Sender: linux-fsdevel-owner@vger.kernel.org List-Id: linux-fsdevel.vger.kernel.org autofs4-2.6.12-rc1-mm4-wait-order.patch It's possible for an event wait request to arive before the event requestor. If this happens the daemon never gets notified and autofs hangs. Signed-off-by: Ian Kent --- linux-2.6.12-rc1-mm4/fs/autofs4/waitq.c.wait-order 2005-04-03 12:30:14.000000000 +0800 +++ linux-2.6.12-rc1-mm4/fs/autofs4/waitq.c 2005-04-03 12:31:57.000000000 +0800 @@ -210,17 +210,8 @@ int autofs4_wait(struct autofs_sb_info * wq->len = len; wq->status = -EINTR; /* Status return if interrupted */ atomic_set(&wq->wait_ctr, 2); + atomic_set(&wq->notified, 1); up(&sbi->wq_sem); - - DPRINTK("new wait id = 0x%08lx, name = %.*s, nfy=%d", - (unsigned long) wq->wait_queue_token, wq->len, wq->name, notify); - /* autofs4_notify_daemon() may block */ - if (notify != NFY_NONE) { - autofs4_notify_daemon(sbi,wq, - notify == NFY_MOUNT ? - autofs_ptype_missing : - autofs_ptype_expire_multi); - } } else { atomic_inc(&wq->wait_ctr); up(&sbi->wq_sem); @@ -229,6 +220,17 @@ int autofs4_wait(struct autofs_sb_info * (unsigned long) wq->wait_queue_token, wq->len, wq->name, notify); } + if (notify != NFY_NONE && atomic_dec_and_test(&wq->notified)) { + int type = (notify == NFY_MOUNT ? + autofs_ptype_missing : autofs_ptype_expire_multi); + + DPRINTK(("new wait id = 0x%08lx, name = %.*s, nfy=%d\n", + (unsigned long) wq->wait_queue_token, wq->len, wq->name, notify)); + + /* autofs4_notify_daemon() may block */ + autofs4_notify_daemon(sbi, wq, type); + } + /* wq->name is NULL if and only if the lock is already released */ if ( sbi->catatonic ) { --- linux-2.6.12-rc1-mm4/fs/autofs4/autofs_i.h.wait-order 2005-04-03 12:30:24.000000000 +0800 +++ linux-2.6.12-rc1-mm4/fs/autofs4/autofs_i.h 2005-04-03 12:30:46.000000000 +0800 @@ -84,6 +84,7 @@ struct autofs_wait_queue { char *name; /* This is for status reporting upon return */ int status; + atomic_t notified; atomic_t wait_ctr; };