Annotation of embedaddon/bird2/conf/conf.h, revision 1.1.1.1

1.1       misho       1: /*
                      2:  *     BIRD Internet Routing Daemon -- Configuration File Handling
                      3:  *
                      4:  *     (c) 1998--2000 Martin Mares <mj@ucw.cz>
                      5:  *
                      6:  *     Can be freely distributed and used under the terms of the GNU GPL.
                      7:  */
                      8: 
                      9: #ifndef _BIRD_CONF_H_
                     10: #define _BIRD_CONF_H_
                     11: 
                     12: #include "sysdep/config.h"
                     13: #include "lib/ip.h"
                     14: #include "lib/hash.h"
                     15: #include "lib/resource.h"
                     16: #include "lib/timer.h"
                     17: 
                     18: /* Configuration structure */
                     19: 
                     20: struct config {
                     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 */
                     28: 
                     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 */
                     33: 
                     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) */
                     42: 
                     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 */
                     61: };
                     62: 
                     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 */
                     66: 
                     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);
                     81: 
                     82: #define RECONFIG_NONE  0
                     83: #define RECONFIG_HARD  1
                     84: #define RECONFIG_SOFT  2
                     85: #define RECONFIG_UNDO  3
                     86: 
                     87: #define CONF_DONE      0
                     88: #define CONF_PROGRESS  1
                     89: #define CONF_QUEUED    2
                     90: #define CONF_UNQUEUED  3
                     91: #define CONF_CONFIRM   4
                     92: #define CONF_SHUTDOWN  -1
                     93: #define CONF_NOTHING   -2
                     94: 
                     95: 
                     96: /* Pools */
                     97: 
                     98: extern linpool *cfg_mem;
                     99: 
                    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);
                    105: 
                    106: /* Lexer */
                    107: 
                    108: extern int (*cf_read_hook)(byte *buf, uint max, int fd);
                    109: 
                    110: struct symbol {
                    111:   node n;                              /* In list of symbols in config */
                    112:   struct symbol *next;
                    113:   struct sym_scope *scope;
                    114:   int class;                           /* SYM_* */
                    115:   uint flags;                          /* SYM_FLAG_* */
                    116: 
                    117:   union {
                    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 */
                    125:   };
                    126: 
                    127:   char name[0];
                    128: };
                    129: 
                    130: struct sym_scope {
                    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 */
                    135: };
                    136: 
                    137: #define SYM_MAX_LEN 64
                    138: 
                    139: /* Remember to update cf_symbol_class_name() */
                    140: #define SYM_VOID 0
                    141: #define SYM_PROTO 1
                    142: #define SYM_TEMPLATE 2
                    143: #define SYM_FUNCTION 3
                    144: #define SYM_FILTER 4
                    145: #define SYM_TABLE 5
                    146: #define SYM_ATTRIBUTE 6
                    147: 
                    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)
                    152: 
                    153: #define SYM_TYPE(s) ((s)->val->type)
                    154: #define SYM_VAL(s) ((s)->val->val)
                    155: 
                    156: /* Symbol flags */
                    157: #define SYM_FLAG_SAME 0x1      /* For SYM_FUNCTION and SYM_FILTER */
                    158: 
                    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 */
                    167: 
                    168:   struct include_file_stack *prev;     /* Previous record in stack */
                    169:   struct include_file_stack *up;       /* Parent (who included this file) */
                    170: };
                    171: 
                    172: extern struct include_file_stack *ifs;
                    173: 
                    174: extern struct sym_scope *conf_this_scope;
                    175: 
                    176: int cf_lex(void);
                    177: void cf_lex_init(int is_cli, struct config *c);
                    178: void cf_lex_unwind(void);
                    179: 
                    180: struct symbol *cf_find_symbol(const struct config *cfg, const byte *c);
                    181: 
                    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);
                    185: 
                    186: /**
                    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
                    191:  *
                    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().
                    197:  *
                    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.
                    200:  */
                    201: #define cf_define_symbol(sym_, type_, var_, def_) ({ \
                    202:     struct symbol *sym = cf_localize_symbol(sym_); \
                    203:     sym->class = type_; \
                    204:     sym->var_ = def_; \
                    205:     sym; })
                    206: 
                    207: void cf_push_scope(struct symbol *);
                    208: void cf_pop_scope(void);
                    209: char *cf_symbol_class_name(struct symbol *sym);
                    210: 
                    211: /* Parser */
                    212: 
                    213: extern char *cf_text;
                    214: int cf_parse(void);
                    215: 
                    216: /* Sysdep hooks */
                    217: 
                    218: void sysdep_preconfig(struct config *);
                    219: int sysdep_commit(struct config *, struct config *);
                    220: void sysdep_shutdown_done(void);
                    221: 
                    222: #endif

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>