|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen master] libxl: fork: Break out sigchld_sethandler_raw
commit b942c569f29e8caab251e36bb1be604697225bde
Author: Ian Jackson <ian.jackson@xxxxxxxxxxxxx>
AuthorDate: Fri Jan 17 15:42:31 2014 +0000
Commit: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx>
CommitDate: Thu Feb 6 14:20:54 2014 +0000
libxl: fork: Break out sigchld_sethandler_raw
We are going to want introduce another call site in the final
substantive patch.
Pure code motion; no functional change.
Signed-off-by: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx>
Cc: Jim Fehlig <jfehlig@xxxxxxxx>
Cc: Ian Campbell <Ian.Campbell@xxxxxxxxxx>
Acked-by: Ian Campbell <Ian.Campbell@xxxxxxxxxx>
---
v3: Remove now-unused variables from sigchld_installhandler_core
---
tools/libxl/libxl_fork.c | 23 ++++++++++++++---------
1 files changed, 14 insertions(+), 9 deletions(-)
diff --git a/tools/libxl/libxl_fork.c b/tools/libxl/libxl_fork.c
index ce8e8eb..084d86a 100644
--- a/tools/libxl/libxl_fork.c
+++ b/tools/libxl/libxl_fork.c
@@ -182,6 +182,19 @@ static void sigchld_handler(int signo)
errno = esave;
}
+static void sigchld_sethandler_raw(void (*handler)(int), struct sigaction *old)
+{
+ struct sigaction ours;
+ int r;
+
+ memset(&ours,0,sizeof(ours));
+ ours.sa_handler = handler;
+ sigemptyset(&ours.sa_mask);
+ ours.sa_flags = SA_NOCLDSTOP | SA_RESTART;
+ r = sigaction(SIGCHLD, &ours, old);
+ assert(!r);
+}
+
static void sigchld_removehandler_core(void)
{
struct sigaction was;
@@ -196,18 +209,10 @@ static void sigchld_removehandler_core(void)
static void sigchld_installhandler_core(libxl__gc *gc)
{
- struct sigaction ours;
- int r;
-
assert(!sigchld_owner);
sigchld_owner = CTX;
- memset(&ours,0,sizeof(ours));
- ours.sa_handler = sigchld_handler;
- sigemptyset(&ours.sa_mask);
- ours.sa_flags = SA_NOCLDSTOP | SA_RESTART;
- r = sigaction(SIGCHLD, &ours, &sigchld_saved_action);
- assert(!r);
+ sigchld_sethandler_raw(sigchld_handler, &sigchld_saved_action);
assert(((void)"application must negotiate with libxl about SIGCHLD",
!(sigchld_saved_action.sa_flags & SA_SIGINFO) &&
--
generated by git-patchbot for /home/xen/git/xen.git#master
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |