|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
From 429a69d0dd273a431f396fe8f5846a8e8a1a0ac7 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
From: Ronny Chevalier <chevalier.ronny@gmail.com>
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
Date: Sun, 14 May 2017 16:30:40 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
Subject: [PATCH] env-util: fix memory leak (#5962)
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
If cunescape succeeds, but the assignment is not valid, uce is not freed.
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
(cherry picked from commit 16eefcafedeecf0e282add6c1eadeebcb3ad0609)
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
src/basic/env-util.c | 4 +++-
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
src/test/test-env-util.c | 10 ++++++++++
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
2 files changed, 13 insertions(+), 1 deletion(-)
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
diff --git a/src/basic/env-util.c b/src/basic/env-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
index 1ec574e8a0..e79b441ab6 100644
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
--- a/src/basic/env-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+++ b/src/basic/env-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
@@ -799,8 +799,10 @@ int deserialize_environment(char ***environment, const char *line) {
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
if (r < 0)
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
return r;
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
- if (!env_assignment_is_valid(uce))
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ if (!env_assignment_is_valid(uce)) {
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ free(uce);
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
return strv_env_replace(environment, uce);
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
diff --git a/src/test/test-env-util.c b/src/test/test-env-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
index e5cc2a2df8..904c50f0ed 100644
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
--- a/src/test/test-env-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+++ b/src/test/test-env-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
@@ -314,6 +314,15 @@ static void test_env_assignment_is_valid(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
assert_se(!env_assignment_is_valid("głąb=printf \"\x1b]0;<mock-chroot>\x07<mock-chroot>\""));
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+static void test_deserialize_environment(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ _cleanup_strv_free_ char **env = strv_new("A=1", NULL);
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ assert_se(deserialize_environment(&env, "env=test") < 0);
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ assert_se(deserialize_environment(&env, "env=B=2") >= 0);
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ assert_se(strv_equal(env, STRV_MAKE("A=1", "B=2")));
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
test_strv_env_delete();
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
test_strv_env_get();
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
@@ -330,6 +339,7 @@ int main(int argc, char *argv[]) {
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
test_env_name_is_valid();
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
test_env_value_is_valid();
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
test_env_assignment_is_valid();
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
+ test_deserialize_environment();
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
f4a676 |
}
|