mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-06-24 23:52:40 +00:00
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>
This commit is contained in:
parent
41cfef2eb8
commit
a92daf6ba1
6 changed files with 73 additions and 21 deletions
|
@ -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;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue