1998-12-06 17:40:42 +00:00
|
|
|
/*
|
|
|
|
* BIRD -- UNIX Kernel Syncer Configuration
|
|
|
|
*
|
2000-01-17 11:52:50 +00:00
|
|
|
* (c) 1998--2000 Martin Mares <mj@ucw.cz>
|
1998-12-06 17:40:42 +00:00
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
CF_HDR
|
|
|
|
|
|
|
|
#include "lib/krt.h"
|
|
|
|
|
2000-04-28 15:11:10 +00:00
|
|
|
CF_DEFINES
|
|
|
|
|
1999-03-03 19:49:56 +00:00
|
|
|
#define THIS_KRT ((struct krt_config *) this_proto)
|
1999-03-26 21:44:38 +00:00
|
|
|
#define THIS_KIF ((struct kif_config *) this_proto)
|
1999-03-03 19:49:56 +00:00
|
|
|
|
1998-12-06 17:40:42 +00:00
|
|
|
CF_DECLS
|
|
|
|
|
2010-04-04 15:41:31 +02:00
|
|
|
CF_KEYWORDS(KERNEL, PERSIST, SCAN, TIME, LEARN, DEVICE, ROUTES)
|
1998-12-06 17:40:42 +00:00
|
|
|
|
|
|
|
CF_GRAMMAR
|
|
|
|
|
1999-03-26 21:44:38 +00:00
|
|
|
/* Kernel syncer protocol */
|
1998-12-06 17:40:42 +00:00
|
|
|
|
|
|
|
CF_ADDTO(proto, kern_proto '}')
|
|
|
|
|
|
|
|
kern_proto_start: proto_start KERNEL {
|
1999-08-03 19:33:22 +00:00
|
|
|
#ifndef CONFIG_MULTIPLE_TABLES
|
1999-03-26 21:44:38 +00:00
|
|
|
if (cf_krt)
|
|
|
|
cf_error("Kernel protocol already defined");
|
1999-08-03 19:33:22 +00:00
|
|
|
#endif
|
2011-11-07 00:31:23 +01:00
|
|
|
cf_krt = this_proto = proto_config_new(&proto_unix_kernel, sizeof(struct krt_config), $1);
|
2000-05-08 10:40:00 +00:00
|
|
|
this_proto->preference = DEF_PREF_INHERITED;
|
1999-03-26 21:44:38 +00:00
|
|
|
THIS_KRT->scan_time = 60;
|
|
|
|
THIS_KRT->learn = THIS_KRT->persist = 0;
|
1999-08-03 19:33:22 +00:00
|
|
|
krt_scan_construct(THIS_KRT);
|
|
|
|
krt_set_construct(THIS_KRT);
|
1998-12-06 17:40:42 +00:00
|
|
|
}
|
|
|
|
;
|
|
|
|
|
1999-03-26 21:44:38 +00:00
|
|
|
CF_ADDTO(kern_proto, kern_proto_start proto_name '{')
|
1998-12-06 17:40:42 +00:00
|
|
|
CF_ADDTO(kern_proto, kern_proto proto_item ';')
|
1999-03-03 19:49:56 +00:00
|
|
|
CF_ADDTO(kern_proto, kern_proto kern_item ';')
|
|
|
|
|
|
|
|
kern_item:
|
|
|
|
PERSIST bool { THIS_KRT->persist = $2; }
|
|
|
|
| SCAN TIME expr {
|
|
|
|
/* Scan time of 0 means scan on startup only */
|
|
|
|
THIS_KRT->scan_time = $3;
|
|
|
|
}
|
1999-04-03 13:05:18 +00:00
|
|
|
| LEARN bool {
|
|
|
|
THIS_KRT->learn = $2;
|
|
|
|
#ifndef KRT_ALLOW_LEARN
|
|
|
|
if ($2)
|
|
|
|
cf_error("Learning of kernel routes not supported in this configuration");
|
|
|
|
#endif
|
|
|
|
}
|
2010-04-04 15:41:31 +02:00
|
|
|
| DEVICE ROUTES bool { THIS_KRT->devroutes = $3; }
|
1999-03-03 19:49:56 +00:00
|
|
|
;
|
1998-12-06 17:40:42 +00:00
|
|
|
|
1999-03-26 21:44:38 +00:00
|
|
|
/* Kernel interface protocol */
|
|
|
|
|
|
|
|
CF_ADDTO(proto, kif_proto '}')
|
|
|
|
|
|
|
|
kif_proto_start: proto_start DEVICE {
|
|
|
|
if (cf_kif)
|
|
|
|
cf_error("Kernel device protocol already defined");
|
2011-11-07 00:31:23 +01:00
|
|
|
cf_kif = this_proto = proto_config_new(&proto_unix_iface, sizeof(struct kif_config), $1);
|
1999-03-26 21:44:38 +00:00
|
|
|
this_proto->preference = DEF_PREF_DIRECT;
|
|
|
|
THIS_KIF->scan_time = 60;
|
2009-05-29 13:32:24 +02:00
|
|
|
init_list(&THIS_KIF->primary);
|
1999-08-03 19:33:22 +00:00
|
|
|
krt_if_construct(THIS_KIF);
|
1999-03-26 21:44:38 +00:00
|
|
|
}
|
|
|
|
;
|
|
|
|
|
2000-01-17 11:52:50 +00:00
|
|
|
CF_ADDTO(kif_proto, kif_proto_start proto_name '{')
|
1999-03-26 21:44:38 +00:00
|
|
|
CF_ADDTO(kif_proto, kif_proto proto_item ';')
|
|
|
|
CF_ADDTO(kif_proto, kif_proto kif_item ';')
|
|
|
|
|
|
|
|
kif_item:
|
|
|
|
SCAN TIME expr {
|
|
|
|
/* Scan time of 0 means scan on startup only */
|
|
|
|
THIS_KIF->scan_time = $3;
|
|
|
|
}
|
2009-05-29 22:49:30 +02:00
|
|
|
| PRIMARY text_or_none prefix_or_ipa {
|
2009-05-29 13:32:24 +02:00
|
|
|
struct kif_primary_item *kpi = cfg_alloc(sizeof (struct kif_primary_item));
|
|
|
|
kpi->pattern = $2;
|
|
|
|
kpi->prefix = $3.addr;
|
|
|
|
kpi->pxlen = $3.len;
|
|
|
|
add_tail(&THIS_KIF->primary, &kpi->n);
|
|
|
|
}
|
1999-03-26 21:44:38 +00:00
|
|
|
;
|
|
|
|
|
1998-12-06 17:40:42 +00:00
|
|
|
CF_CODE
|
|
|
|
|
|
|
|
CF_END
|