From 7cf7f1a0c1238531307c170b3cf6940d77511c11 Mon Sep 17 00:00:00 2001 From: Yu Watanabe Date: Thu, 8 Mar 2018 22:21:54 +0900 Subject: core: do not free heap-allocated strings (#8391) Fixes #8387. (cherry picked from commit 5cbaad2f6795088db56063d20695c6444595822f) --- src/core/mount-setup.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/core/mount-setup.c b/src/core/mount-setup.c index 8fb0a1dea..ea6f04f52 100644 --- a/src/core/mount-setup.c +++ b/src/core/mount-setup.c @@ -263,6 +263,7 @@ int mount_setup_early(void) { int mount_cgroup_controllers(char ***join_controllers) { _cleanup_set_free_free_ Set *controllers = NULL; + bool has_argument = !!join_controllers; int r; if (!cg_is_legacy_wanted()) @@ -270,7 +271,7 @@ int mount_cgroup_controllers(char ***join_controllers) { /* Mount all available cgroup controllers that are built into the kernel. */ - if (!join_controllers) + if (!has_argument) /* The defaults: * mount "cpu" + "cpuacct" together, and "net_cls" + "net_prio". * @@ -315,7 +316,8 @@ int mount_cgroup_controllers(char ***join_controllers) { t = set_remove(controllers, *i); if (!t) { - free(*i); + if (has_argument) + free(*i); continue; } } -- cgit v1.2.3