Zbigniew Jędrzejewski-Szmek 794d16
From c3d2db4dd65bf5127cbddec2edd931399ce5ebce Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 794d16
From: Dave Reisner <dreisner@archlinux.org>
Zbigniew Jędrzejewski-Szmek 794d16
Date: Sun, 6 Oct 2013 18:26:23 -0400
Zbigniew Jędrzejewski-Szmek 794d16
Subject: [PATCH] shared/util: fix off-by-one error in tag_to_udev_node
Zbigniew Jędrzejewski-Szmek 794d16
Zbigniew Jędrzejewski-Szmek 794d16
Triggered false negatives when encoding a string which needed every
Zbigniew Jędrzejewski-Szmek 794d16
character to be escaped, e.g. "LABEL=/".
Zbigniew Jędrzejewski-Szmek 794d16
---
Zbigniew Jędrzejewski-Szmek 794d16
 src/shared/util.c            | 2 +-
Zbigniew Jędrzejewski-Szmek 794d16
 src/test/test-device-nodes.c | 4 +++-
Zbigniew Jędrzejewski-Szmek 794d16
 2 files changed, 4 insertions(+), 2 deletions(-)
Zbigniew Jędrzejewski-Szmek 794d16
Zbigniew Jędrzejewski-Szmek 794d16
diff --git a/src/shared/util.c b/src/shared/util.c
Zbigniew Jędrzejewski-Szmek 794d16
index 9be6acf..748f1bb 100644
Zbigniew Jędrzejewski-Szmek 794d16
--- a/src/shared/util.c
Zbigniew Jędrzejewski-Szmek 794d16
+++ b/src/shared/util.c
Zbigniew Jędrzejewski-Szmek 794d16
@@ -3527,7 +3527,7 @@ static char *tag_to_udev_node(const char *tagvalue, const char *by) {
Zbigniew Jędrzejewski-Szmek 794d16
         if (u == NULL)
Zbigniew Jędrzejewski-Szmek 794d16
                 return NULL;
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
-        enc_len = strlen(u) * 4;
Zbigniew Jędrzejewski-Szmek 794d16
+        enc_len = strlen(u) * 4 + 1;
Zbigniew Jędrzejewski-Szmek 794d16
         t = new(char, enc_len);
Zbigniew Jędrzejewski-Szmek 794d16
         if (t == NULL)
Zbigniew Jędrzejewski-Szmek 794d16
                 return NULL;
Zbigniew Jędrzejewski-Szmek 794d16
diff --git a/src/test/test-device-nodes.c b/src/test/test-device-nodes.c
Zbigniew Jędrzejewski-Szmek 794d16
index 2f3dedb..59ba4be 100644
Zbigniew Jędrzejewski-Szmek 794d16
--- a/src/test/test-device-nodes.c
Zbigniew Jędrzejewski-Szmek 794d16
+++ b/src/test/test-device-nodes.c
Zbigniew Jędrzejewski-Szmek 794d16
@@ -26,7 +26,7 @@
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
 /* helpers for test_encode_devnode_name */
Zbigniew Jędrzejewski-Szmek 794d16
 static char *do_encode_string(const char *in) {
Zbigniew Jędrzejewski-Szmek 794d16
-        size_t out_len = strlen(in) * 4;
Zbigniew Jędrzejewski-Szmek 794d16
+        size_t out_len = strlen(in) * 4 + 1;
Zbigniew Jędrzejewski-Szmek 794d16
         char *out = malloc(out_len);
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(out);
Zbigniew Jędrzejewski-Szmek 794d16
@@ -46,6 +46,8 @@ static void test_encode_devnode_name(void) {
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(expect_encoded_as("pinkiepie", "pinkiepie"));
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(expect_encoded_as("valíd\\ųtf8", "valíd\\x5cųtf8"));
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(expect_encoded_as("s/ash/ng", "s\\x2fash\\x2fng"));
Zbigniew Jędrzejewski-Szmek 794d16
+        assert_se(expect_encoded_as("/", "\\x2f"));
Zbigniew Jędrzejewski-Szmek 794d16
+        assert_se(expect_encoded_as("!", "\\x21"));
Zbigniew Jędrzejewski-Szmek 794d16
 }
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
 int main(int argc, char *argv[]) {