[PATCH v2 evemu] Only overwrite NULL names on evemu_read()

Peter Hutterer peter.hutterer at who-t.net
Wed Nov 13 19:11:42 PST 2013


If a caller has provided a device name to evemu_new(), parse the name but
don't copy it in to the device struct.

Signed-off-by: Peter Hutterer <peter.hutterer at who-t.net>
---
Sorry, first patch was dodgy, should've tested it. Paperbag applied, etc.

Changes to v1:
- actually do the right thing :)
- evemu-device sets the PID-based name only for devices without a name (does
  the kernel even allow that?)

 src/evemu.c              | 13 +++++++++++--
 test/test-evemu-create.c | 16 ++++++++++++----
 tools/evemu-device.c     | 11 +++++++----
 3 files changed, 30 insertions(+), 10 deletions(-)

diff --git a/src/evemu.c b/src/evemu.c
index 838225c..579fb28 100644
--- a/src/evemu.c
+++ b/src/evemu.c
@@ -421,8 +421,10 @@ static int parse_name(struct evemu_device *dev, const char *line, struct version
 	int matched;
 	char *devname = NULL;
 
-	if ((matched = sscanf(line, "N: %m[^\n]\n", &devname)) > 0)
-		evemu_set_name(dev, devname);
+	if ((matched = sscanf(line, "N: %m[^\n]\n", &devname)) > 0) {
+		if (strlen(dev->name) == 0)
+			evemu_set_name(dev, devname);
+	}
 
 	if (devname != NULL)
 		free(devname);
@@ -558,9 +560,16 @@ int evemu_read(struct evemu_device *dev, FILE *fp)
 	struct version file_version; /* file format version */
 	size_t size = 0;
 	char *line = NULL;
+	char *name = NULL;
 
+	if (strlen(evemu_get_name(dev)) > 0)
+		name = strdup(evemu_get_name(dev));
 	memset(dev, 0, sizeof(*dev));
 	dev->version = EVEMU_VERSION;
+	if (name) {
+		strcpy(dev->name, name);
+		free(name);
+	}
 
 	/* first line _may_ be version */
 	if (!first_line(fp, &line, &size)) {
diff --git a/test/test-evemu-create.c b/test/test-evemu-create.c
index 4437420..3df3194 100644
--- a/test/test-evemu-create.c
+++ b/test/test-evemu-create.c
@@ -14,6 +14,7 @@
 #define UNUSED __attribute__((unused))
 
 #define NAME "evemu test device"
+#define CUSTOM_NAME "custom evemu test device"
 
 static const char *name		= "N: " NAME "";
 static const char *ident	= "I: 0003 0004 0005 0006";
@@ -40,7 +41,8 @@ enum flags {
 	EOLCOMMENT	 = (1 << 6), /* end-of-line comment */
 	EVENT		 = (1 << 7), /* event line */
 	EMPTYLINE	 = (1 << 8),
-	ALLFLAGS	 = (EMPTYLINE << 1) - 1
+	WITHNAME	 = (1 << 9), /* use evemu_new(custom name) */
+	ALLFLAGS	 = (WITHNAME << 1) - 1
 };
 
 static int max[EV_CNT] = {
@@ -69,6 +71,7 @@ void check_evemu_read(int fd, const char *file, enum flags flags)
 {
 	FILE *fp;
 	struct evemu_device *dev;
+	const char *device_name;
 
 	ftruncate(fd, 0);
 	lseek(fd, 0, SEEK_SET);
@@ -146,11 +149,16 @@ void check_evemu_read(int fd, const char *file, enum flags flags)
 	fp = fopen(file, "r");
 	assert(fp);
 
-	dev = evemu_new("test device");
+	if (flags & WITHNAME) {
+		dev = evemu_new(CUSTOM_NAME);
+		device_name = CUSTOM_NAME;
+	} else {
+		dev = evemu_new(NULL);
+		device_name = NAME;
+	}
 	assert(dev);
-
 	assert(evemu_read(dev, fp) >= 0);
-	assert(strcmp(NAME, evemu_get_name(dev)) == 0);
+	assert(strcmp(device_name, evemu_get_name(dev)) == 0);
 	assert(evemu_get_id_bustype(dev) == 0x0003);
 	assert(evemu_get_id_vendor(dev) == 0x0004);
 	assert(evemu_get_id_product(dev) == 0x0005);
diff --git a/tools/evemu-device.c b/tools/evemu-device.c
index 20e0f44..5ddd166 100644
--- a/tools/evemu-device.c
+++ b/tools/evemu-device.c
@@ -201,19 +201,22 @@ static void hold_device(const struct evemu_device *dev)
 static int evemu_device(FILE *fp)
 {
 	struct evemu_device *dev;
-	char name[64];
 	int ret = -ENOMEM;
 	int fd;
 
-	sprintf(name, "evemu-%d", getpid());
-
-	dev = evemu_new(name);
+	dev = evemu_new(NULL);
 	if (!dev)
 		goto out;
 	ret = evemu_read(dev, fp);
 	if (ret <= 0)
 		goto out;
 
+	if (strlen(evemu_get_name(dev)) == 0) {
+		char name[64];
+		sprintf(name, "evemu-%d", getpid());
+		evemu_set_name(dev, name);
+	}
+
 	ret = fd = open(UINPUT_NODE, O_WRONLY);
 	if (ret < 0)
 		goto out;
-- 
1.8.3.1



More information about the Input-tools mailing list