diff options
author | obrien <obrien@FreeBSD.org> | 2009-01-12 08:22:36 +0000 |
---|---|---|
committer | obrien <obrien@FreeBSD.org> | 2009-01-12 08:22:36 +0000 |
commit | c9e59ec6fa825d5d93c9929e20f76b414e42e005 (patch) | |
tree | 4a41321877f0b9f004fa0093cd50fba639564dee /sbin/mount | |
parent | ff24caf9b390a09d1c465a98ce24cd7c0ef1ef98 (diff) | |
download | FreeBSD-src-c9e59ec6fa825d5d93c9929e20f76b414e42e005.zip FreeBSD-src-c9e59ec6fa825d5d93c9929e20f76b414e42e005.tar.gz |
Use a dynamically grown buffer for building the argv for the sub-mounts.
Also fix RCSid spamage.
Inspired by patch from: Christoph Mallon <christoph.mallon@gmx.de>
Diffstat (limited to 'sbin/mount')
-rw-r--r-- | sbin/mount/mount.c | 27 |
1 files changed, 16 insertions, 11 deletions
diff --git a/sbin/mount/mount.c b/sbin/mount/mount.c index 56f01d8..47b355c 100644 --- a/sbin/mount/mount.c +++ b/sbin/mount/mount.c @@ -31,16 +31,14 @@ static const char copyright[] = "@(#) Copyright (c) 1980, 1989, 1993, 1994\n\ The Regents of the University of California. All rights reserved.\n"; -#endif /* not lint */ - -#ifndef lint #if 0 static char sccsid[] = "@(#)mount.c 8.25 (Berkeley) 5/8/95"; #endif -static const char rcsid[] = - "$FreeBSD$"; #endif /* not lint */ +#include <sys/cdefs.h> +__FBSDID("$FreeBSD$"); + #include <sys/param.h> #include <sys/mount.h> #include <sys/stat.h> @@ -70,10 +68,8 @@ static const char rcsid[] = int debug, fstab_style, verbose; -#define MAX_ARGS 100 struct cpa { - char *a[MAX_ARGS]; - ssize_t m; + char **a; int c; }; @@ -507,9 +503,14 @@ hasopt(const char *mntopts, const char *option) static void append_arg(struct cpa *sa, char *arg) { - if (sa->c >= sa->m) - errx(1, "Cannot process more than %zd mount arguments", sa->m); + static int a_sz; + if (sa->c + 1 == a_sz) { + a_sz = a_sz == 0 ? 8 : a_sz * 2; + sa->a = realloc(sa->a, sizeof(sa->a) * a_sz); + if (sa->a == NULL) + errx(1, "realloc failed"); + } sa->a[++sa->c] = arg; } @@ -521,6 +522,7 @@ mountfs(const char *vfstype, const char *spec, const char *name, int flags, struct statfs sf; int i, ret; char *optbuf, execname[PATH_MAX], mntpath[PATH_MAX]; + static int mnt_argv_inited; /* resolve the mountpoint with realpath(3) */ (void)checkpath(name, mntpath); @@ -555,7 +557,10 @@ mountfs(const char *vfstype, const char *spec, const char *name, int flags, /* Construct the name of the appropriate mount command */ (void)snprintf(execname, sizeof(execname), "mount_%s", vfstype); - mnt_argv.m = MAX_ARGS; + if (!mnt_argv_inited) { + mnt_argv_inited++; + mnt_argv.a = NULL; + } mnt_argv.c = -1; append_arg(&mnt_argv, execname); mangle(optbuf, &mnt_argv); |