diff options
Diffstat (limited to 'fs/autofs4/waitq.c')
| -rw-r--r-- | fs/autofs4/waitq.c | 78 | 
1 files changed, 42 insertions, 36 deletions
| diff --git a/fs/autofs4/waitq.c b/fs/autofs4/waitq.c index 35b755e79c2d..0146d911f468 100644 --- a/fs/autofs4/waitq.c +++ b/fs/autofs4/waitq.c @@ -1,15 +1,11 @@ -/* -*- c -*- --------------------------------------------------------------- * - * - * linux/fs/autofs/waitq.c - * - *  Copyright 1997-1998 Transmeta Corporation -- All Rights Reserved - *  Copyright 2001-2006 Ian Kent <raven@themaw.net> +/* + * Copyright 1997-1998 Transmeta Corporation -- All Rights Reserved + * Copyright 2001-2006 Ian Kent <raven@themaw.net>   *   * This file is part of the Linux kernel and is made available under   * the terms of the GNU General Public License, version 2, or at your   * option, any later version, incorporated herein by reference. - * - * ------------------------------------------------------------------------- */ + */  #include <linux/slab.h>  #include <linux/time.h> @@ -18,7 +14,8 @@  #include "autofs_i.h"  /* We make this a static variable rather than a part of the superblock; it -   is better if we don't reassign numbers easily even across filesystems */ + * is better if we don't reassign numbers easily even across filesystems + */  static autofs_wqt_t autofs4_next_wait_queue = 1;  /* These are the signals we allow interrupting a pending mount */ @@ -34,7 +31,7 @@ void autofs4_catatonic_mode(struct autofs_sb_info *sbi)  		return;  	} -	DPRINTK("entering catatonic mode"); +	pr_debug("entering catatonic mode\n");  	sbi->catatonic = 1;  	wq = sbi->queues; @@ -69,17 +66,19 @@ static int autofs4_write(struct autofs_sb_info *sbi,  	set_fs(KERNEL_DS);  	mutex_lock(&sbi->pipe_mutex); -	while (bytes && -	       (wr = __vfs_write(file,data,bytes,&file->f_pos)) > 0) { +	wr = __vfs_write(file, data, bytes, &file->f_pos); +	while (bytes && wr) {  		data += wr;  		bytes -= wr; +		wr = __vfs_write(file, data, bytes, &file->f_pos);  	}  	mutex_unlock(&sbi->pipe_mutex);  	set_fs(fs);  	/* Keep the currently executing process from receiving a -	   SIGPIPE unless it was already supposed to get one */ +	 * SIGPIPE unless it was already supposed to get one +	 */  	if (wr == -EPIPE && !sigpipe) {  		spin_lock_irqsave(¤t->sighand->siglock, flags);  		sigdelset(¤t->pending.signal, SIGPIPE); @@ -89,7 +88,7 @@ static int autofs4_write(struct autofs_sb_info *sbi,  	return (bytes > 0);  } -	 +  static void autofs4_notify_daemon(struct autofs_sb_info *sbi,  				 struct autofs_wait_queue *wq,  				 int type) @@ -102,10 +101,11 @@ static void autofs4_notify_daemon(struct autofs_sb_info *sbi,  	struct file *pipe = NULL;  	size_t pktsz; -	DPRINTK("wait id = 0x%08lx, name = %.*s, type=%d", -		(unsigned long) wq->wait_queue_token, wq->name.len, wq->name.name, type); +	pr_debug("wait id = 0x%08lx, name = %.*s, type=%d\n", +		 (unsigned long) wq->wait_queue_token, +		 wq->name.len, wq->name.name, type); -	memset(&pkt,0,sizeof pkt); /* For security reasons */ +	memset(&pkt, 0, sizeof(pkt)); /* For security reasons */  	pkt.hdr.proto_version = sbi->version;  	pkt.hdr.type = type; @@ -126,7 +126,8 @@ static void autofs4_notify_daemon(struct autofs_sb_info *sbi,  	}  	case autofs_ptype_expire_multi:  	{ -		struct autofs_packet_expire_multi *ep = &pkt.v4_pkt.expire_multi; +		struct autofs_packet_expire_multi *ep = +					&pkt.v4_pkt.expire_multi;  		pktsz = sizeof(*ep); @@ -163,7 +164,7 @@ static void autofs4_notify_daemon(struct autofs_sb_info *sbi,  		break;  	}  	default: -		printk("autofs4_notify_daemon: bad type %d!\n", type); +		pr_warn("bad type %d!\n", type);  		mutex_unlock(&sbi->wq_mutex);  		return;  	} @@ -231,7 +232,7 @@ autofs4_find_wait(struct autofs_sb_info *sbi, struct qstr *qstr)  		if (wq->name.hash == qstr->hash &&  		    wq->name.len == qstr->len &&  		    wq->name.name && -			 !memcmp(wq->name.name, qstr->name, qstr->len)) +		    !memcmp(wq->name.name, qstr->name, qstr->len))  			break;  	}  	return wq; @@ -248,7 +249,7 @@ autofs4_find_wait(struct autofs_sb_info *sbi, struct qstr *qstr)  static int validate_request(struct autofs_wait_queue **wait,  			    struct autofs_sb_info *sbi,  			    struct qstr *qstr, -			    struct dentry*dentry, enum autofs_notify notify) +			    struct dentry *dentry, enum autofs_notify notify)  {  	struct autofs_wait_queue *wq;  	struct autofs_info *ino; @@ -322,8 +323,10 @@ static int validate_request(struct autofs_wait_queue **wait,  		 * continue on and create a new request.  		 */  		if (!IS_ROOT(dentry)) { -			if (d_really_is_positive(dentry) && d_unhashed(dentry)) { +			if (d_unhashed(dentry) && +			    d_really_is_positive(dentry)) {  				struct dentry *parent = dentry->d_parent; +  				new = d_lookup(parent, &dentry->d_name);  				if (new)  					dentry = new; @@ -340,8 +343,8 @@ static int validate_request(struct autofs_wait_queue **wait,  	return 1;  } -int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry, -		enum autofs_notify notify) +int autofs4_wait(struct autofs_sb_info *sbi, +		 struct dentry *dentry, enum autofs_notify notify)  {  	struct autofs_wait_queue *wq;  	struct qstr qstr; @@ -411,7 +414,7 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,  	if (!wq) {  		/* Create a new wait queue */ -		wq = kmalloc(sizeof(struct autofs_wait_queue),GFP_KERNEL); +		wq = kmalloc(sizeof(struct autofs_wait_queue), GFP_KERNEL);  		if (!wq) {  			kfree(qstr.name);  			mutex_unlock(&sbi->wq_mutex); @@ -450,17 +453,19 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,  					autofs_ptype_expire_indirect;  		} -		DPRINTK("new wait id = 0x%08lx, name = %.*s, nfy=%d\n", -			(unsigned long) wq->wait_queue_token, wq->name.len, -			wq->name.name, notify); +		pr_debug("new wait id = 0x%08lx, name = %.*s, nfy=%d\n", +			 (unsigned long) wq->wait_queue_token, wq->name.len, +			 wq->name.name, notify); -		/* autofs4_notify_daemon() may block; it will unlock ->wq_mutex */ +		/* +		 * autofs4_notify_daemon() may block; it will unlock ->wq_mutex +		 */  		autofs4_notify_daemon(sbi, wq, type);  	} else {  		wq->wait_ctr++; -		DPRINTK("existing wait id = 0x%08lx, name = %.*s, nfy=%d", -			(unsigned long) wq->wait_queue_token, wq->name.len, -			wq->name.name, notify); +		pr_debug("existing wait id = 0x%08lx, name = %.*s, nfy=%d\n", +			 (unsigned long) wq->wait_queue_token, wq->name.len, +			 wq->name.name, notify);  		mutex_unlock(&sbi->wq_mutex);  		kfree(qstr.name);  	} @@ -471,12 +476,14 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,  	 */  	if (wq->name.name) {  		/* Block all but "shutdown" signals while waiting */ -		sigset_t oldset; +		unsigned long shutdown_sigs_mask;  		unsigned long irqflags; +		sigset_t oldset;  		spin_lock_irqsave(¤t->sighand->siglock, irqflags);  		oldset = current->blocked; -		siginitsetinv(¤t->blocked, SHUTDOWN_SIGS & ~oldset.sig[0]); +		shutdown_sigs_mask = SHUTDOWN_SIGS & ~oldset.sig[0]; +		siginitsetinv(¤t->blocked, shutdown_sigs_mask);  		recalc_sigpending();  		spin_unlock_irqrestore(¤t->sighand->siglock, irqflags); @@ -487,7 +494,7 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,  		recalc_sigpending();  		spin_unlock_irqrestore(¤t->sighand->siglock, irqflags);  	} else { -		DPRINTK("skipped sleeping"); +		pr_debug("skipped sleeping\n");  	}  	status = wq->status; @@ -562,4 +569,3 @@ int autofs4_wait_release(struct autofs_sb_info *sbi, autofs_wqt_t wait_queue_tok  	return 0;  } - | 
