1999-12-06 13:45:56 +00:00
|
|
|
/*
|
|
|
|
* BIRD -- UNIX Configuration
|
|
|
|
*
|
2000-01-16 16:44:50 +00:00
|
|
|
* (c) 1999--2000 Martin Mares <mj@ucw.cz>
|
1999-12-06 13:45:56 +00:00
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
CF_HDR
|
|
|
|
|
2016-04-12 11:14:54 +02:00
|
|
|
#include "sysdep/unix/unix.h"
|
2002-11-13 08:30:56 +00:00
|
|
|
#include <stdio.h>
|
1999-12-06 13:45:56 +00:00
|
|
|
|
2018-11-14 17:16:05 +01:00
|
|
|
CF_DEFINES
|
|
|
|
|
|
|
|
static struct log_config *this_log;
|
|
|
|
|
1999-12-06 13:45:56 +00:00
|
|
|
CF_DECLS
|
|
|
|
|
2024-01-28 23:01:39 +01:00
|
|
|
CF_KEYWORDS(LOG, SYSLOG, ALL, DEBUG, TRACE, INFO, REMOTE, WARNING, ERROR, AUTH, FATAL, BUG, STDERR, SOFT, UDP, PORT)
|
2019-06-12 16:13:21 +02:00
|
|
|
CF_KEYWORDS(NAME, CONFIRM, UNDO, CHECK, TIMEOUT, DEBUG, LATENCY, LIMIT, WATCHDOG, WARNING, STATUS)
|
2024-06-26 20:45:54 +02:00
|
|
|
CF_KEYWORDS(PING, WAKEUP, SOCKETS, SCHEDULING, EVENTS, TIMERS, ALLOCATOR)
|
2023-08-24 17:00:54 +02:00
|
|
|
CF_KEYWORDS(GRACEFUL, RESTART, FIXED)
|
2024-10-01 10:24:04 +02:00
|
|
|
CF_KEYWORDS(MEMORY, GLOBAL, LOCAL, KEEP, HOT, ALLOCATE, BLOCK)
|
1999-12-06 13:45:56 +00:00
|
|
|
|
2024-06-07 12:12:00 +02:00
|
|
|
%type <i> log_mask log_mask_list log_cat cfg_timeout debug_unix latency_debug_mask latency_debug_flag latency_debug_list
|
2000-01-16 16:44:50 +00:00
|
|
|
%type <t> cfg_name
|
2010-02-03 00:19:24 +01:00
|
|
|
%type <tf> timeformat_which
|
2010-04-07 11:00:36 +02:00
|
|
|
%type <t> syslog_name
|
1999-12-06 13:45:56 +00:00
|
|
|
|
|
|
|
CF_GRAMMAR
|
|
|
|
|
2018-06-26 14:29:03 +02:00
|
|
|
conf: log_config ;
|
1999-12-06 13:45:56 +00:00
|
|
|
|
2018-11-14 17:16:05 +01:00
|
|
|
log_begin: { this_log = cfg_allocz(sizeof(struct log_config)); };
|
|
|
|
|
|
|
|
log_config: LOG log_begin log_file log_mask ';' {
|
|
|
|
this_log->mask = $4;
|
|
|
|
add_tail(&new_config->logfiles, &this_log->n);
|
1999-12-06 13:45:56 +00:00
|
|
|
}
|
|
|
|
;
|
|
|
|
|
2010-04-07 11:00:36 +02:00
|
|
|
syslog_name:
|
2014-05-29 23:05:03 +02:00
|
|
|
NAME text { $$ = $2; }
|
2010-04-07 11:00:36 +02:00
|
|
|
| { $$ = bird_name; }
|
|
|
|
;
|
|
|
|
|
2018-11-14 17:16:05 +01:00
|
|
|
log_limit:
|
|
|
|
/* empty */
|
|
|
|
| expr text { this_log->limit = $1; this_log->backup = $2; }
|
|
|
|
;
|
|
|
|
|
1999-12-06 13:51:04 +00:00
|
|
|
log_file:
|
2018-11-14 17:16:05 +01:00
|
|
|
text log_limit {
|
2020-05-31 13:21:55 +02:00
|
|
|
if (!parse_and_exit)
|
|
|
|
{
|
2023-08-24 15:38:44 +02:00
|
|
|
this_log->rf = rf_open(new_config->pool, $1, RF_APPEND, this_log->limit);
|
2020-05-31 13:21:55 +02:00
|
|
|
if (!this_log->rf) cf_error("Unable to open log file '%s': %m", $1);
|
|
|
|
}
|
2018-11-14 17:16:05 +01:00
|
|
|
this_log->filename = $1;
|
1999-12-06 13:51:04 +00:00
|
|
|
}
|
2023-08-24 17:00:54 +02:00
|
|
|
| FIXED text expr {
|
|
|
|
if (!parse_and_exit)
|
|
|
|
{
|
|
|
|
this_log->rf = rf_open(new_config->pool, $2, RF_FIXED, this_log->limit = $3);
|
|
|
|
if (!this_log->rf) cf_error("Unable to open log file '%s': %m", $2);
|
|
|
|
}
|
|
|
|
this_log->filename = $2;
|
|
|
|
}
|
2023-08-16 15:05:36 +02:00
|
|
|
| SYSLOG syslog_name { this_log->rf = NULL; new_config->syslog_name = $2; }
|
2024-01-28 21:42:39 +01:00
|
|
|
| STDERR { this_log->rf = &rf_stderr; this_log->terminal_flag = 1; }
|
2024-01-28 23:01:39 +01:00
|
|
|
| UDP log_udp_host log_udp_port { this_log->rf = NULL; }
|
1999-12-06 13:51:04 +00:00
|
|
|
;
|
|
|
|
|
2023-12-13 03:48:12 +01:00
|
|
|
log_udp_host: text_or_ipa
|
|
|
|
{
|
|
|
|
if ($1.type == T_STRING)
|
2024-01-28 23:01:39 +01:00
|
|
|
this_log->udp_host = $1.val.s;
|
2023-12-13 03:48:12 +01:00
|
|
|
else if ($1.type == T_IP)
|
2024-01-28 23:01:39 +01:00
|
|
|
this_log->udp_ip = $1.val.ip;
|
2023-12-13 03:48:12 +01:00
|
|
|
else bug("Bad text_or_ipa");
|
|
|
|
};
|
|
|
|
|
|
|
|
log_udp_port:
|
2024-01-28 23:01:39 +01:00
|
|
|
/* empty */ { this_log->udp_port = 514; }
|
|
|
|
| PORT NUM { check_u16($2); this_log->udp_port = $2; }
|
2023-12-13 03:48:12 +01:00
|
|
|
;
|
|
|
|
|
1999-12-06 13:45:56 +00:00
|
|
|
log_mask:
|
|
|
|
ALL { $$ = ~0; }
|
|
|
|
| '{' log_mask_list '}' { $$ = $2; }
|
|
|
|
;
|
|
|
|
|
|
|
|
log_mask_list:
|
|
|
|
log_cat { $$ = 1 << $1; }
|
|
|
|
| log_mask_list ',' log_cat { $$ = $1 | (1 << $3); }
|
|
|
|
;
|
|
|
|
|
|
|
|
log_cat:
|
|
|
|
DEBUG { $$ = L_DEBUG[0]; }
|
|
|
|
| TRACE { $$ = L_TRACE[0]; }
|
|
|
|
| INFO { $$ = L_INFO[0]; }
|
|
|
|
| REMOTE { $$ = L_REMOTE[0]; }
|
|
|
|
| WARNING { $$ = L_WARN[0]; }
|
|
|
|
| ERROR { $$ = L_ERR[0]; }
|
|
|
|
| AUTH { $$ = L_AUTH[0]; }
|
|
|
|
| FATAL { $$ = L_FATAL[0]; }
|
|
|
|
| BUG { $$ = L_BUG[0]; }
|
|
|
|
;
|
|
|
|
|
2010-01-03 12:17:52 +01:00
|
|
|
|
2018-06-26 14:29:03 +02:00
|
|
|
conf: mrtdump_base ;
|
2010-01-03 12:17:52 +01:00
|
|
|
|
|
|
|
mrtdump_base:
|
|
|
|
MRTDUMP PROTOCOLS mrtdump_mask ';' { new_config->proto_default_mrtdump = $3; }
|
2014-05-29 23:05:03 +02:00
|
|
|
| MRTDUMP text ';' {
|
2020-05-31 13:21:55 +02:00
|
|
|
if (!parse_and_exit)
|
|
|
|
{
|
2023-08-24 15:38:44 +02:00
|
|
|
struct rfile *f = rf_open(new_config->pool, $2, RF_APPEND, 0);
|
2020-05-31 13:21:55 +02:00
|
|
|
if (!f) cf_error("Unable to open MRTDump file '%s': %m", $2);
|
2023-08-21 18:44:10 +02:00
|
|
|
new_config->mrtdump_file = f;
|
2020-05-31 13:21:55 +02:00
|
|
|
}
|
2010-01-03 12:17:52 +01:00
|
|
|
}
|
|
|
|
;
|
|
|
|
|
2015-03-02 09:41:14 +01:00
|
|
|
|
2023-01-19 10:49:47 +01:00
|
|
|
conf: THREADS expr {
|
|
|
|
if ($2 < 1) cf_error("Number of threads must be at least one.");
|
2024-09-03 12:24:27 +02:00
|
|
|
new_config->threads.count = $2;
|
2023-01-19 10:49:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-06-26 14:29:03 +02:00
|
|
|
conf: debug_unix ;
|
2015-03-02 09:41:14 +01:00
|
|
|
|
|
|
|
debug_unix:
|
2024-08-27 17:50:30 +02:00
|
|
|
DEBUG LATENCY latency_debug_mask { new_config->runtime.latency_debug = $3; }
|
|
|
|
| DEBUG LATENCY LIMIT expr_us { new_config->runtime.latency_limit = $4; }
|
|
|
|
| WATCHDOG WARNING expr_us { new_config->runtime.watchdog_warning = $3; }
|
|
|
|
| WATCHDOG TIMEOUT expr_us { new_config->runtime.watchdog_timeout = ($3 + 999999) TO_S; }
|
2015-03-02 09:41:14 +01:00
|
|
|
;
|
|
|
|
|
2024-06-07 12:12:00 +02:00
|
|
|
latency_debug_mask:
|
|
|
|
ALL { $$ = ~0; }
|
|
|
|
| OFF { $$ = 0; }
|
|
|
|
| '{' latency_debug_list '}' { $$ = $2; }
|
|
|
|
;
|
|
|
|
|
|
|
|
latency_debug_list: latency_debug_flag | latency_debug_list ',' latency_debug_flag { $$ = $1 | $3; };
|
|
|
|
|
|
|
|
latency_debug_flag:
|
|
|
|
PING { $$ = DL_PING; }
|
|
|
|
| WAKEUP { $$ = DL_WAKEUP; }
|
|
|
|
| SOCKETS { $$ = DL_SOCKETS; }
|
|
|
|
| SCHEDULING { $$ = DL_SCHEDULING; }
|
2024-06-26 20:45:54 +02:00
|
|
|
| ALLOCATOR { $$ = DL_ALLOCATOR; }
|
2024-06-07 12:12:00 +02:00
|
|
|
| EVENTS { $$ = DL_EVENTS; }
|
|
|
|
| TIMERS { $$ = DL_TIMERS; }
|
|
|
|
;
|
|
|
|
|
2024-10-01 10:24:04 +02:00
|
|
|
conf: MEMORY '{' memory_items '}'
|
|
|
|
{
|
|
|
|
if (new_config->runtime.alloc.keep_mem_max_global <= new_config->runtime.alloc.keep_mem_max_local)
|
|
|
|
cf_error("Global (%u) hot memory limit must be higher than local (%u)",
|
|
|
|
new_config->runtime.alloc.keep_mem_max_global,
|
|
|
|
new_config->runtime.alloc.keep_mem_max_local);
|
|
|
|
|
|
|
|
if (new_config->runtime.alloc.keep_mem_max_local < new_config->runtime.alloc.at_once)
|
|
|
|
cf_error("Can't allocate more memory at once (%u) than local hot limit (%u)",
|
|
|
|
new_config->runtime.alloc.at_once,
|
|
|
|
new_config->runtime.alloc.keep_mem_max_local);
|
|
|
|
}
|
|
|
|
|
|
|
|
memory_items:
|
|
|
|
| memory_items GLOBAL KEEP HOT NUM ';' {
|
|
|
|
new_config->runtime.alloc.keep_mem_max_global = BIRD_ALIGN($5, page_size); }
|
|
|
|
| memory_items LOCAL KEEP HOT NUM ';' {
|
|
|
|
new_config->runtime.alloc.keep_mem_max_local = BIRD_ALIGN($5, page_size); }
|
|
|
|
| memory_items ALLOCATE BLOCK NUM ';' {
|
|
|
|
new_config->runtime.alloc.at_once = BIRD_ALIGN($4, page_size); }
|
|
|
|
;
|
|
|
|
|
2015-03-02 09:41:14 +01:00
|
|
|
|
2000-01-16 16:44:50 +00:00
|
|
|
/* Unix specific commands */
|
|
|
|
|
2012-12-26 12:40:48 +01:00
|
|
|
CF_CLI_HELP(CONFIGURE, ..., [[Reload configuration]])
|
2009-06-19 23:49:34 +02:00
|
|
|
|
2012-12-26 12:40:48 +01:00
|
|
|
CF_CLI(CONFIGURE, cfg_name cfg_timeout, [\"<file>\"] [timeout [<sec>]], [[Reload configuration]])
|
|
|
|
{ cmd_reconfig($2, RECONFIG_HARD, $3); } ;
|
2009-06-19 23:49:34 +02:00
|
|
|
|
2012-12-26 12:40:48 +01:00
|
|
|
CF_CLI(CONFIGURE SOFT, cfg_name cfg_timeout, [\"<file>\"] [timeout [<sec>]], [[Reload configuration and ignore changes in filters]])
|
|
|
|
{ cmd_reconfig($3, RECONFIG_SOFT, $4); } ;
|
|
|
|
|
|
|
|
/* Hack to get input completion for 'timeout' */
|
|
|
|
CF_CLI_CMD(CONFIGURE TIMEOUT, [<sec>], [[Reload configuration with undo timeout]])
|
|
|
|
CF_CLI_CMD(CONFIGURE SOFT TIMEOUT, [<sec>], [[Reload configuration with undo timeout]])
|
|
|
|
|
|
|
|
CF_CLI(CONFIGURE CONFIRM,,, [[Confirm last configuration change - deactivate undo timeout]])
|
|
|
|
{ cmd_reconfig_confirm(); } ;
|
|
|
|
|
|
|
|
CF_CLI(CONFIGURE UNDO,,, [[Undo last configuration change]])
|
|
|
|
{ cmd_reconfig_undo(); } ;
|
|
|
|
|
2019-06-12 16:13:21 +02:00
|
|
|
CF_CLI(CONFIGURE STATUS,,, [[Show configuration status]])
|
|
|
|
{ cmd_reconfig_status(); } ;
|
|
|
|
|
2012-12-26 12:40:48 +01:00
|
|
|
CF_CLI(CONFIGURE CHECK, cfg_name, [\"<file>\"], [[Parse configuration and check its validity]])
|
|
|
|
{ cmd_check_config($3); } ;
|
2000-01-16 16:44:50 +00:00
|
|
|
|
2000-03-07 20:09:35 +00:00
|
|
|
CF_CLI(DOWN,,, [[Shut the daemon down]])
|
2010-02-21 09:57:26 +01:00
|
|
|
{ cmd_shutdown(); } ;
|
2000-01-16 17:40:26 +00:00
|
|
|
|
2019-09-22 23:32:22 +02:00
|
|
|
CF_CLI_HELP(GRACEFUL, restart, [[Shut the daemon down for graceful restart]])
|
|
|
|
|
2019-07-31 19:45:29 +02:00
|
|
|
CF_CLI(GRACEFUL RESTART,,, [[Shut the daemon down for graceful restart]])
|
2019-06-18 16:27:21 +02:00
|
|
|
{ cmd_graceful_restart(); } ;
|
|
|
|
|
2023-01-19 10:49:47 +01:00
|
|
|
CF_CLI(SHOW THREADS,,, [[Write out thread information]])
|
|
|
|
{ cmd_show_threads(0); } ;
|
|
|
|
|
|
|
|
CF_CLI(SHOW THREADS ALL,,, [[Write out thread and IO loop information]])
|
|
|
|
{ cmd_show_threads(1); } ;
|
2019-06-18 16:27:21 +02:00
|
|
|
|
2000-01-16 16:44:50 +00:00
|
|
|
cfg_name:
|
|
|
|
/* empty */ { $$ = NULL; }
|
|
|
|
| TEXT
|
|
|
|
;
|
|
|
|
|
2012-12-26 12:40:48 +01:00
|
|
|
cfg_timeout:
|
|
|
|
/* empty */ { $$ = 0; }
|
|
|
|
| TIMEOUT { $$ = UNIX_DEFAULT_CONFIGURE_TIMEOUT; }
|
|
|
|
| TIMEOUT expr { $$ = $2; }
|
|
|
|
;
|
|
|
|
|
1999-12-06 13:45:56 +00:00
|
|
|
CF_CODE
|
|
|
|
|
|
|
|
CF_END
|