diff options
| author | Ian Kent <raven@themaw.net> | 2009-01-06 14:42:08 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-01-06 15:59:23 -0800 | 
| commit | a92daf6ba1f9ace8584edc8eb557a77aa7c2c71d (patch) | |
| tree | a4734bb761e762af714710ab53c4b3c3c58516f8 /fs/autofs4/inode.c | |
| parent | 41cfef2eb87694a8d64105c059b39f7bd6b7d4fe (diff) | |
autofs4: make autofs type usage explicit
- the type assigned at mount when no type is given is changed
  from 0 to AUTOFS_TYPE_INDIRECT. This was done because 0 and
  AUTOFS_TYPE_INDIRECT were being treated implicitly as the same
  type.
- previously, an offset mount had it's type set to
  AUTOFS_TYPE_DIRECT|AUTOFS_TYPE_OFFSET but the mount control
  re-implementation needs to be able distinguish all three types.
  So this was changed to make the type setting explicit.
- a type AUTOFS_TYPE_ANY was added for use by the re-implementation
  when checking if a given path is a mountpoint. It's not really a
  type as we use this to ask if a given path is a mountpoint in the
  autofs_dev_ioctl_ismountpoint() function.
- functions to set and test the autofs mount types have been added to
  improve readability and make the type usage explicit.
- the mount type is used from user space for the mount control
  re-implementtion so, for consistency, all the definitions have
  been moved to the user space include file include/linux/auto_fs4.h.
Signed-off-by: Ian Kent <raven@themaw.net>
Signed-off-by: Jeff Moyer <jmoyer@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/autofs4/inode.c')
| -rw-r--r-- | fs/autofs4/inode.c | 14 | 
1 files changed, 7 insertions, 7 deletions
| diff --git a/fs/autofs4/inode.c b/fs/autofs4/inode.c index cfc23e53b6f4..716e12b627b2 100644 --- a/fs/autofs4/inode.c +++ b/fs/autofs4/inode.c @@ -197,9 +197,9 @@ static int autofs4_show_options(struct seq_file *m, struct vfsmount *mnt)  	seq_printf(m, ",minproto=%d", sbi->min_proto);  	seq_printf(m, ",maxproto=%d", sbi->max_proto); -	if (sbi->type & AUTOFS_TYPE_OFFSET) +	if (autofs_type_offset(sbi->type))  		seq_printf(m, ",offset"); -	else if (sbi->type & AUTOFS_TYPE_DIRECT) +	else if (autofs_type_direct(sbi->type))  		seq_printf(m, ",direct");  	else  		seq_printf(m, ",indirect"); @@ -284,13 +284,13 @@ static int parse_options(char *options, int *pipefd, uid_t *uid, gid_t *gid,  			*maxproto = option;  			break;  		case Opt_indirect: -			*type = AUTOFS_TYPE_INDIRECT; +			set_autofs_type_indirect(type);  			break;  		case Opt_direct: -			*type = AUTOFS_TYPE_DIRECT; +			set_autofs_type_direct(type);  			break;  		case Opt_offset: -			*type = AUTOFS_TYPE_OFFSET; +			set_autofs_type_offset(type);  			break;  		default:  			return 1; @@ -338,7 +338,7 @@ int autofs4_fill_super(struct super_block *s, void *data, int silent)  	sbi->sb = s;  	sbi->version = 0;  	sbi->sub_version = 0; -	sbi->type = AUTOFS_TYPE_INDIRECT; +	set_autofs_type_indirect(&sbi->type);  	sbi->min_proto = 0;  	sbi->max_proto = 0;  	mutex_init(&sbi->wq_mutex); @@ -380,7 +380,7 @@ int autofs4_fill_super(struct super_block *s, void *data, int silent)  	}  	root_inode->i_fop = &autofs4_root_operations; -	root_inode->i_op = sbi->type & AUTOFS_TYPE_TRIGGER ? +	root_inode->i_op = autofs_type_trigger(sbi->type) ?  			&autofs4_direct_root_inode_operations :  			&autofs4_indirect_root_inode_operations; | 
