Zbigniew Jędrzejewski-Szmek 62fe94
From 5ed1227238724959f020169f5332086439709b55 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Thu, 21 Aug 2014 16:13:43 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] util: make asynchronous_close() really work like an
Zbigniew Jędrzejewski-Szmek 62fe94
 asynchronous version of safe_close()
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Save/restore errno, like we do in safe_close(). And don't fork a thread
Zbigniew Jędrzejewski-Szmek 62fe94
if the parameter is already negative.
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/shared/async.c | 12 ++++++++----
Zbigniew Jędrzejewski-Szmek 62fe94
 1 file changed, 8 insertions(+), 4 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/shared/async.c b/src/shared/async.c
Zbigniew Jędrzejewski-Szmek 62fe94
index 3876deda70..115901e637 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/shared/async.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/shared/async.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -73,7 +73,7 @@ int asynchronous_sync(void) {
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 static void *close_thread(void *p) {
Zbigniew Jędrzejewski-Szmek 62fe94
-        safe_close(PTR_TO_INT(p));
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert_se(close_nointr(PTR_TO_INT(p)) != -EBADF);
Zbigniew Jędrzejewski-Szmek 62fe94
         return NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -86,9 +86,13 @@ int asynchronous_close(int fd) {
Zbigniew Jędrzejewski-Szmek 62fe94
          * but it doesn't, so we work around it, and hide this as a
Zbigniew Jędrzejewski-Szmek 62fe94
          * far away as we can. */
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        r = asynchronous_job(close_thread, INT_TO_PTR(fd));
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (r < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
-                safe_close(fd);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (fd >= 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                PROTECT_ERRNO;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+                r = asynchronous_job(close_thread, INT_TO_PTR(fd));
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (r < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
+                         assert_se(close_nointr(fd) != -EBADF);
Zbigniew Jędrzejewski-Szmek 62fe94
+        }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         return -1;
Zbigniew Jędrzejewski-Szmek 62fe94
 }