From 659730a173a6780111b95325c95a113297ad8dcc Mon Sep 17 00:00:00 2001 From: Artur Grabowski Date: Wed, 17 Feb 1999 18:03:48 +0000 Subject: try harder to match the mntonname with the name we are trying to unmount --- sbin/umount/umount.c | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) (limited to 'sbin/umount/umount.c') diff --git a/sbin/umount/umount.c b/sbin/umount/umount.c index f3cfeb569ab..4852944efb8 100644 --- a/sbin/umount/umount.c +++ b/sbin/umount/umount.c @@ -1,4 +1,4 @@ -/* $OpenBSD: umount.c,v 1.5 1997/01/15 23:41:45 millert Exp $ */ +/* $OpenBSD: umount.c,v 1.6 1999/02/17 18:03:47 art Exp $ */ /* $NetBSD: umount.c,v 1.16 1996/05/11 14:13:55 mycroft Exp $ */ /*- @@ -44,7 +44,7 @@ static char copyright[] = #if 0 static char sccsid[] = "@(#)umount.c 8.3 (Berkeley) 2/20/94"; #else -static char rcsid[] = "$OpenBSD: umount.c,v 1.5 1997/01/15 23:41:45 millert Exp $"; +static char rcsid[] = "$OpenBSD: umount.c,v 1.6 1999/02/17 18:03:47 art Exp $"; #endif #endif /* not lint */ @@ -276,19 +276,30 @@ getmntname(name, what, type) { struct statfs *mntbuf; int i, mntsize; + char realonname[MAXPATHLEN], realfromname[MAXPATHLEN]; if ((mntsize = getmntinfo(&mntbuf, MNT_NOWAIT)) == 0) { warn("getmntinfo"); return (NULL); } for (i = 0; i < mntsize; i++) { - if ((what == MNTON) && !strcmp(mntbuf[i].f_mntfromname, name)) { + /* + * Translate the name in case the mount call wasn't done + * with a translated name. + * (but return the name as it is in the struct) + */ + if (realpath(mntbuf[i].f_mntfromname, realfromname) == NULL) + continue; + if (realpath(mntbuf[i].f_mntonname, realonname) == NULL) + continue; + + if ((what == MNTON) && !strcmp(realfromname, name)) { if (type) memcpy(type, mntbuf[i].f_fstypename, sizeof(mntbuf[i].f_fstypename)); return (mntbuf[i].f_mntonname); } - if ((what == MNTFROM) && !strcmp(mntbuf[i].f_mntonname, name)) { + if ((what == MNTFROM) && !strcmp(realonname, name)) { if (type) memcpy(type, mntbuf[i].f_fstypename, sizeof(mntbuf[i].f_fstypename)); -- cgit v1.2.3