summaryrefslogtreecommitdiffstats
path: root/lib/libfrr.h
diff options
context:
space:
mode:
authorDavid Lamparter <equinox@opensourcerouting.org>2018-09-27 04:18:48 +0200
committerDavid Lamparter <equinox@opensourcerouting.org>2018-10-02 12:27:47 +0200
commit0a7c7856e3eb6db017d3d0c4d19d55c6cdb212e9 (patch)
tree4a6cb7cee5c17e1e51ba8fe6b81e5c1b40e628ba /lib/libfrr.h
parentMerge pull request #3102 from ton31337/feature/match_blackhole_nexthops (diff)
downloadfrr-0a7c7856e3eb6db017d3d0c4d19d55c6cdb212e9.tar.xz
frr-0a7c7856e3eb6db017d3d0c4d19d55c6cdb212e9.zip
watchfrr, lib: cleanup & delay detaching
This cleans up watchfrr to be more "normal" like the other daemons in terms of what it does in main(), i.e. using the full frr_*() call set. Also, this changes the startup behaviour on watchfrr to stay attached on the daemon's parent process until startup is really complete. This should allow removing the "watchfrr.started" hack at some point. Signed-off-by: David Lamparter <equinox@diac24.net>
Diffstat (limited to 'lib/libfrr.h')
-rw-r--r--lib/libfrr.h16
1 files changed, 12 insertions, 4 deletions
diff --git a/lib/libfrr.h b/lib/libfrr.h
index d25527990..db58ff92b 100644
--- a/lib/libfrr.h
+++ b/lib/libfrr.h
@@ -29,11 +29,21 @@
#include "module.h"
#include "hook.h"
+/* The following options disable specific command line options that
+ * are not applicable for a particular daemon.
+ */
#define FRR_NO_PRIVSEP (1 << 0)
#define FRR_NO_TCPVTY (1 << 1)
#define FRR_LIMITED_CLI (1 << 2)
-#define FRR_NO_CFG_PID_DRY (1 << 3)
+#define FRR_NO_CFG_PID_DRY (1 << 3)
#define FRR_NO_ZCLIENT (1 << 4)
+/* If FRR_DETACH_LATER is used, the daemon will keep its parent running
+ * until frr_detach() is called. Normally "somedaemon -d" returns once the
+ * main event loop is reached in the daemon; use this for extra startup bits.
+ *
+ * Does nothing if -d isn't used.
+ */
+#define FRR_DETACH_LATER (1 << 5)
struct frr_daemon_info {
unsigned flags;
@@ -102,10 +112,8 @@ extern struct thread_master *frr_init(void);
DECLARE_HOOK(frr_late_init, (struct thread_master * tm), (tm))
extern void frr_config_fork(void);
-extern void frr_vty_serv(void);
-
-/* note: contains call to frr_vty_serv() */
extern void frr_run(struct thread_master *master);
+extern void frr_detach(void);
extern bool frr_zclient_addr(struct sockaddr_storage *sa, socklen_t *sa_len,
const char *path);