summaryrefslogtreecommitdiffstats
path: root/sbin/mount_cd9660
diff options
context:
space:
mode:
authorphk <phk@FreeBSD.org>1999-10-09 11:54:14 +0000
committerphk <phk@FreeBSD.org>1999-10-09 11:54:14 +0000
commit41c4f3920e76ddd3b3a183fc18e6e0834a26086b (patch)
tree90d36f2866e2e9c8c9fe890230d8240ed54253f1 /sbin/mount_cd9660
parent977cb3153eec3286210df53421e8494748c21d3a (diff)
downloadFreeBSD-src-41c4f3920e76ddd3b3a183fc18e6e0834a26086b.zip
FreeBSD-src-41c4f3920e76ddd3b3a183fc18e6e0834a26086b.tar.gz
mount* fixes from Martin Blapp <mb@imp.ch>:
Made mount more userfriendly (bad slashes are now filtered out) and we remove in mount_nfs trailing slashes if there are any. Fixed mount_xxx binarys to resolve with realpath(3) the mountpoint. Translate the deprecated nfs-syntax with '@' to ':' . The ':' syntax has now precedence, but '@' still works. Notify the user that the '@' syntax should not be used. PR: 7846 PR: 13692 Submitted by: Martin Blapp <mb@imp.ch> Reviewed by: phk
Diffstat (limited to 'sbin/mount_cd9660')
-rw-r--r--sbin/mount_cd9660/mount_cd9660.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/sbin/mount_cd9660/mount_cd9660.c b/sbin/mount_cd9660/mount_cd9660.c
index a3185d7..665d22f 100644
--- a/sbin/mount_cd9660/mount_cd9660.c
+++ b/sbin/mount_cd9660/mount_cd9660.c
@@ -85,7 +85,7 @@ main(int argc, char **argv)
{
struct iso_args args;
int ch, mntflags, opts;
- char *dev, *dir;
+ char *dev, *dir, mntpath[MAXPATHLEN];
struct vfsconf vfc;
int error, verbose;
@@ -128,6 +128,13 @@ main(int argc, char **argv)
dev = argv[0];
dir = argv[1];
+ /*
+ * Resolve the mountpoint with realpath(3) and remove unnecessary
+ * slashes from the devicename if there are any.
+ */
+ (void)checkpath(dir, mntpath);
+ (void)rmslashes(dev, dev);
+
#define DEFAULT_ROOTUID -2
/*
* ISO 9660 filesystems are not writeable.
@@ -168,7 +175,7 @@ main(int argc, char **argv)
if (error)
errx(1, "cd9660 filesystem is not available");
- if (mount(vfc.vfc_name, dir, mntflags, &args) < 0)
+ if (mount(vfc.vfc_name, mntpath, mntflags, &args) < 0)
err(1, NULL);
exit(0);
}
OpenPOWER on IntegriCloud