Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 8 Jan 2013 21:31:47 +0200
From:      Jaakko Heinonen <jh@FreeBSD.org>
To:        John Baldwin <jhb@freebsd.org>
Cc:        src-committers@freebsd.org, pjd@FreeBSD.org, svn-src-all@freebsd.org, kib@FreeBSD.org, svn-src-head@freebsd.org, imp@FreeBSD.org
Subject:   Re: svn commit: r244585 - in head: . sys/geom/label
Message-ID:  <20130108193146.GA1815@a91-153-116-96.elisa-laajakaista.fi>
In-Reply-To: <201301070927.07157.jhb@freebsd.org>
References:  <201212221343.qBMDhCHa086834@svn.freebsd.org> <201301041218.07804.john@baldwin.cx> <20130105092252.GA1832@a91-153-116-96.elisa-laajakaista.fi> <201301070927.07157.jhb@freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On 2013-01-07, John Baldwin wrote:
> I think if it isn't hard to do so, we should aim to preserve labels as they 
> are generally intended to be human readable as-is.  Just preserving spaces is 
> probably sufficient for this as they are probably the most commonly used 
> character in labels affected by this change.

All right. I have prepared patches for review.

- Quote device names in devctl(4) device events. This allows events to
  work for device names containing spaces.
- Allow spaces again in device names.

Requested by:	jhb
PR:		kern/161912

%%%
Index: sys/kern/kern_conf.c
===================================================================
--- sys/kern/kern_conf.c	(revision 245155)
+++ sys/kern/kern_conf.c	(working copy)
@@ -536,17 +536,17 @@ notify(struct cdev *dev, const char *ev,
 {
 	static const char prefix[] = "cdev=";
 	char *data;
-	int namelen, mflags;
+	size_t datalen;
+	int mflags;
 
 	if (cold)
 		return;
 	mflags = (flags & MAKEDEV_NOWAIT) ? M_NOWAIT : M_WAITOK;
-	namelen = strlen(dev->si_name);
-	data = malloc(namelen + sizeof(prefix), M_TEMP, mflags);
+	datalen = strlen(dev->si_name) + sizeof(prefix) + 2;
+	data = malloc(datalen, M_TEMP, mflags);
 	if (data == NULL)
 		return;
-	memcpy(data, prefix, sizeof(prefix) - 1);
-	memcpy(data + sizeof(prefix) - 1, dev->si_name, namelen + 1);
+	snprintf(data, datalen, "%s\"%s\"", prefix, dev->si_name);
 	devctl_notify_f("DEVFS", "CDEV", ev, data, mflags);
 	free(data, M_TEMP);
 }
@@ -699,11 +699,11 @@ prep_devname(struct cdev *dev, const cha
 
 	for (to = dev->si_name; *from != '\0'; from++, to++) {
 		/*
-		 * Spaces and double quotation marks cause
-		 * problems for the devctl(4) protocol.
-		 * Reject names containing those characters.
+		 * Double quotation marks cause problems for the
+		 * devctl(4) protocol. Reject names containing
+		 * those characters.
 		 */
-		if (isspace(*from) || *from == '"')
+		if (*from == '"')
 			return (EINVAL);
 		/* Treat multiple sequential slashes as single. */
 		while (from[0] == '/' && from[1] == '/')
Index: sys/geom/geom_dev.c
===================================================================
--- sys/geom/geom_dev.c	(revision 245155)
+++ sys/geom/geom_dev.c	(working copy)
@@ -107,15 +107,15 @@ static void
 g_dev_attrchanged(struct g_consumer *cp, const char *attr)
 {
 	struct cdev *dev;
-	char buf[SPECNAMELEN + 6];
+	char buf[SPECNAMELEN + 8];
 
 	if (strcmp(attr, "GEOM::media") == 0) {
 		dev = cp->geom->softc;
-		snprintf(buf, sizeof(buf), "cdev=%s", dev->si_name);
+		snprintf(buf, sizeof(buf), "cdev=\"%s\"", dev->si_name);
 		devctl_notify_f("DEVFS", "CDEV", "MEDIACHANGE", buf, M_WAITOK);
 		dev = cp->cp_alias_dev;
 		if (dev != NULL) {
-			snprintf(buf, sizeof(buf), "cdev=%s", dev->si_name);
+			snprintf(buf, sizeof(buf), "cdev=\"%s\"", dev->si_name);
 			devctl_notify_f("DEVFS", "CDEV", "MEDIACHANGE", buf,
 			    M_WAITOK);
 		}
%%%

Don't mangle spaces in label names.

Requested by:	jhb

%%%
Index: sys/geom/label/g_label.c
===================================================================
--- sys/geom/label/g_label.c	(revision 245155)
+++ sys/geom/label/g_label.c	(working copy)
@@ -148,7 +148,7 @@ g_label_mangle_name(char *label, size_t 
 
 	sb = sbuf_new(NULL, NULL, size, SBUF_FIXEDLEN);
 	for (c = label; *c != '\0'; c++) {
-		if (!isprint(*c) || isspace(*c) || *c =='"' || *c == '%')
+		if (!isprint(*c) || *c =='"' || *c == '%')
 			sbuf_printf(sb, "%%%02X", *c);
 		else
 			sbuf_putc(sb, *c);
Index: UPDATING
===================================================================
--- UPDATING	(revision 245155)
+++ UPDATING	(working copy)
@@ -33,9 +33,9 @@ NOTE TO PEOPLE WHO THINK THAT FreeBSD 10
 
 20121222:
 	GEOM_LABEL now mangles label names read from file system metadata.
-	Mangling affect labels containing spaces, non-printable characters,
-	'%' or '"'. Device names in /etc/fstab and other places may need to
-	be updated.
+	Mangling affect labels containing non-printable characters, '%' or
+	'"'. Device names in /etc/fstab and other places may need to be
+	updated.
 
 20121217:
 	By default, only the 10 most recent kernel dumps will be saved.  To
%%%

-- 
Jaakko



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