diff options
author | Ian Kent <raven@themaw.net> | 2009-01-06 17:42:08 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-01-06 18:59:23 -0500 |
commit | a92daf6ba1f9ace8584edc8eb557a77aa7c2c71d (patch) | |
tree | a4734bb761e762af714710ab53c4b3c3c58516f8 /fs/autofs4/dev-ioctl.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/dev-ioctl.c')
-rw-r--r-- | fs/autofs4/dev-ioctl.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/autofs4/dev-ioctl.c b/fs/autofs4/dev-ioctl.c index 0566ff8db4cd..aa3f47293bb8 100644 --- a/fs/autofs4/dev-ioctl.c +++ b/fs/autofs4/dev-ioctl.c | |||
@@ -532,7 +532,7 @@ static int autofs_dev_ioctl_expire(struct file *fp, | |||
532 | how = param->expire.how; | 532 | how = param->expire.how; |
533 | mnt = fp->f_path.mnt; | 533 | mnt = fp->f_path.mnt; |
534 | 534 | ||
535 | if (sbi->type & AUTOFS_TYPE_TRIGGER) | 535 | if (autofs_type_trigger(sbi->type)) |
536 | dentry = autofs4_expire_direct(sbi->sb, mnt, sbi, how); | 536 | dentry = autofs4_expire_direct(sbi->sb, mnt, sbi, how); |
537 | else | 537 | else |
538 | dentry = autofs4_expire_indirect(sbi->sb, mnt, sbi, how); | 538 | dentry = autofs4_expire_indirect(sbi->sb, mnt, sbi, how); |
@@ -615,7 +615,7 @@ static int autofs_dev_ioctl_ismountpoint(struct file *fp, | |||
615 | param->ismountpoint.out.magic = magic = 0; | 615 | param->ismountpoint.out.magic = magic = 0; |
616 | 616 | ||
617 | if (!fp || param->ioctlfd == -1) { | 617 | if (!fp || param->ioctlfd == -1) { |
618 | if (type == AUTOFS_TYPE_ANY) { | 618 | if (autofs_type_any(type)) { |
619 | struct super_block *sb; | 619 | struct super_block *sb; |
620 | 620 | ||
621 | err = path_lookup(path, LOOKUP_FOLLOW, &nd); | 621 | err = path_lookup(path, LOOKUP_FOLLOW, &nd); |