diff options
author | Greg Hudson <ghudson@mit.edu> | 2011-09-14 16:12:29 +0000 |
---|---|---|
committer | Greg Hudson <ghudson@mit.edu> | 2011-09-14 16:12:29 +0000 |
commit | 6cae0a18e4fb6fc3469b5bdf75f888f580dbdec0 (patch) | |
tree | 7b7b3df4bf918a1bc7d5a8571af085ecdee46b66 /src/lib/apputils | |
parent | 61941e636016405b5dfbb031e2904dcce4c83801 (diff) | |
download | krb5-6cae0a18e4fb6fc3469b5bdf75f888f580dbdec0.tar.gz krb5-6cae0a18e4fb6fc3469b5bdf75f888f580dbdec0.tar.xz krb5-6cae0a18e4fb6fc3469b5bdf75f888f580dbdec0.zip |
Reinitialize verto after creating worker child
Also mark fd events as reinitiable so they survive the fork. From
npmccallum@redhat.com.
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@25175 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/lib/apputils')
-rw-r--r-- | src/lib/apputils/net-server.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/src/lib/apputils/net-server.c b/src/lib/apputils/net-server.c index fc6d6e7c4..546ed769e 100644 --- a/src/lib/apputils/net-server.c +++ b/src/lib/apputils/net-server.c @@ -580,7 +580,9 @@ static verto_ev * add_udp_fd(struct socksetup *data, int sock, int pktinfo) { return add_fd(data, sock, pktinfo ? CONN_UDP_PKTINFO : CONN_UDP, - VERTO_EV_FLAG_IO_READ | VERTO_EV_FLAG_PERSIST, + VERTO_EV_FLAG_IO_READ | + VERTO_EV_FLAG_PERSIST | + VERTO_EV_FLAG_REINITIABLE, process_packet, 1); } @@ -588,7 +590,9 @@ static verto_ev * add_tcp_listener_fd(struct socksetup *data, int sock) { return add_fd(data, sock, CONN_TCP_LISTENER, - VERTO_EV_FLAG_IO_READ | VERTO_EV_FLAG_PERSIST, + VERTO_EV_FLAG_IO_READ | + VERTO_EV_FLAG_PERSIST | + VERTO_EV_FLAG_REINITIABLE, accept_tcp_connection, 1); } @@ -666,7 +670,9 @@ add_rpc_listener_fd(struct socksetup *data, struct rpc_svc_data *svc, int sock) verto_ev *ev; ev = add_fd(data, sock, CONN_RPC_LISTENER, - VERTO_EV_FLAG_IO_READ | VERTO_EV_FLAG_PERSIST, + VERTO_EV_FLAG_IO_READ | + VERTO_EV_FLAG_PERSIST | + VERTO_EV_FLAG_REINITIABLE, accept_rpc_connection, 1); if (ev == NULL) return NULL; |