|
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 |
}
|