diff options
author | Nicholas Marriott <nicholas.marriott@gmail.com> | 2008-06-07 07:27:28 +0000 |
---|---|---|
committer | Nicholas Marriott <nicholas.marriott@gmail.com> | 2008-06-07 07:27:28 +0000 |
commit | d51f075a4e71cbde5f25cd22cf07d0b7691d4c6c (patch) | |
tree | 0ca61a4abde7bd4d524dee67ed15dee37fe9f5f8 /server.c | |
parent | 958069575dc663595d37a37a8273db73a4e99aa1 (diff) | |
download | rtmux-d51f075a4e71cbde5f25cd22cf07d0b7691d4c6c.tar.gz rtmux-d51f075a4e71cbde5f25cd22cf07d0b7691d4c6c.tar.bz2 rtmux-d51f075a4e71cbde5f25cd22cf07d0b7691d4c6c.zip |
Use a socketpair to synchronise server startup.
Diffstat (limited to 'server.c')
-rw-r--r-- | server.c | 32 |
1 files changed, 25 insertions, 7 deletions
@@ -1,4 +1,4 @@ -/* $Id: server.c,v 1.58 2008-06-07 07:13:08 nicm Exp $ */ +/* $Id: server.c,v 1.59 2008-06-07 07:27:28 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> @@ -58,24 +58,37 @@ void server_check_redraw(struct client *); void server_check_status(struct client *); /* Fork new server. */ -pid_t +int server_start(const char *path) { struct sockaddr_un sa; size_t size; mode_t mask; - int n, fd, mode; - pid_t pid; + int n, fd, pair[2], mode; char *cause; + u_char ch; + + /* Make a little socketpair to wait for the server to be ready. */ + if (socketpair(AF_UNIX, SOCK_STREAM, PF_UNSPEC, pair) != 0) + fatal("socketpair failed"); - switch (pid = fork()) { + switch (fork()) { case -1: - fatal("fork"); + fatal("fork failed"); case 0: break; default: - return (pid); + close(pair[1]); + + ch = 0; + if (read(pair[0], &ch, 1) == 1 && ch == 0xff) { + close(pair[0]); + return (0); + } + close(pair[0]); + return (1); } + close(pair[0]); #ifdef DEBUG xmalloc_clear(); @@ -130,6 +143,11 @@ server_start(const char *path) fatal("fcntl failed"); if (fcntl(fd, F_SETFD, FD_CLOEXEC) == -1) fatal("fcntl failed"); + + ch = 0xff; + if (write(pair[1], &ch, 1) != 1) + fatal("write failed"); + /* Don't close the socketpair fd on success. */ n = server_main(path, fd); #ifdef DEBUG |