From cf7f2baa5c93cc79c46ffc583e6d4aff6ab97c60 Mon Sep 17 00:00:00 2001 From: Reyk Floeter Date: Mon, 25 Dec 2006 19:05:42 +0000 Subject: fix the conversion from milliseconds to struct timeval, which uses seconds (tv_sec) and microseconds (tv_usec), but the code assumed seconds and milliseconds... --- usr.sbin/relayd/parse.y | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) (limited to 'usr.sbin/relayd/parse.y') diff --git a/usr.sbin/relayd/parse.y b/usr.sbin/relayd/parse.y index 0c6008365b8..33a7ed336ed 100644 --- a/usr.sbin/relayd/parse.y +++ b/usr.sbin/relayd/parse.y @@ -1,4 +1,4 @@ -/* $OpenBSD: parse.y,v 1.5 2006/12/25 18:12:14 reyk Exp $ */ +/* $OpenBSD: parse.y,v 1.6 2006/12/25 19:05:41 reyk Exp $ */ /* * Copyright (c) 2006 Pierre-Yves Ritschard @@ -90,6 +90,7 @@ typedef struct { u_int32_t number; char *string; struct host *host; + struct timeval tv; } v; int lineno; } YYSTYPE; @@ -105,6 +106,7 @@ typedef struct { %type interface %type number %type host +%type timeout %% @@ -140,7 +142,9 @@ varset : STRING '=' STRING { ; main : INTERVAL number { conf->interval = $2; } - | TIMEOUT number { conf->timeout = $2; } + | TIMEOUT timeout { + bcopy(&$2, &conf->timeout, sizeof(struct timeval)); + } ; service : SERVICE STRING { @@ -292,7 +296,7 @@ table : TABLE STRING { YYERROR; } tb->id = last_table_id++; - tb->timeout = conf->timeout; + bcopy(&conf->timeout, &tb->timeout, sizeof(struct timeval)); if (last_table_id == UINT_MAX) { yyerror("too many tables defined"); YYERROR; @@ -326,8 +330,8 @@ tableoptsl : host { $1->tablename = table->name; TAILQ_INSERT_HEAD(&table->hosts, $1, entry); } - | TIMEOUT number { - table->timeout = $2; + | TIMEOUT timeout { + bcopy(&$2, &table->timeout, sizeof(struct timeval)); } | CHECK ICMP { table->check = CHECK_ICMP; @@ -413,6 +417,13 @@ host : HOST STRING { } ; +timeout : number + { + $$.tv_sec = $1 / 1000; + $$.tv_usec = ($1 % 1000) * 1000; + } + ; + optnl : '\n' optnl | ; @@ -686,7 +697,8 @@ parse_config(struct hostated *x_conf, const char *filename, int opts) (void)strlcpy(conf->empty_table.name, "empty", sizeof(conf->empty_table.name)); - conf->timeout = CHECK_TIMEOUT; + conf->timeout.tv_sec = CHECK_TIMEOUT / 1000; + conf->timeout.tv_usec = (CHECK_TIMEOUT % 1000) * 1000; conf->interval = CHECK_INTERVAL; conf->opts = opts; -- cgit v1.2.3