diff options
author | Claudio Jeker <claudio@cvs.openbsd.org> | 2006-04-20 17:04:31 +0000 |
---|---|---|
committer | Claudio Jeker <claudio@cvs.openbsd.org> | 2006-04-20 17:04:31 +0000 |
commit | 1b1cba1df9dbdd38ec44c7068e96e633871dc9b7 (patch) | |
tree | 6b571d7d8a44bf19cb4c4aeab8fbe97b0f6f3d57 | |
parent | 97a68190c4791a956b4009ed9f1fa8d3db1d9a8b (diff) |
Simplify the defaults handling. This is long overdue and necessary to add
auth-type et al. to the main and area blocks. OK norby@
-rw-r--r-- | usr.sbin/ospfd/ospfd.h | 8 | ||||
-rw-r--r-- | usr.sbin/ospfd/parse.y | 238 |
2 files changed, 76 insertions, 170 deletions
diff --git a/usr.sbin/ospfd/ospfd.h b/usr.sbin/ospfd/ospfd.h index e65019e5b04..a128365cd4f 100644 --- a/usr.sbin/ospfd/ospfd.h +++ b/usr.sbin/ospfd/ospfd.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ospfd.h,v 1.54 2006/03/23 18:37:34 norby Exp $ */ +/* $OpenBSD: ospfd.h,v 1.55 2006/04/20 17:04:30 claudio Exp $ */ /* * Copyright (c) 2004 Esben Norby <norby@openbsd.org> @@ -169,13 +169,7 @@ struct area { /* list addr_range_list; */ u_int32_t stub_default_cost; u_int32_t num_spf_calc; - u_int32_t dead_interval; int active; - u_int16_t transmit_delay; - u_int16_t hello_interval; - u_int16_t rxmt_interval; - u_int16_t metric; - u_int8_t priority; u_int8_t transit; u_int8_t stub; u_int8_t dirty; diff --git a/usr.sbin/ospfd/parse.y b/usr.sbin/ospfd/parse.y index 3532218e03e..a7887687c3e 100644 --- a/usr.sbin/ospfd/parse.y +++ b/usr.sbin/ospfd/parse.y @@ -1,4 +1,4 @@ -/* $OpenBSD: parse.y,v 1.27 2006/03/15 13:29:45 claudio Exp $ */ +/* $OpenBSD: parse.y,v 1.28 2006/04/20 17:04:30 claudio Exp $ */ /* * Copyright (c) 2004, 2005 Esben Norby <norby@openbsd.org> @@ -63,14 +63,19 @@ void clear_config(struct ospfd_conf *xconf); int check_file_secrecy(int fd, const char *fname); u_int32_t get_rtr_id(void); -static struct { +struct config_defaults { u_int32_t dead_interval; u_int16_t transmit_delay; u_int16_t hello_interval; u_int16_t rxmt_interval; u_int16_t metric; u_int8_t priority; -} defaults; +}; + +struct config_defaults globaldefs; +struct config_defaults areadefs; +struct config_defaults ifacedefs; +struct config_defaults *defs; TAILQ_HEAD(symhead, sym) symhead = TAILQ_HEAD_INITIALIZER(symhead); struct sym { @@ -167,58 +172,7 @@ varset : STRING '=' string { } ; -conf_main : METRIC number { - if ($2 < MIN_METRIC || $2 > MAX_METRIC) { - yyerror("metric out of range (%d-%d)", - MIN_METRIC, MAX_METRIC); - YYERROR; - } - defaults.metric = $2; - } - | ROUTERPRIORITY number { - if ($2 < MIN_PRIORITY || $2 > MAX_PRIORITY) { - yyerror("router-priority out of range (%d-%d)", - MIN_PRIORITY, MAX_PRIORITY); - YYERROR; - } - defaults.priority = $2; - } - | ROUTERDEADTIME number { - if ($2 < MIN_RTR_DEAD_TIME || $2 > MAX_RTR_DEAD_TIME) { - yyerror("router-dead-time out of range (%d-%d)", - MIN_RTR_DEAD_TIME, MAX_RTR_DEAD_TIME); - YYERROR; - } - defaults.dead_interval = $2; - } - | TRANSMITDELAY number { - if ($2 < MIN_TRANSMIT_DELAY || - $2 > MAX_TRANSMIT_DELAY) { - yyerror("transmit-delay out of range (%d-%d)", - MIN_TRANSMIT_DELAY, MAX_TRANSMIT_DELAY); - YYERROR; - } - defaults.transmit_delay = $2; - } - | HELLOINTERVAL number { - if ($2 < MIN_HELLO_INTERVAL || - $2 > MAX_HELLO_INTERVAL) { - yyerror("hello-interval out of range (%d-%d)", - MIN_HELLO_INTERVAL, MAX_HELLO_INTERVAL); - YYERROR; - } - defaults.hello_interval = $2; - } - | RETRANSMITINTERVAL number { - if ($2 < MIN_RXMT_INTERVAL || $2 > MAX_RXMT_INTERVAL) { - yyerror("retransmit-interval out of range " - "(%d-%d)", MIN_RXMT_INTERVAL, - MAX_RXMT_INTERVAL); - YYERROR; - } - defaults.rxmt_interval = $2; - } - | ROUTERID STRING { +conf_main : ROUTERID STRING { if (!inet_aton($2, &conf->rtr_id)) { yyerror("error parsing router-id"); free($2); @@ -272,6 +226,7 @@ conf_main : METRIC number { } conf->spf_hold_time = $2; } + | defaults ; authmd : AUTHMD number STRING { @@ -333,83 +288,89 @@ authkey : AUTHKEY STRING { } ; -optnl : '\n' optnl - | - ; - -nl : '\n' optnl /* one newline or more */ - ; - -area : AREA STRING { - struct in_addr id; - if (inet_aton($2, &id) == 0) { - yyerror("error parsing area"); - free($2); - YYERROR; - } - free($2); - area = conf_get_area(id); - } '{' optnl areaopts_l '}' { - area = NULL; - } - ; - -areaopts_l : areaopts_l areaoptsl - | areaoptsl - ; - -areaoptsl : interface nl - | METRIC number nl { +defaults : METRIC number { if ($2 < MIN_METRIC || $2 > MAX_METRIC) { yyerror("metric out of range (%d-%d)", MIN_METRIC, MAX_METRIC); YYERROR; } - area->metric = $2; + defs->metric = $2; } - | ROUTERPRIORITY number nl { + | ROUTERPRIORITY number { if ($2 < MIN_PRIORITY || $2 > MAX_PRIORITY) { yyerror("router-priority out of range (%d-%d)", MIN_PRIORITY, MAX_PRIORITY); YYERROR; } - area->priority = $2; + defs->priority = $2; } - | ROUTERDEADTIME number nl { + | ROUTERDEADTIME number { if ($2 < MIN_RTR_DEAD_TIME || $2 > MAX_RTR_DEAD_TIME) { yyerror("router-dead-time out of range (%d-%d)", MIN_RTR_DEAD_TIME, MAX_RTR_DEAD_TIME); YYERROR; } - area->dead_interval = $2; + defs->dead_interval = $2; } - | TRANSMITDELAY number nl { + | TRANSMITDELAY number { if ($2 < MIN_TRANSMIT_DELAY || $2 > MAX_TRANSMIT_DELAY) { yyerror("transmit-delay out of range (%d-%d)", MIN_TRANSMIT_DELAY, MAX_TRANSMIT_DELAY); YYERROR; } - area->transmit_delay = $2; + defs->transmit_delay = $2; } - | HELLOINTERVAL number nl { + | HELLOINTERVAL number { if ($2 < MIN_HELLO_INTERVAL || $2 > MAX_HELLO_INTERVAL) { yyerror("hello-interval out of range (%d-%d)", MIN_HELLO_INTERVAL, MAX_HELLO_INTERVAL); YYERROR; } - area->hello_interval = $2; + defs->hello_interval = $2; } - | RETRANSMITINTERVAL number nl { + | RETRANSMITINTERVAL number { if ($2 < MIN_RXMT_INTERVAL || $2 > MAX_RXMT_INTERVAL) { yyerror("retransmit-interval out of range " "(%d-%d)", MIN_RXMT_INTERVAL, MAX_RXMT_INTERVAL); YYERROR; } - area->rxmt_interval = $2; + defs->rxmt_interval = $2; } + +optnl : '\n' optnl + | + ; + +nl : '\n' optnl /* one newline or more */ + ; + +area : AREA STRING { + struct in_addr id; + if (inet_aton($2, &id) == 0) { + yyerror("error parsing area"); + free($2); + YYERROR; + } + free($2); + area = conf_get_area(id); + + memcpy(&areadefs, defs, sizeof(areadefs)); + defs = &areadefs; + } '{' optnl areaopts_l '}' { + area = NULL; + defs = &globaldefs; + } + ; + +areaopts_l : areaopts_l areaoptsl + | areaoptsl + ; + +areaoptsl : interface nl + | defaults nl ; interface : INTERFACE STRING { @@ -427,8 +388,20 @@ interface : INTERFACE STRING { iface->area = area; LIST_INSERT_HEAD(&area->iface_list, iface, entry); + + memcpy(&ifacedefs, defs, sizeof(ifacedefs)); + defs = &ifacedefs; } interface_block { + iface->dead_interval = defs->dead_interval; + iface->transmit_delay = defs->transmit_delay; + iface->hello_interval = defs->hello_interval; + iface->rxmt_interval = defs->rxmt_interval; + iface->metric = defs->metric; + iface->priority = defs->priority; + iface = NULL; + /* interface is always part of an area */ + defs = &areadefs; } ; @@ -446,57 +419,7 @@ interfaceoptsl : authmd nl | authmdkeyid nl | authtype nl | PASSIVE nl { iface->passive = 1; } - | METRIC number nl { - if ($2 < MIN_METRIC || $2 > MAX_METRIC) { - yyerror("metric out of range (%d-%d)", - MIN_METRIC, MAX_METRIC); - YYERROR; - } - iface->metric = $2; - } - | ROUTERPRIORITY number nl { - if ($2 < MIN_PRIORITY || $2 > MAX_PRIORITY) { - yyerror("router-priority out of range (%d-%d)", - MIN_PRIORITY, MAX_PRIORITY); - YYERROR; - } - iface->priority = $2; - } - | ROUTERDEADTIME number nl { - if ($2 < MIN_RTR_DEAD_TIME || $2 > MAX_RTR_DEAD_TIME) { - yyerror("router-dead-time out of range (%d-%d)", - MIN_RTR_DEAD_TIME, MAX_RTR_DEAD_TIME); - YYERROR; - } - iface->dead_interval = $2; - } - | TRANSMITDELAY number nl { - if ($2 < MIN_TRANSMIT_DELAY || - $2 > MAX_TRANSMIT_DELAY) { - yyerror("transmit-delay out of range (%d-%d)", - MIN_TRANSMIT_DELAY, MAX_TRANSMIT_DELAY); - YYERROR; - } - iface->transmit_delay = $2; - } - | HELLOINTERVAL number nl { - if ($2 < MIN_HELLO_INTERVAL || - $2 > MAX_HELLO_INTERVAL) { - yyerror("hello-interval out of range (%d-%d)", - MIN_HELLO_INTERVAL, MAX_HELLO_INTERVAL); - YYERROR; - } - iface->hello_interval = $2; - } - | RETRANSMITINTERVAL number nl { - if ($2 < MIN_RXMT_INTERVAL || $2 > MAX_RXMT_INTERVAL) { - yyerror("retransmit-interval out of range " - "(%d-%d)", MIN_RXMT_INTERVAL, - MAX_RXMT_INTERVAL); - YYERROR; - } - iface->rxmt_interval = $2; - } + | defaults nl ; %% @@ -765,12 +688,14 @@ parse_config(char *filename, int opts) return (NULL); } - defaults.dead_interval = DEFAULT_RTR_DEAD_TIME; - defaults.transmit_delay = DEFAULT_TRANSMIT_DELAY; - defaults.hello_interval = DEFAULT_HELLO_INTERVAL; - defaults.rxmt_interval = DEFAULT_RXMT_INTERVAL; - defaults.metric = DEFAULT_METRIC; - defaults.priority = DEFAULT_PRIORITY; + bzero(&globaldefs, sizeof(globaldefs)); + defs = &globaldefs; + defs->dead_interval = DEFAULT_RTR_DEAD_TIME; + defs->transmit_delay = DEFAULT_TRANSMIT_DELAY; + defs->hello_interval = DEFAULT_HELLO_INTERVAL; + defs->rxmt_interval = DEFAULT_RXMT_INTERVAL; + defs->metric = DEFAULT_METRIC; + defs->priority = DEFAULT_PRIORITY; conf->options = OSPF_OPTION_E; conf->spf_delay = DEFAULT_SPF_DELAY; @@ -924,13 +849,6 @@ conf_get_area(struct in_addr id) a = area_new(); LIST_INSERT_HEAD(&conf->area_list, a, entry); - a->dead_interval = defaults.dead_interval; - a->transmit_delay = defaults.transmit_delay; - a->hello_interval = defaults.hello_interval; - a->rxmt_interval = defaults.rxmt_interval; - a->metric = defaults.metric; - a->priority = defaults.priority; - a->id.s_addr = id.s_addr; return (a); @@ -951,12 +869,6 @@ conf_get_if(struct kif *kif) } i = if_new(kif); - i->dead_interval = area->dead_interval; - i->transmit_delay = area->transmit_delay; - i->hello_interval = area->hello_interval; - i->rxmt_interval = area->rxmt_interval; - i->metric = area->metric; - i->priority = area->priority; i->auth_keyid = 1; return (i); |