summaryrefslogtreecommitdiffstats
path: root/source/lib/util.c
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@samba.org>2008-04-15 10:36:15 +0200
committerKarolin Seeger <kseeger@samba.org>2008-04-21 08:40:39 +0200
commitf9caba82f6105d3d62cba89772b956627ec0672e (patch)
tree7ef387768af760c673c773c07a191b0c0151a68f /source/lib/util.c
parentc46c6a842b907e3ea3a91fd7bbb7833fbb836f39 (diff)
downloadsamba-f9caba82f6105d3d62cba89772b956627ec0672e.tar.gz
samba-f9caba82f6105d3d62cba89772b956627ec0672e.tar.xz
samba-f9caba82f6105d3d62cba89772b956627ec0672e.zip
util: add reinit_after_fork() function
metze (cherry picked from commit 5f6c3a4f6db68c985884cbe9401a4dbe515f756b)
Diffstat (limited to 'source/lib/util.c')
-rw-r--r--source/lib/util.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/source/lib/util.c b/source/lib/util.c
index ecd8951f946..3b2d37526c8 100644
--- a/source/lib/util.c
+++ b/source/lib/util.c
@@ -990,6 +990,36 @@ void become_daemon(bool Fork, bool no_process_group)
attach it to the logfile */
}
+bool reinit_after_fork(struct messaging_context *msg_ctx)
+{
+ NTSTATUS status;
+
+ /* Reset the state of the random
+ * number generation system, so
+ * children do not get the same random
+ * numbers as each other */
+ set_need_random_reseed();
+
+ /* tdb needs special fork handling */
+ if (tdb_reopen_all(1) == -1) {
+ DEBUG(0,("tdb_reopen_all failed.\n"));
+ return false;
+ }
+
+ /*
+ * For clustering, we need to re-init our ctdbd connection after the
+ * fork
+ */
+ status = messaging_reinit(msg_ctx);
+ if (!NT_STATUS_IS_OK(status)) {
+ DEBUG(0,("messaging_reinit() failed: %s\n",
+ nt_errstr(status)));
+ return false;
+ }
+
+ return true;
+}
+
/****************************************************************************
Put up a yes/no prompt.
****************************************************************************/