Statistics
| Branch: | Revision:

iof-bird-daemon / conf / confbase.Y @ d14f8c3c

History | View | Annotate | Download (6.06 KB)

1
/*
2
 *	BIRD -- Configuration Parser Top
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
CF_HDR
10

    
11
#define PARSER 1
12

    
13
#include "nest/bird.h"
14
#include "conf/conf.h"
15
#include "lib/resource.h"
16
#include "lib/socket.h"
17
#include "sysdep/unix/timer.h"
18
#include "lib/string.h"
19
#include "nest/protocol.h"
20
#include "nest/iface.h"
21
#include "nest/route.h"
22
#include "nest/cli.h"
23
#include "filter/filter.h"
24

    
25
/* FIXME: Turn on YYERROR_VERBOSE and work around lots of bison bugs? */
26

    
27
CF_DEFINES
28

    
29
static void
30
check_u16(unsigned val)
31
{
32
  if (val > 0xFFFF)
33
    cf_error("Value %d out of range (0-65535)", val);
34
}
35

    
36
CF_DECLS
37

    
38
%union {
39
  int i;
40
  u32 i32;
41
  ip_addr a;
42
  ip4_addr ip4;
43
  ip6_addr ip6;
44
  net_addr net;
45
  net_addr *net_ptr;
46
  struct symbol *s;
47
  char *t;
48
  struct rtable_config *r;
49
  struct channel_config *cc;
50
  struct f_inst *x;
51
  struct filter *f;
52
  struct f_tree *e;
53
  struct f_trie *trie;
54
  struct f_val v;
55
  struct f_path_mask *h;
56
  struct password_item *p;
57
  struct rt_show_data *ra;
58
  struct sym_show_data *sd;
59
  struct lsadb_show_data *ld;
60
  struct iface *iface;
61
  void *g;
62
  bird_clock_t time;
63
  struct f_prefix px;
64
  struct proto_spec ps;
65
  struct channel_limit cl;
66
  struct timeformat *tf;
67
  u32 *lbl;
68
}
69

    
70
%token END CLI_MARKER INVALID_TOKEN ELSECOL DDOT
71
%token GEQ LEQ NEQ AND OR
72
%token PO PC
73
%token <i> NUM ENUM
74
%token <ip4> IP4
75
%token <ip6> IP6
76
%token <s> SYM
77
%token <t> TEXT
78
%type <iface> ipa_scope
79

    
80
%type <i> expr bool pxlen4
81
%type <i32> expr_us
82
%type <time> datetime
83
%type <a> ipa
84
%type <net> net_ip4_ net_ip6_ net_ip6 net_ip_ net_ip net_or_ipa
85
%type <net_ptr> net_ net_any net_roa4_ net_roa6_ net_roa_
86
%type <lbl> label_stack_start label_stack
87

    
88
%type <t> text opttext
89

    
90
%nonassoc PREFIX_DUMMY
91
%left AND OR
92
%nonassoc '=' '<' '>' '~' GEQ LEQ NEQ NMA PO PC
93
%left '+' '-'
94
%left '*' '/' '%'
95
%left '!'
96
%nonassoc '.'
97

    
98
CF_KEYWORDS(DEFINE, ON, OFF, YES, NO, S, MS, US, PORT)
99

    
100
CF_GRAMMAR
101

    
102
/* Basic config file structure */
103

    
104
config: conf_entries END { return 0; }
105
 | CLI_MARKER cli_cmd { return 0; }
106
 ;
107

    
108
conf_entries:
109
   /* EMPTY */
110
 | conf_entries conf
111
 ;
112

    
113
CF_ADDTO(conf, ';')
114

    
115

    
116
/* Constant expressions */
117

    
118
CF_ADDTO(conf, definition)
119
definition:
120
   DEFINE SYM '=' term ';' {
121
     struct f_val *val = cfg_alloc(sizeof(struct f_val));
122
     *val = f_eval($4, cfg_mem);
123
     if (val->type == T_RETURN) cf_error("Runtime error");
124
     cf_define_symbol($2, SYM_CONSTANT | val->type, val);
125
   }
126
 ;
127

    
128
expr:
129
   NUM
130
 | '(' term ')' { $$ = f_eval_int($2); }
131
 | SYM {
132
     if ($1->class != (SYM_CONSTANT | T_INT)) cf_error("Number expected");
133
     $$ = SYM_VAL($1).i; }
134
 ;
135

    
136

    
137
expr_us:
138
   expr S  { $$ = (u32) $1 * 1000000; }
139
 | expr MS { $$ = (u32) $1 * 1000; }
140
 | expr US { $$ = (u32) $1 * 1; }
141
 ;
142

    
143
/* Switches */
144

    
145
bool:
146
   expr { $$ = !!$1; }
147
 | ON { $$ = 1; }
148
 | YES { $$ = 1; }
149
 | OFF { $$ = 0; }
150
 | NO { $$ = 0; }
151
 | /* Silence means agreement */ { $$ = 1; }
152
 ;
153

    
154

    
155
/* Addresses */
156

    
157
ipa:
158
   IP4 { $$ = ipa_from_ip4($1); }
159
 | IP6 { $$ = ipa_from_ip6($1); }
160
 | SYM {
161
     if ($1->class != (SYM_CONSTANT | T_IP)) cf_error("IP address expected");
162
     $$ = SYM_VAL($1).ip;
163
   }
164
 ;
165

    
166
ipa_scope:
167
   /* empty */ { $$ = NULL; }
168
 | '%' SYM { $$ = if_get_by_name($2->name); }
169
 ;
170

    
171

    
172
/* Networks - internal */
173

    
174
pxlen4:
175
   '/' NUM {
176
     if ($2 < 0 || $2 > IP4_MAX_PREFIX_LENGTH) cf_error("Invalid prefix length %d", $2);
177
     $$ = $2;
178
   }
179
 | ':' IP4 {
180
     $$ = ip4_masklen($2);
181
     if ($$ == 255) cf_error("Invalid netmask %I4", $2);
182
   }
183
 ;
184

    
185
net_ip4_: IP4 pxlen4
186
{
187
  net_fill_ip4(&($$), $1, $2);
188
  if (!net_validate_ip4((net_addr_ip4 *) &($$)))
189
    cf_error("Invalid IPv4 prefix");
190
};
191

    
192
net_ip6_: IP6 '/' NUM
193
{
194
  net_fill_ip6(&($$), $1, $3);
195
  if ($3 < 0 || $3 > IP6_MAX_PREFIX_LENGTH)
196
    cf_error("Invalid prefix length %d", $3);
197
  if (!net_validate_ip6((net_addr_ip6 *) &($$)))
198
    cf_error("Invalid IPv6 prefix");
199
};
200

    
201
net_roa4_: net_ip4_ MAX NUM AS NUM
202
{
203
  $$ = cfg_alloc(sizeof(net_addr_roa4));
204
  net_fill_roa4($$, net4_prefix(&$1), net4_pxlen(&$1), $3, $5);
205
  if ($3 < (int) net4_pxlen(&$1) || $3 > IP4_MAX_PREFIX_LENGTH)
206
    cf_error("Invalid max prefix length %d", $3);
207
};
208

    
209
net_roa6_: net_ip6_ MAX NUM AS NUM
210
{
211
  $$ = cfg_alloc(sizeof(net_addr_roa6));
212
  net_fill_roa6($$, net6_prefix(&$1), net6_pxlen(&$1), $3, $5);
213
  if ($3 < (int) net6_pxlen(&$1) || $3 > IP6_MAX_PREFIX_LENGTH)
214
    cf_error("Invalid max prefix length %d", $3);
215
};
216

    
217
net_ip_: net_ip4_ | net_ip6_ ;
218
net_roa_: net_roa4_ | net_roa6_ ;
219

    
220
net_:
221
   net_ip_ { $$ = cfg_alloc($1.length); net_copy($$, &($1)); }
222
 | net_roa_
223
 | net_flow_
224
 ;
225

    
226

    
227
/* Networks - regular */
228

    
229
net_ip6:
230
   net_ip6_
231
 | SYM {
232
     if (($1->class != (SYM_CONSTANT | T_NET)) || (SYM_VAL($1).net->type != NET_IP6))
233
       cf_error("IPv6 network expected");
234
     $$ = * SYM_VAL($1).net;
235
   }
236
 ;
237

    
238
net_ip:
239
   net_ip_
240
 | SYM {
241
     if (($1->class != (SYM_CONSTANT | T_NET)) || !net_is_ip(SYM_VAL($1).net))
242
       cf_error("IP network expected");
243
     $$ = * SYM_VAL($1).net;
244
   }
245
 ;
246

    
247
net_any:
248
   net_
249
 | SYM {
250
     if ($1->class != (SYM_CONSTANT | T_NET))
251
       cf_error("Network expected");
252
     $$ = (net_addr *) SYM_VAL($1).net; /* Avoid const warning */
253
   }
254
 ;
255

    
256
net_or_ipa:
257
   net_ip4_
258
 | net_ip6_
259
 | IP4 { net_fill_ip4(&($$), $1, IP4_MAX_PREFIX_LENGTH); }
260
 | IP6 { net_fill_ip6(&($$), $1, IP6_MAX_PREFIX_LENGTH); }
261
 | SYM {
262
     if ($1->class == (SYM_CONSTANT | T_IP))
263
       net_fill_ip_host(&($$), SYM_VAL($1).ip);
264
     else if (($1->class == (SYM_CONSTANT | T_NET)) && net_is_ip(SYM_VAL($1).net))
265
       $$ = * SYM_VAL($1).net;
266
     else
267
       cf_error("IP address or network expected");
268
   }
269
 ;
270

    
271
label_stack_start: NUM
272
{
273
  $$ = cfg_allocz(sizeof(u32) * (MPLS_MAX_LABEL_STACK+1));
274
  $$[0] = 1;
275
  $$[1] = $1;
276
};
277

    
278
label_stack:
279
    label_stack_start
280
  | label_stack '/' NUM {
281
    if ($1[0] >= MPLS_MAX_LABEL_STACK)
282
      cf_error("Too many labels in stack.");
283
    $1[++$1[0]] = $3;
284
    $$ = $1;
285
  }
286
;
287

    
288
datetime:
289
   TEXT {
290
     $$ = tm_parse_datetime($1);
291
     if (!$$)
292
       cf_error("Invalid date and time");
293
   }
294
 ;
295

    
296
text:
297
   TEXT
298
 | SYM {
299
     if ($1->class != (SYM_CONSTANT | T_STRING)) cf_error("String expected");
300
     $$ = SYM_VAL($1).s;
301
   }
302
 ;
303

    
304
opttext:
305
    TEXT
306
 | /* empty */ { $$ = NULL; }
307
 ;
308

    
309

    
310
CF_CODE
311

    
312
CF_END