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:
@ -337,7 +337,7 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,
|
||||
* is very similar for indirect mounts except only dentrys
|
||||
* in the root of the autofs file system may be negative.
|
||||
*/
|
||||
if (sbi->type & AUTOFS_TYPE_TRIGGER)
|
||||
if (autofs_type_trigger(sbi->type))
|
||||
return -ENOENT;
|
||||
else if (!IS_ROOT(dentry->d_parent))
|
||||
return -ENOENT;
|
||||
@ -348,7 +348,7 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,
|
||||
return -ENOMEM;
|
||||
|
||||
/* If this is a direct mount request create a dummy name */
|
||||
if (IS_ROOT(dentry) && sbi->type & AUTOFS_TYPE_TRIGGER)
|
||||
if (IS_ROOT(dentry) && autofs_type_trigger(sbi->type))
|
||||
qstr.len = sprintf(name, "%p", dentry);
|
||||
else {
|
||||
qstr.len = autofs4_getpath(sbi, dentry, &name);
|
||||
@ -406,11 +406,11 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry,
|
||||
type = autofs_ptype_expire_multi;
|
||||
} else {
|
||||
if (notify == NFY_MOUNT)
|
||||
type = (sbi->type & AUTOFS_TYPE_TRIGGER) ?
|
||||
type = autofs_type_trigger(sbi->type) ?
|
||||
autofs_ptype_missing_direct :
|
||||
autofs_ptype_missing_indirect;
|
||||
else
|
||||
type = (sbi->type & AUTOFS_TYPE_TRIGGER) ?
|
||||
type = autofs_type_trigger(sbi->type) ?
|
||||
autofs_ptype_expire_direct :
|
||||
autofs_ptype_expire_indirect;
|
||||
}
|
||||
|
Reference in New Issue
Block a user