]>
git.ipfire.org Git - thirdparty/bird.git/blob - conf/conf.h
2 * BIRD Internet Routing Daemon -- Configuration File Handling
4 * (c) 1998--2000 Martin Mares <mj@ucw.cz>
6 * Can be freely distributed and used under the terms of the GNU GPL.
12 #include "sysdep/config.h"
15 #include "lib/resource.h"
16 #include "lib/timer.h"
18 /* Configuration structure */
21 pool
*pool
; /* Pool the configuration is stored in */
22 linpool
*mem
; /* Linear pool containing configuration data */
23 list protos
; /* Configured protocol instances (struct proto_config) */
24 list tables
; /* Configured routing tables (struct rtable_config) */
25 list logfiles
; /* Configured log files (sysdep) */
26 list tests
; /* Configured unit tests (f_bt_test_suite) */
27 list symbols
; /* Configured symbols in config order */
29 int mrtdump_file
; /* Configured MRTDump file (sysdep, fd in unix) */
30 char *syslog_name
; /* Name used for syslog (NULL -> no syslog) */
31 struct rtable_config
*def_tables
[NET_MAX
]; /* Default routing tables for each network */
32 struct iface_patt
*router_id_from
; /* Configured list of router ID iface patterns */
34 u32 router_id
; /* Our Router ID */
35 unsigned proto_default_debug
; /* Default protocol debug mask */
36 unsigned proto_default_mrtdump
; /* Default protocol mrtdump mask */
37 struct timeformat tf_route
; /* Time format for 'show route' */
38 struct timeformat tf_proto
; /* Time format for 'show protocol' */
39 struct timeformat tf_log
; /* Time format for the logfile */
40 struct timeformat tf_base
; /* Time format for other purposes */
41 u32 gr_wait
; /* Graceful restart wait timeout (sec) */
43 int cli_debug
; /* Tracing of CLI connections and commands */
44 int latency_debug
; /* I/O loop tracks duration of each event */
45 u32 latency_limit
; /* Events with longer duration are logged (us) */
46 u32 watchdog_warning
; /* I/O loop watchdog limit for warning (us) */
47 u32 watchdog_timeout
; /* Watchdog timeout (in seconds, 0 = disabled) */
48 char *err_msg
; /* Parser error message */
49 int err_lino
; /* Line containing error */
50 int err_chno
; /* Character where the parser stopped */
51 char *err_file_name
; /* File name containing error */
52 char *file_name
; /* Name of main configuration file */
53 int file_fd
; /* File descriptor of main configuration file */
54 HASH(struct symbol
) sym_hash
; /* Lexer: symbol hash table */
55 struct config
*fallback
; /* Link to regular config for CLI parsing */
56 struct sym_scope
*root_scope
; /* Scope for root symbols */
57 int obstacle_count
; /* Number of items blocking freeing of this config */
58 int shutdown
; /* This is a pseudo-config for daemon shutdown */
59 int gr_down
; /* This is a pseudo-config for graceful restart */
60 btime load_time
; /* When we've got this configuration */
63 /* Please don't use these variables in protocols. Use proto_config->global instead. */
64 extern struct config
*config
; /* Currently active configuration */
65 extern struct config
*new_config
; /* Configuration being parsed */
67 struct config
*config_alloc(const char *name
);
68 int config_parse(struct config
*);
69 int cli_parse(struct config
*);
70 void config_free(struct config
*);
71 int config_commit(struct config
*, int type
, uint timeout
);
72 int config_confirm(void);
73 int config_undo(void);
74 int config_status(void);
75 btime
config_timer_status(void);
76 void config_init(void);
77 void cf_error(const char *msg
, ...) NORET
;
78 void config_add_obstacle(struct config
*);
79 void config_del_obstacle(struct config
*);
80 void order_shutdown(int gr
);
82 #define RECONFIG_NONE 0
83 #define RECONFIG_HARD 1
84 #define RECONFIG_SOFT 2
85 #define RECONFIG_UNDO 3
88 #define CONF_PROGRESS 1
90 #define CONF_UNQUEUED 3
91 #define CONF_CONFIRM 4
92 #define CONF_SHUTDOWN -1
93 #define CONF_NOTHING -2
98 extern linpool
*cfg_mem
;
100 #define cfg_alloc(size) lp_alloc(cfg_mem, size)
101 #define cfg_allocu(size) lp_allocu(cfg_mem, size)
102 #define cfg_allocz(size) lp_allocz(cfg_mem, size)
103 char *cfg_strdup(const char *c
);
104 void cfg_copy_list(list
*dest
, list
*src
, unsigned node_size
);
108 extern int (*cf_read_hook
)(byte
*buf
, uint max
, int fd
);
111 node n
; /* In list of symbols in config */
113 struct sym_scope
*scope
;
114 int class; /* SYM_* */
115 uint flags
; /* SYM_FLAG_* */
118 struct proto_config
*proto
; /* For SYM_PROTO and SYM_TEMPLATE */
119 const struct f_line
*function
; /* For SYM_FUNCTION */
120 const struct filter
*filter
; /* For SYM_FILTER */
121 struct rtable_config
*table
; /* For SYM_TABLE */
122 struct f_dynamic_attr
*attribute
; /* For SYM_ATTRIBUTE */
123 struct f_val
*val
; /* For SYM_CONSTANT */
124 uint offset
; /* For SYM_VARIABLE */
131 struct sym_scope
*next
; /* Next on scope stack */
132 struct symbol
*name
; /* Name of this scope */
133 uint slots
; /* Variable slots */
134 int active
; /* Currently entered */
137 #define SYM_MAX_LEN 64
139 /* Remember to update cf_symbol_class_name() */
142 #define SYM_TEMPLATE 2
143 #define SYM_FUNCTION 3
146 #define SYM_ATTRIBUTE 6
148 #define SYM_VARIABLE 0x100 /* 0x100-0x1ff are variable types */
149 #define SYM_VARIABLE_RANGE SYM_VARIABLE ... (SYM_VARIABLE | 0xff)
150 #define SYM_CONSTANT 0x200 /* 0x200-0x2ff are variable types */
151 #define SYM_CONSTANT_RANGE SYM_CONSTANT ... (SYM_CONSTANT | 0xff)
153 #define SYM_TYPE(s) ((s)->val->type)
154 #define SYM_VAL(s) ((s)->val->val)
157 #define SYM_FLAG_SAME 0x1 /* For SYM_FUNCTION and SYM_FILTER */
159 struct include_file_stack
{
160 void *buffer
; /* Internal lexer state */
161 char *file_name
; /* File name */
162 int fd
; /* File descriptor */
163 int lino
; /* Current line num */
164 int chno
; /* Current char num (on current line) */
165 int toklen
; /* Current token length */
166 int depth
; /* Include depth, 0 = cannot include */
168 struct include_file_stack
*prev
; /* Previous record in stack */
169 struct include_file_stack
*up
; /* Parent (who included this file) */
172 extern struct include_file_stack
*ifs
;
174 extern struct sym_scope
*conf_this_scope
;
177 void cf_lex_init(int is_cli
, struct config
*c
);
178 void cf_lex_unwind(void);
180 struct symbol
*cf_find_symbol(const struct config
*cfg
, const byte
*c
);
182 struct symbol
*cf_get_symbol(const byte
*c
);
183 struct symbol
*cf_default_name(char *template, int *counter
);
184 struct symbol
*cf_localize_symbol(struct symbol
*sym
);
187 * cf_define_symbol - define meaning of a symbol
188 * @sym: symbol to be defined
189 * @type: symbol class to assign
190 * @def: class dependent data
192 * Defines new meaning of a symbol. If the symbol is an undefined
193 * one (%SYM_VOID), it's just re-defined to the new type. If it's defined
194 * in different scope, a new symbol in current scope is created and the
195 * meaning is assigned to it. If it's already defined in the current scope,
196 * an error is reported via cf_error().
198 * Result: Pointer to the newly defined symbol. If we are in the top-level
199 * scope, it's the same @sym as passed to the function.
201 #define cf_define_symbol(sym_, type_, var_, def_) ({ \
202 struct symbol *sym = cf_localize_symbol(sym_); \
203 sym->class = type_; \
207 void cf_push_scope(struct symbol
*);
208 void cf_pop_scope(void);
209 char *cf_symbol_class_name(struct symbol
*sym
);
213 extern char *cf_text
;
218 void sysdep_preconfig(struct config
*);
219 int sysdep_commit(struct config
*, struct config
*);
220 void sysdep_shutdown_done(void);