From: Zbigniew Jędrzejewski-Szmek Date: Mon, 8 Jul 2019 12:18:46 +0000 (+0200) Subject: pid1: fix serialization/deserialization of commmands with spaces X-Git-Tag: v243-rc1~178 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=334c0979f37adab7cf6df01cff1ee818bf72d7b2;p=thirdparty%2Fsystemd.git pid1: fix serialization/deserialization of commmands with spaces Fixes #12258. This is enough to reproduce: $ systemd-run bash -c 'sleep 10' && systemctl daemon-reload would result in Current command vanished from the unit file. We would serialize as: ExecStart 0 /usr/bin/bash /usr/bin/bash -c sleep 10000 which of course can't work. Now we serialize as ExecStart 0 /usr/bin/bash "/usr/bin/bash" "-c" "sleep 10". --- diff --git a/src/core/service.c b/src/core/service.c index 4b50d8d0297..a7031df48a6 100644 --- a/src/core/service.c +++ b/src/core/service.c @@ -2530,14 +2530,16 @@ static int service_serialize_exec_command(Unit *u, FILE *f, ExecCommand *command return log_oom(); n = strlen(e); - if (!GREEDY_REALLOC(args, allocated, length + 1 + n + 1)) + if (!GREEDY_REALLOC(args, allocated, length + 2 + n + 2)) return log_oom(); if (length > 0) args[length++] = ' '; + args[length++] = '"'; memcpy(args + length, e, n); length += n; + args[length++] = '"'; } if (!GREEDY_REALLOC(args, allocated, length + 1)) @@ -2682,7 +2684,7 @@ static int service_deserialize_exec_command(Unit *u, const char *key, const char for (;;) { _cleanup_free_ char *arg = NULL; - r = extract_first_word(&value, &arg, NULL, EXTRACT_CUNESCAPE); + r = extract_first_word(&value, &arg, NULL, EXTRACT_CUNESCAPE | EXTRACT_UNQUOTE); if (r < 0) return r; if (r == 0)