git://git.onelab.eu
/
sliver-openvswitch.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Setting tag sliver-openvswitch-1.10.90-3
[sliver-openvswitch.git]
/
lib
/
worker.c
diff --git
a/lib/worker.c
b/lib/worker.c
index
ce4a53b
..
6904fdd
100644
(file)
--- a/
lib/worker.c
+++ b/
lib/worker.c
@@
-101,6
+101,9
@@
worker_start(void)
xset_nonblocking(work_fds[0]);
xset_nonblocking(work_fds[1]);
xset_nonblocking(work_fds[0]);
xset_nonblocking(work_fds[1]);
+ /* Don't let the worker process own the responsibility to delete
+ * the pidfile. Register it again after the fork. */
+ remove_pidfile_from_unlink();
if (!fork_and_clean_up()) {
/* In child (worker) process. */
daemonize_post_detach();
if (!fork_and_clean_up()) {
/* In child (worker) process. */
daemonize_post_detach();
@@
-110,6
+113,7
@@
worker_start(void)
}
/* In parent (main) process. */
}
/* In parent (main) process. */
+ add_pidfile_to_unlink();
close(work_fds[1]);
client_sock = work_fds[0];
rxbuf_init(&client_rx);
close(work_fds[1]);
client_sock = work_fds[0];
rxbuf_init(&client_rx);
@@
-229,7
+233,7
@@
worker_send_iovec(const struct iovec iovs[], size_t n_iovs,
} while (error == EINTR);
if (error) {
worker_broke();
} while (error == EINTR);
if (error) {
worker_broke();
- VLOG_ABORT("poll failed (%s)", strerror(error));
+ VLOG_ABORT("poll failed (%s)",
ovs_
strerror(error));
}
}
}
}
}
}
@@
-260,7
+264,7
@@
worker_request_iovec(const struct iovec iovs[], size_t n_iovs,
error = worker_send_iovec(all_iovs, n_iovs + 1, fds, n_fds);
if (error) {
worker_broke();
error = worker_send_iovec(all_iovs, n_iovs + 1, fds, n_fds);
if (error) {
worker_broke();
- VLOG_ABORT("send failed (%s)", strerror(error));
+ VLOG_ABORT("send failed (%s)",
ovs_
strerror(error));
}
free(all_iovs);
}
free(all_iovs);
@@
-343,9
+347,9
@@
worker_reply_iovec(const struct iovec *iovs, size_t n_iovs,
if (error == EPIPE) {
/* Parent probably died. Continue processing any RPCs still buffered,
* to avoid missing log messages. */
if (error == EPIPE) {
/* Parent probably died. Continue processing any RPCs still buffered,
* to avoid missing log messages. */
- VLOG_INFO("send failed (%s)", strerror(error));
+ VLOG_INFO("send failed (%s)",
ovs_
strerror(error));
} else if (error) {
} else if (error) {
- VLOG_FATAL("send failed (%s)", strerror(error));
+ VLOG_FATAL("send failed (%s)",
ovs_
strerror(error));
}
free(all_iovs);
}
free(all_iovs);