Blame SOURCES/0070-libblkid-fix-memory-leak-in-blkid_parse_tag_string.patch

05ad79
From 8af4232ff50154588c75f25a951b5619f05d0421 Mon Sep 17 00:00:00 2001
05ad79
From: Karel Zak <kzak@redhat.com>
05ad79
Date: Tue, 19 Nov 2013 17:52:56 +0100
05ad79
Subject: [PATCH 70/84] libblkid: fix memory leak in blkid_parse_tag_string()
05ad79
05ad79
Upstream: http://github.com/karelzak/util-linux/commit/c1178175e7adb35388a3e34495974d7f24f45d5d
05ad79
Upstream: http://github.com/karelzak/util-linux/commit/aab691cf8deb4a53782a0317b6f96c5d8b61f8e9
05ad79
Addresses: http://bugzilla.redhat.com/show_bug.cgi?id=1335671
05ad79
Signed-off-by: Karel Zak <kzak@redhat.com>
05ad79
---
05ad79
 libblkid/src/tag.c | 14 +++++++++-----
05ad79
 1 file changed, 9 insertions(+), 5 deletions(-)
05ad79
05ad79
diff --git a/libblkid/src/tag.c b/libblkid/src/tag.c
05ad79
index 3a70950..3aede04 100644
05ad79
--- a/libblkid/src/tag.c
05ad79
+++ b/libblkid/src/tag.c
05ad79
@@ -237,14 +237,18 @@ int blkid_parse_tag_string(const char *token, char **ret_type, char **ret_val)
05ad79
 			goto errout; /* missing closing quote */
05ad79
 		*cp = '\0';
05ad79
 	}
05ad79
-	value = value && *value ? strdup(value) : NULL;
05ad79
-	if (!value)
05ad79
-		goto errout;
05ad79
+
05ad79
+	if (ret_val) {
05ad79
+		value = *value ? strdup(value) : NULL;
05ad79
+		if (!value)
05ad79
+			goto errout;
05ad79
+		*ret_val = value;
05ad79
+	}
05ad79
 
05ad79
 	if (ret_type)
05ad79
 		*ret_type = name;
05ad79
-	if (ret_val)
05ad79
-		*ret_val = value;
05ad79
+	else
05ad79
+		free(name);
05ad79
 
05ad79
 	return 0;
05ad79
 
05ad79
-- 
05ad79
2.7.4
05ad79