forked from pool/systemd
55 lines
1.7 KiB
Diff
55 lines
1.7 KiB
Diff
|
From 98b47d54ce946ad3524f84eb38d2413498a333dc Mon Sep 17 00:00:00 2001
|
||
|
From: Lennart Poettering <lennart@poettering.net>
|
||
|
Date: Mon, 3 Mar 2014 17:11:39 +0100
|
||
|
Subject: [PATCH] execute: free directory path if we fail to remove it because
|
||
|
we cannot allocate a thread
|
||
|
|
||
|
---
|
||
|
src/core/execute.c | 18 ++++++++++++++++--
|
||
|
1 file changed, 16 insertions(+), 2 deletions(-)
|
||
|
|
||
|
diff --git src/core/execute.c src/core/execute.c
|
||
|
index 9de6e87..3312885 100644
|
||
|
--- src/core/execute.c
|
||
|
+++ src/core/execute.c
|
||
|
@@ -2713,6 +2713,8 @@ static void *remove_tmpdir_thread(void *p) {
|
||
|
}
|
||
|
|
||
|
void exec_runtime_destroy(ExecRuntime *rt) {
|
||
|
+ int r;
|
||
|
+
|
||
|
if (!rt)
|
||
|
return;
|
||
|
|
||
|
@@ -2722,13 +2724,25 @@ void exec_runtime_destroy(ExecRuntime *rt) {
|
||
|
|
||
|
if (rt->tmp_dir) {
|
||
|
log_debug("Spawning thread to nuke %s", rt->tmp_dir);
|
||
|
- asynchronous_job(remove_tmpdir_thread, rt->tmp_dir);
|
||
|
+
|
||
|
+ r = asynchronous_job(remove_tmpdir_thread, rt->tmp_dir);
|
||
|
+ if (r < 0) {
|
||
|
+ log_warning("Failed to nuke %s: %s", rt->tmp_dir, strerror(-r));
|
||
|
+ free(rt->tmp_dir);
|
||
|
+ }
|
||
|
+
|
||
|
rt->tmp_dir = NULL;
|
||
|
}
|
||
|
|
||
|
if (rt->var_tmp_dir) {
|
||
|
log_debug("Spawning thread to nuke %s", rt->var_tmp_dir);
|
||
|
- asynchronous_job(remove_tmpdir_thread, rt->var_tmp_dir);
|
||
|
+
|
||
|
+ r = asynchronous_job(remove_tmpdir_thread, rt->var_tmp_dir);
|
||
|
+ if (r < 0) {
|
||
|
+ log_warning("Failed to nuke %s: %s", rt->var_tmp_dir, strerror(-r));
|
||
|
+ free(rt->var_tmp_dir);
|
||
|
+ }
|
||
|
+
|
||
|
rt->var_tmp_dir = NULL;
|
||
|
}
|
||
|
|
||
|
--
|
||
|
1.7.9.2
|
||
|
|