aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Documentation/filesystems/exofs.txt10
-rw-r--r--fs/exofs/super.c31
2 files changed, 36 insertions, 5 deletions
diff --git a/Documentation/filesystems/exofs.txt b/Documentation/filesystems/exofs.txt
index abd2a9b5b787..23583a136975 100644
--- a/Documentation/filesystems/exofs.txt
+++ b/Documentation/filesystems/exofs.txt
@@ -104,7 +104,15 @@ Where:
104 exofs specific options: Options are separated by commas (,) 104 exofs specific options: Options are separated by commas (,)
105 pid=<integer> - The partition number to mount/create as 105 pid=<integer> - The partition number to mount/create as
106 container of the filesystem. 106 container of the filesystem.
107 This option is mandatory. 107 This option is mandatory. integer can be
108 Hex by pre-pending an 0x to the number.
109 osdname=<id> - Mount by a device's osdname.
110 osdname is usually a 36 character uuid of the
111 form "d2683732-c906-4ee1-9dbd-c10c27bb40df".
112 It is one of the device's uuid specified in the
113 mkfs.exofs format command.
114 If this option is specified then the /dev/osdX
115 above can be empty and is ignored.
108 to=<integer> - Timeout in ticks for a single command. 116 to=<integer> - Timeout in ticks for a single command.
109 default is (60 * HZ) [for debugging only] 117 default is (60 * HZ) [for debugging only]
110 118
diff --git a/fs/exofs/super.c b/fs/exofs/super.c
index e87510f4749e..474989eeb7d6 100644
--- a/fs/exofs/super.c
+++ b/fs/exofs/super.c
@@ -48,6 +48,7 @@
48 * struct to hold what we get from mount options 48 * struct to hold what we get from mount options
49 */ 49 */
50struct exofs_mountopt { 50struct exofs_mountopt {
51 bool is_osdname;
51 const char *dev_name; 52 const char *dev_name;
52 uint64_t pid; 53 uint64_t pid;
53 int timeout; 54 int timeout;
@@ -56,7 +57,7 @@ struct exofs_mountopt {
56/* 57/*
57 * exofs-specific mount-time options. 58 * exofs-specific mount-time options.
58 */ 59 */
59enum { Opt_pid, Opt_to, Opt_mkfs, Opt_format, Opt_err }; 60enum { Opt_name, Opt_pid, Opt_to, Opt_err };
60 61
61/* 62/*
62 * Our mount-time options. These should ideally be 64-bit unsigned, but the 63 * Our mount-time options. These should ideally be 64-bit unsigned, but the
@@ -64,6 +65,7 @@ enum { Opt_pid, Opt_to, Opt_mkfs, Opt_format, Opt_err };
64 * sufficient for most applications now. 65 * sufficient for most applications now.
65 */ 66 */
66static match_table_t tokens = { 67static match_table_t tokens = {
68 {Opt_name, "osdname=%s"},
67 {Opt_pid, "pid=%u"}, 69 {Opt_pid, "pid=%u"},
68 {Opt_to, "to=%u"}, 70 {Opt_to, "to=%u"},
69 {Opt_err, NULL} 71 {Opt_err, NULL}
@@ -94,6 +96,14 @@ static int parse_options(char *options, struct exofs_mountopt *opts)
94 96
95 token = match_token(p, tokens, args); 97 token = match_token(p, tokens, args);
96 switch (token) { 98 switch (token) {
99 case Opt_name:
100 opts->dev_name = match_strdup(&args[0]);
101 if (unlikely(!opts->dev_name)) {
102 EXOFS_ERR("Error allocating dev_name");
103 return -ENOMEM;
104 }
105 opts->is_osdname = true;
106 break;
97 case Opt_pid: 107 case Opt_pid:
98 if (0 == match_strlcpy(str, &args[0], sizeof(str))) 108 if (0 == match_strlcpy(str, &args[0], sizeof(str)))
99 return -EINVAL; 109 return -EINVAL;
@@ -575,9 +585,17 @@ static int exofs_fill_super(struct super_block *sb, void *data, int silent)
575 goto free_bdi; 585 goto free_bdi;
576 586
577 /* use mount options to fill superblock */ 587 /* use mount options to fill superblock */
578 od = osduld_path_lookup(opts->dev_name); 588 if (opts->is_osdname) {
589 struct osd_dev_info odi = {.systemid_len = 0};
590
591 odi.osdname_len = strlen(opts->dev_name);
592 odi.osdname = (u8 *)opts->dev_name;
593 od = osduld_info_lookup(&odi);
594 } else {
595 od = osduld_path_lookup(opts->dev_name);
596 }
579 if (IS_ERR(od)) { 597 if (IS_ERR(od)) {
580 ret = PTR_ERR(od); 598 ret = -EINVAL;
581 goto free_sbi; 599 goto free_sbi;
582 } 600 }
583 601
@@ -670,6 +688,8 @@ static int exofs_fill_super(struct super_block *sb, void *data, int silent)
670 688
671 _exofs_print_device("Mounting", opts->dev_name, sbi->layout.s_ods[0], 689 _exofs_print_device("Mounting", opts->dev_name, sbi->layout.s_ods[0],
672 sbi->layout.s_pid); 690 sbi->layout.s_pid);
691 if (opts->is_osdname)
692 kfree(opts->dev_name);
673 return 0; 693 return 0;
674 694
675free_sbi: 695free_sbi:
@@ -678,6 +698,8 @@ free_bdi:
678 EXOFS_ERR("Unable to mount exofs on %s pid=0x%llx err=%d\n", 698 EXOFS_ERR("Unable to mount exofs on %s pid=0x%llx err=%d\n",
679 opts->dev_name, sbi->layout.s_pid, ret); 699 opts->dev_name, sbi->layout.s_pid, ret);
680 exofs_free_sbi(sbi); 700 exofs_free_sbi(sbi);
701 if (opts->is_osdname)
702 kfree(opts->dev_name);
681 return ret; 703 return ret;
682} 704}
683 705
@@ -695,7 +717,8 @@ static struct dentry *exofs_mount(struct file_system_type *type,
695 if (ret) 717 if (ret)
696 return ERR_PTR(ret); 718 return ERR_PTR(ret);
697 719
698 opts.dev_name = dev_name; 720 if (!opts.dev_name)
721 opts.dev_name = dev_name;
699 return mount_nodev(type, flags, &opts, exofs_fill_super); 722 return mount_nodev(type, flags, &opts, exofs_fill_super);
700} 723}
701 724