Zbigniew Jędrzejewski-Szmek 96237b
From f0eb7735d8cdf44ebf7064613add363ddda329b0 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 96237b
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek 96237b
Date: Mon, 3 Mar 2014 17:11:39 +0100
Zbigniew Jędrzejewski-Szmek 96237b
Subject: [PATCH] execute: free directory path if we fail to remove it because
Zbigniew Jędrzejewski-Szmek 96237b
 we cannot allocate a thread
Zbigniew Jędrzejewski-Szmek 96237b
Zbigniew Jędrzejewski-Szmek 96237b
(cherry picked from commit 98b47d54ce946ad3524f84eb38d2413498a333dc)
Zbigniew Jędrzejewski-Szmek 96237b
---
Zbigniew Jędrzejewski-Szmek 96237b
 src/core/execute.c | 18 ++++++++++++++++--
Zbigniew Jędrzejewski-Szmek 96237b
 1 file changed, 16 insertions(+), 2 deletions(-)
Zbigniew Jędrzejewski-Szmek 96237b
Zbigniew Jędrzejewski-Szmek 96237b
diff --git a/src/core/execute.c b/src/core/execute.c
Zbigniew Jędrzejewski-Szmek 96237b
index a328fc2..bb06507 100644
Zbigniew Jędrzejewski-Szmek 96237b
--- a/src/core/execute.c
Zbigniew Jędrzejewski-Szmek 96237b
+++ b/src/core/execute.c
Zbigniew Jędrzejewski-Szmek 96237b
@@ -2579,6 +2579,8 @@ static void *remove_tmpdir_thread(void *p) {
Zbigniew Jędrzejewski-Szmek 96237b
 }
Zbigniew Jędrzejewski-Szmek 96237b
 
Zbigniew Jędrzejewski-Szmek 96237b
 void exec_runtime_destroy(ExecRuntime *rt) {
Zbigniew Jędrzejewski-Szmek 96237b
+        int r;
Zbigniew Jędrzejewski-Szmek 96237b
+
Zbigniew Jędrzejewski-Szmek 96237b
         if (!rt)
Zbigniew Jędrzejewski-Szmek 96237b
                 return;
Zbigniew Jędrzejewski-Szmek 96237b
 
Zbigniew Jędrzejewski-Szmek 96237b
@@ -2588,13 +2590,25 @@ void exec_runtime_destroy(ExecRuntime *rt) {
Zbigniew Jędrzejewski-Szmek 96237b
 
Zbigniew Jędrzejewski-Szmek 96237b
         if (rt->tmp_dir) {
Zbigniew Jędrzejewski-Szmek 96237b
                 log_debug("Spawning thread to nuke %s", rt->tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
-                asynchronous_job(remove_tmpdir_thread, rt->tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
+
Zbigniew Jędrzejewski-Szmek 96237b
+                r = asynchronous_job(remove_tmpdir_thread, rt->tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
+                if (r < 0) {
Zbigniew Jędrzejewski-Szmek 96237b
+                        log_warning("Failed to nuke %s: %s", rt->tmp_dir, strerror(-r));
Zbigniew Jędrzejewski-Szmek 96237b
+                        free(rt->tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
+                }
Zbigniew Jędrzejewski-Szmek 96237b
+
Zbigniew Jędrzejewski-Szmek 96237b
                 rt->tmp_dir = NULL;
Zbigniew Jędrzejewski-Szmek 96237b
         }
Zbigniew Jędrzejewski-Szmek 96237b
 
Zbigniew Jędrzejewski-Szmek 96237b
         if (rt->var_tmp_dir) {
Zbigniew Jędrzejewski-Szmek 96237b
                 log_debug("Spawning thread to nuke %s", rt->var_tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
-                asynchronous_job(remove_tmpdir_thread, rt->var_tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
+
Zbigniew Jędrzejewski-Szmek 96237b
+                r = asynchronous_job(remove_tmpdir_thread, rt->var_tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
+                if (r < 0) {
Zbigniew Jędrzejewski-Szmek 96237b
+                        log_warning("Failed to nuke %s: %s", rt->var_tmp_dir, strerror(-r));
Zbigniew Jędrzejewski-Szmek 96237b
+                        free(rt->var_tmp_dir);
Zbigniew Jędrzejewski-Szmek 96237b
+                }
Zbigniew Jędrzejewski-Szmek 96237b
+
Zbigniew Jędrzejewski-Szmek 96237b
                 rt->var_tmp_dir = NULL;
Zbigniew Jędrzejewski-Szmek 96237b
         }
Zbigniew Jędrzejewski-Szmek 96237b