Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 27 Feb 2010 18:27:32 +0000 (UTC)
From:      Hajimu UMEMOTO <ume@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-stable@freebsd.org, svn-src-stable-8@freebsd.org
Subject:   svn commit: r204422 - in stable/8/sbin: mount_nfs umount
Message-ID:  <201002271827.o1RIRWCf038258@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: ume
Date: Sat Feb 27 18:27:32 2010
New Revision: 204422
URL: http://svn.freebsd.org/changeset/base/204422

Log:
  MFC r203490: Introduce '[ipaddr]:path' notation.
  Since the existing implementation searches ':' backward, a path which
  includes ':' could not be mounted.  You can now mount such path by
  enclosing an IP address by '[]'.
  Though we should change to search ':' forward, it will break
  'ipv6addr:path' which is currently working.  So, it still searches ':'
  backward, at least for now.

Modified:
  stable/8/sbin/mount_nfs/mount_nfs.c
  stable/8/sbin/umount/umount.c
Directory Properties:
  stable/8/sbin/mount_nfs/   (props changed)
  stable/8/sbin/umount/   (props changed)

Modified: stable/8/sbin/mount_nfs/mount_nfs.c
==============================================================================
--- stable/8/sbin/mount_nfs/mount_nfs.c	Sat Feb 27 18:19:13 2010	(r204421)
+++ stable/8/sbin/mount_nfs/mount_nfs.c	Sat Feb 27 18:27:32 2010	(r204422)
@@ -698,12 +698,17 @@ getnfsargs(char *spec, struct iovec **io
 {
 	struct addrinfo hints, *ai_nfs, *ai;
 	enum tryret ret;
-	int ecode, speclen, remoteerr;
+	int ecode, speclen, remoteerr, offset, have_bracket = 0;
 	char *hostp, *delimp, *errstr;
 	size_t len;
 	static char nam[MNAMELEN + 1], pname[MAXHOSTNAMELEN + 5];
 
-	if ((delimp = strrchr(spec, ':')) != NULL) {
+	if (*spec == '[' && (delimp = strchr(spec + 1, ']')) != NULL &&
+	    *(delimp + 1) == ':') {
+		hostp = spec + 1;
+		spec = delimp + 2;
+		have_bracket = 1;
+	} else if ((delimp = strrchr(spec, ':')) != NULL) {
 		hostp = spec;
 		spec = delimp + 1;
 	} else if ((delimp = strrchr(spec, '@')) != NULL) {
@@ -731,10 +736,15 @@ getnfsargs(char *spec, struct iovec **io
 	/* Make both '@' and ':' notations equal */
 	if (*hostp != '\0') {
 		len = strlen(hostp);
-		memmove(nam, hostp, len);
-		nam[len] = ':';
-		memmove(nam + len + 1, spec, speclen);
-		nam[len + speclen + 1] = '\0';
+		offset = 0;
+		if (have_bracket)
+			nam[offset++] = '[';
+		memmove(nam + offset, hostp, len);
+		if (have_bracket)
+			nam[len + offset++] = ']';
+		nam[len + offset++] = ':';
+		memmove(nam + len + offset, spec, speclen);
+		nam[len + speclen + offset] = '\0';
 	}
 
 	/*

Modified: stable/8/sbin/umount/umount.c
==============================================================================
--- stable/8/sbin/umount/umount.c	Sat Feb 27 18:19:13 2010	(r204421)
+++ stable/8/sbin/umount/umount.c	Sat Feb 27 18:27:32 2010	(r204422)
@@ -325,14 +325,21 @@ umountfs(struct statfs *sfs)
 		if ((nfsdirname = strdup(sfs->f_mntfromname)) == NULL)
 			err(1, "strdup");
 		orignfsdirname = nfsdirname;
-		if ((delimp = strrchr(nfsdirname, ':')) != NULL) {
-			*delimp = '\0';
+		if (*nfsdirname == '[' &&
+		    (delimp = strchr(nfsdirname + 1, ']')) != NULL &&
+		    *(delimp + 1) == ':') {
+			hostp = nfsdirname + 1;
+			nfsdirname = delimp + 2;
+		} else if ((delimp = strrchr(nfsdirname, ':')) != NULL) {
 			hostp = nfsdirname;
+			nfsdirname = delimp + 1;
+		}
+		if (hostp != NULL) {
+			*delimp = '\0';
 			getaddrinfo(hostp, NULL, &hints, &ai);
 			if (ai == NULL) {
 				warnx("can't get net id for host");
 			}
-			nfsdirname = delimp + 1;
 		}
 
 		/*



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201002271827.o1RIRWCf038258>