]> git.proxmox.com Git - mirror_frr.git/blobdiff - lib/libfrr.h
bgpd: dynamic mpls label pool
[mirror_frr.git] / lib / libfrr.h
index 6bd92d8beae7f29fec37371bd759aac0d1691c08..fe6c46670a3c6b312cb83fcd59b535a0d7f3c623 100644 (file)
@@ -49,10 +49,12 @@ struct frr_daemon_info {
        char *vty_sock_path;
        bool dryrun;
        bool daemon_mode;
+       bool terminal;
        const char *config_file;
        const char *pid_file;
        const char *vty_path;
        const char *module_path;
+       const char *pathspace;
 
        const char *proghelp;
        void (*printhelp)(FILE *target);
@@ -74,30 +76,25 @@ struct frr_daemon_info {
  * upcoming module support) that need to place some per-daemon things.  Each
  * daemon should have one of these.
  */
-#define FRR_DAEMON_INFO(execname, constname, ...) \
-       static struct frr_daemon_info execname ##_di = { \
-               .name = # execname, \
-               .logname = # constname, \
-               .module = THIS_MODULE, \
-               __VA_ARGS__ \
-       }; \
-       FRR_COREMOD_SETUP( \
-               .name = # execname, \
-               .description = # execname " daemon", \
-                .version = FRR_VERSION, \
-       ) \
-       /* end */
-
-extern void frr_preinit(struct frr_daemon_info *daemon,
-               int argc, char **argv);
-extern void frr_opt_add(const char *optstr,
-               const struct option *longopts, const char *helpstr);
-extern int frr_getopt(int argc, char * const argv[], int *longindex);
+#define FRR_DAEMON_INFO(execname, constname, ...)                              \
+       static struct frr_daemon_info execname##_di = {.name = #execname,      \
+                                                      .logname = #constname,  \
+                                                      .module = THIS_MODULE,  \
+                                                      __VA_ARGS__};           \
+       FRR_COREMOD_SETUP(.name = #execname,                                   \
+                         .description = #execname " daemon",                  \
+                         .version = FRR_VERSION, )                            \
+/* end */
+
+extern void frr_preinit(struct frr_daemon_info *daemon, int argc, char **argv);
+extern void frr_opt_add(const char *optstr, const struct option *longopts,
+                       const char *helpstr);
+extern int frr_getopt(int argc, char *const argv[], int *longindex);
 extern void frr_help_exit(int status);
 
 extern struct thread_master *frr_init(void);
 
-DECLARE_HOOK(frr_late_init, (struct thread_master *tm), (tm))
+DECLARE_HOOK(frr_late_init, (struct thread_master * tm), (tm))
 extern void frr_config_fork(void);
 
 extern void frr_vty_serv(void);
@@ -105,9 +102,26 @@ extern void frr_vty_serv(void);
 /* note: contains call to frr_vty_serv() */
 extern void frr_run(struct thread_master *master);
 
+extern bool frr_zclient_addr(struct sockaddr_storage *sa, socklen_t *sa_len,
+                            const char *path);
+
+/* these two are before the protocol daemon does its own shutdown
+ * it's named this way being the counterpart to frr_late_init */
+DECLARE_KOOH(frr_early_fini, (), ())
+extern void frr_early_fini(void);
+/* and these two are after the daemon did its own cleanup */
+DECLARE_KOOH(frr_fini, (), ())
+extern void frr_fini(void);
+
 extern char config_default[256];
+extern char frr_zclientpath[256];
 extern const char frr_sysconfdir[];
 extern const char frr_vtydir[];
 extern const char frr_moduledir[];
 
+extern char frr_protoname[];
+extern char frr_protonameinst[];
+
+extern bool debug_memstats_at_exit;
+
 #endif /* _ZEBRA_FRR_H */