Blame SOURCES/autofs-5.0.9-amd-lookup-add-lofs-ext-and-xfs-fs-types.patch

4d476f
autofs-5.0.9 - amd lookup add fs types lofs, ext, and xfs
4d476f
4d476f
From: Ian Kent <raven@themaw.net>
4d476f
4d476f
4d476f
---
4d476f
 include/parse_amd.h |    9 +++++++++
4d476f
 modules/amd_parse.y |   13 +++++++++++++
4d476f
 modules/amd_tok.l   |    4 +++-
4d476f
 modules/parse_amd.c |   50 ++++++++++++++++++++++++++++++++++++++++++++++++++
4d476f
 4 files changed, 75 insertions(+), 1 deletion(-)
4d476f
4d476f
diff --git a/include/parse_amd.h b/include/parse_amd.h
4d476f
index a8521b5..4015e9f 100644
4d476f
--- a/include/parse_amd.h
4d476f
+++ b/include/parse_amd.h
4d476f
@@ -20,6 +20,14 @@
4d476f
 #define AMD_MOUNT_TYPE_NFS	0x00000002
4d476f
 #define AMD_MOUNT_TYPE_LINK	0x00000004
4d476f
 #define AMD_MOUNT_TYPE_HOST	0x00000008
4d476f
+#define AMD_MOUNT_TYPE_NFSL	0x00000010
4d476f
+#define AMD_MOUNT_TYPE_NFSX	0x00000020
4d476f
+#define AMD_MOUNT_TYPE_LINKX	0x00000040
4d476f
+#define AMD_MOUNT_TYPE_LOFS	0x00000080
4d476f
+#define AMD_MOUNT_TYPE_EXT	0x00000100
4d476f
+#define AMD_MOUNT_TYPE_XFS	0x00000200
4d476f
+#define AMD_MOUNT_TYPE_JFS	0x00000400
4d476f
+#define AMD_MOUNT_TYPE_CACHEFS	0x00000800
4d476f
 #define AMD_MOUNT_TYPE_MASK	0x0000ffff
4d476f
 
4d476f
 #define AMD_ENTRY_CUT		0x00010000
4d476f
@@ -38,6 +46,7 @@ struct amd_entry {
4d476f
 	char *fs;
4d476f
 	char *rhost;
4d476f
 	char *rfs;
4d476f
+	char *dev;
4d476f
 	char *opts;
4d476f
 	char *addopts;
4d476f
 	char *remopts;
4d476f
diff --git a/modules/amd_parse.y b/modules/amd_parse.y
4d476f
index 71fd569..cd69c49 100644
4d476f
--- a/modules/amd_parse.y
4d476f
+++ b/modules/amd_parse.y
4d476f
@@ -248,6 +248,17 @@ option_assignment: MAP_OPTION OPTION_ASSIGN FS_TYPE
4d476f
 		} else if (!strcmp($3, "host")) {
4d476f
 			entry.flags |= AMD_MOUNT_TYPE_HOST;
4d476f
 			entry.type = amd_strdup($3);
4d476f
+		} else if (!strcmp($3, "lofs")) {
4d476f
+			entry.flags |= AMD_MOUNT_TYPE_LOFS;
4d476f
+			entry.type = amd_strdup("bind");
4d476f
+		} else if (!strcmp($3, "xfs")) {
4d476f
+			entry.flags |= AMD_MOUNT_TYPE_XFS;
4d476f
+			entry.type = amd_strdup($3);
4d476f
+		} else if (!strcmp($3, "ext2") ||
4d476f
+			   !strcmp($3, "ext3") ||
4d476f
+			   !strcmp($3, "ext4")) {
4d476f
+			entry.flags |= AMD_MOUNT_TYPE_EXT;
4d476f
+			entry.type = amd_strdup($3);
4d476f
 		} else {
4d476f
 			amd_notify($1);
4d476f
 			YYABORT;
4d476f
@@ -291,6 +302,8 @@ option_assignment: MAP_OPTION OPTION_ASSIGN FS_TYPE
4d476f
 			entry.rhost = amd_strdup($3);
4d476f
 		else if (!strcmp($1, "rfs"))
4d476f
 			entry.rfs = amd_strdup($3);
4d476f
+		else if (!strcmp($1, "dev"))
4d476f
+			entry.dev = amd_strdup($3);
4d476f
 		else {
4d476f
 			amd_notify($1);
4d476f
 			YYABORT;
4d476f
diff --git a/modules/amd_tok.l b/modules/amd_tok.l
4d476f
index cea9ea5..fdc8899 100644
4d476f
--- a/modules/amd_tok.l
4d476f
+++ b/modules/amd_tok.l
4d476f
@@ -98,7 +98,9 @@ MAPOPT		(fs|type|maptype|pref|sublink|delay)
4d476f
 MNTOPT		(opts|addopts|remopts)
4d476f
 FSOPTS		(rhost|rfs|dev|cachedir)
4d476f
 MAPTYPE		(file|nis|nisplus|ldap|hesiod|exec|ndbm|passwd|union)
4d476f
-FSTYPE		(auto|nfs|link|host|nfsx|ufs|xfs|efs)
4d476f
+FSTYPE_LOCAL	(link|linkx|lofs|ext2|ext3|ext4|xfs|jfs|cachefs)
4d476f
+FSTYPE_NET	(nfs|nfsx|nfsl|host)
4d476f
+FSTYPE		(auto|program|direct|{FSTYPE_LOCAL}|{FSTYPE_NET})
4d476f
 
4d476f
 OSSEL		(arch|karch|os|osver|full_os|vendor)
4d476f
 HSTSEL		(host|hostd|domain|byte|cluster)
4d476f
diff --git a/modules/parse_amd.c b/modules/parse_amd.c
4d476f
index 4322479..e27a195 100644
4d476f
--- a/modules/parse_amd.c
4d476f
+++ b/modules/parse_amd.c
4d476f
@@ -598,6 +598,12 @@ static void update_with_defaults(struct amd_entry *defaults,
4d476f
 		}
4d476f
 	}
4d476f
 
4d476f
+	if (!entry->dev && defaults->dev) {
4d476f
+		tmp = strdup(defaults->dev);
4d476f
+		if (tmp)
4d476f
+			entry->dev = tmp;
4d476f
+	}
4d476f
+
4d476f
 	if (!entry->opts && defaults->opts) {
4d476f
 		tmp = merge_options(defaults->opts, entry->opts);
4d476f
 		if (tmp)
4d476f
@@ -949,6 +955,35 @@ out:
4d476f
 	return ret;
4d476f
 }
4d476f
 
4d476f
+static int do_generic_mount(struct autofs_point *ap, const char *name,
4d476f
+			    struct amd_entry *entry, const char *target,
4d476f
+			    unsigned int flags)
4d476f
+{
4d476f
+	int ret = 0;
4d476f
+
4d476f
+	if (!entry->sublink) {
4d476f
+		ret = do_mount(ap, ap->path, name, strlen(name),
4d476f
+			       target, entry->type, entry->opts);
4d476f
+	} else {
4d476f
+		/*
4d476f
+		 * Careful, external mounts may get mounted
4d476f
+		 * multiple times since they are outside of
4d476f
+		 * the automount filesystem.
4d476f
+		 */
4d476f
+		if (!is_mounted(_PATH_MOUNTED, entry->fs, MNTS_REAL)) {
4d476f
+			ret = do_mount(ap, entry->fs, "/", 1,
4d476f
+				       target, entry->type, entry->opts);
4d476f
+			if (ret)
4d476f
+				goto out;
4d476f
+		}
4d476f
+		/* We might be using an external mount */
4d476f
+		ext_mount_add(&entry->ext_mount, entry->fs);
4d476f
+		ret = do_link_mount(ap, name, entry, flags);
4d476f
+	}
4d476f
+out:
4d476f
+	return ret;
4d476f
+}
4d476f
+
4d476f
 static int do_nfs_mount(struct autofs_point *ap, const char *name,
4d476f
 			struct amd_entry *entry, unsigned int flags)
4d476f
 {
4d476f
@@ -1024,6 +1059,15 @@ static int amd_mount(struct autofs_point *ap, const char *name,
4d476f
 		ret = do_auto_mount(ap, name, entry, flags);
4d476f
 		break;
4d476f
 
4d476f
+	case AMD_MOUNT_TYPE_LOFS:
4d476f
+		ret = do_generic_mount(ap, name, entry, entry->rfs, flags);
4d476f
+		break;
4d476f
+
4d476f
+	case AMD_MOUNT_TYPE_EXT:
4d476f
+	case AMD_MOUNT_TYPE_XFS:
4d476f
+		ret = do_generic_mount(ap, name, entry, entry->dev, flags);
4d476f
+		break;
4d476f
+
4d476f
 	case AMD_MOUNT_TYPE_NFS:
4d476f
 		ret = do_nfs_mount(ap, name, entry, flags);
4d476f
 		break;
4d476f
@@ -1260,6 +1304,12 @@ static struct amd_entry *dup_defaults_entry(struct amd_entry *defaults)
4d476f
 			entry->rhost = tmp;
4d476f
 	}
4d476f
 
4d476f
+	if (defaults->dev) {
4d476f
+		tmp = strdup(defaults->dev);
4d476f
+		if (tmp)
4d476f
+			entry->dev = tmp;
4d476f
+	}
4d476f
+
4d476f
 	if (defaults->opts) {
4d476f
 		tmp = strdup(defaults->opts);
4d476f
 		if (tmp)