The mount(8) manpage lists this as a fs-independent option:
nofail: Do not report errors for this device if it does not exist.
Implement that in mount.cifs by not returning an error if we were unable
to find a suitable address for the mount attempt.
Reported-by: Peter Trenholme <[email protected]>
Signed-off-by: Jeff Layton <[email protected]>
---
mount.cifs.c | 9 ++++++++-
1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/mount.cifs.c b/mount.cifs.c
index 7ee859b..756fce2 100644
--- a/mount.cifs.c
+++ b/mount.cifs.c
@@ -159,6 +159,7 @@
#define OPT_CRUID 29
#define OPT_BKUPUID 30
#define OPT_BKUPGID 31
+#define OPT_NOFAIL 32
#define MNT_TMP_FILE "/.mtab.cifs.XXXXXX"
@@ -178,6 +179,7 @@ struct parsed_mount_info {
unsigned int fakemnt:1;
unsigned int nomtab:1;
unsigned int verboseflag:1;
+ unsigned int nofail:1;
};
const char *thisprogram;
@@ -805,6 +807,8 @@ static int parse_opt_token(const char *token)
return OPT_BKUPUID;
if (strncmp(token, "backupgid", 9) == 0)
return OPT_BKUPGID;
+ if (strncmp(token, "nofail", 6) == 0)
+ return OPT_NOFAIL;
return OPT_ERROR;
}
@@ -1177,6 +1181,9 @@ parse_options(const char *data, struct parsed_mount_info
*parsed_info)
bkupgid = gr->gr_gid;
goto nocopy;
+ case OPT_NOFAIL:
+ parsed_info->nofail = 1;
+ goto nocopy;
}
/* check size before copying option to buffer */
@@ -2119,7 +2126,7 @@ int main(int argc, char **argv)
mount_retry:
if (!currentaddress) {
fprintf(stderr, "Unable to find suitable address.\n");
- rc = EX_FAIL;
+ rc = parsed_info->nofail ? 0 : EX_FAIL;
goto mount_exit;
}
strlcpy(options, "ip=", options_size);
--
1.7.11.4
--
To unsubscribe from this list: send the line "unsubscribe linux-cifs" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html