This issue seems to be specific to git-daemon on AIX built with xlc. After commit 695605b5080e1957bd9dab1fed35a7fee9814297 (from Aug 2008), git-daemon segfaults in child_handler() inside the signal() syscall immediately after any remote clone/pull operation. While it is not fully understood why this happens, changing signal() to sigaction() resolves the issue. This commit converts singal() to sigaction() in child_handler(). --- daemon.c | 10 ++++++++-- 1 files changed, 8 insertions(+), 2 deletions(-) diff --git a/daemon.c b/daemon.c index 4c8346d..3ea5b2c 100644 --- a/daemon.c +++ b/daemon.c @@ -715,7 +715,10 @@ static void child_handler(int signo) * upon signal receipt * SysV needs the handler to be rearmed */ - signal(SIGCHLD, child_handler); + struct sigaction sigact; + memset(&sigact, 0, sizeof(sigact)); + sigact.sa_handler = child_handler; + sigaction(SIGCHLD, &sigact, NULL); } static int set_reuse_addr(int sockfd) @@ -889,7 +892,10 @@ static int service_loop(struct socketlist *socklist) pfd[i].events = POLLIN; } - signal(SIGCHLD, child_handler); + struct sigaction sigact; + memset(&sigact, 0, sizeof(sigact)); + sigact.sa_handler = child_handler; + sigaction(SIGCHLD, &sigact, NULL); for (;;) { int i; -- 1.7.0.4 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html