diff options
author | Reyk Floeter <reyk@cvs.openbsd.org> | 2006-12-25 19:05:42 +0000 |
---|---|---|
committer | Reyk Floeter <reyk@cvs.openbsd.org> | 2006-12-25 19:05:42 +0000 |
commit | cf7f2baa5c93cc79c46ffc583e6d4aff6ab97c60 (patch) | |
tree | 47537f17cc61d69a418755cbac5f22008ac0adeb /usr.sbin/relayd | |
parent | 2e002eb51e98ddcd00053415bdcefc85983560b6 (diff) |
fix the conversion from milliseconds to struct timeval, which uses
seconds (tv_sec) and microseconds (tv_usec), but the code assumed
seconds and milliseconds...
Diffstat (limited to 'usr.sbin/relayd')
-rw-r--r-- | usr.sbin/relayd/check_icmp.c | 20 | ||||
-rw-r--r-- | usr.sbin/relayd/check_tcp.c | 5 | ||||
-rw-r--r-- | usr.sbin/relayd/parse.y | 24 | ||||
-rw-r--r-- | usr.sbin/relayd/relayd.h | 4 |
4 files changed, 29 insertions, 24 deletions
diff --git a/usr.sbin/relayd/check_icmp.c b/usr.sbin/relayd/check_icmp.c index ad562e771c4..3cf5360e01f 100644 --- a/usr.sbin/relayd/check_icmp.c +++ b/usr.sbin/relayd/check_icmp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: check_icmp.c,v 1.3 2006/12/25 18:12:14 reyk Exp $ */ +/* $OpenBSD: check_icmp.c,v 1.4 2006/12/25 19:05:41 reyk Exp $ */ /* * Copyright (c) 2006 Pierre-Yves Ritschard <pyr@spootnik.org> @@ -69,18 +69,13 @@ check_icmp(struct ctl_icmp_event *cie) if (gettimeofday(&cie->tv_start, NULL)) fatal("check_icmp: gettimeofday"); - if (cie->has_icmp4) { - tv.tv_sec = cie->env->timeout / 1000; - tv.tv_usec = cie->env->timeout % 1000; + bcopy(&cie->env->timeout, &tv, sizeof(tv)); + if (cie->has_icmp4) event_once(cie->icmp_sock, EV_READ|EV_TIMEOUT, recv_icmp4, cie, &tv); - } - if (cie->has_icmp6) { - tv.tv_sec = cie->env->timeout / 1000; - tv.tv_usec = cie->env->timeout % 1000; + if (cie->has_icmp6) event_once(cie->icmp6_sock, EV_READ|EV_TIMEOUT, recv_icmp6, cie, &tv); - } } int @@ -247,8 +242,7 @@ recv_icmp6(int s, short event, void *arg) return; if (gettimeofday(&tv_now, NULL)) fatal("recv_icmp6: gettimeofday"); - tv.tv_sec = cie->env->timeout / 1000; - tv.tv_usec = cie->env->timeout % 1000; + bcopy(&cie->env->timeout, &tv, sizeof(tv)); timersub(&tv_now, &cie->tv_start, &tv_now); timersub(&tv, &tv_now, &tv); event_once(cie->icmp6_sock, EV_READ|EV_TIMEOUT, recv_icmp6, cie, &tv); @@ -327,8 +321,8 @@ recv_icmp4(int s, short event, void *arg) if (gettimeofday(&tv_now, NULL)) fatal("recv_icmp4: gettimeofday"); - tv.tv_sec = cie->env->timeout / 1000; - tv.tv_usec = cie->env->timeout % 1000; + + bcopy(&cie->env->timeout, &tv, sizeof(tv)); timersub(&tv_now, &cie->tv_start, &tv_now); timersub(&tv, &tv_now, &tv); event_once(cie->icmp_sock, EV_READ|EV_TIMEOUT, recv_icmp4, cie, &tv); diff --git a/usr.sbin/relayd/check_tcp.c b/usr.sbin/relayd/check_tcp.c index 2a65abc4307..93cf8dd7041 100644 --- a/usr.sbin/relayd/check_tcp.c +++ b/usr.sbin/relayd/check_tcp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: check_tcp.c,v 1.3 2006/12/25 18:12:14 reyk Exp $ */ +/* $OpenBSD: check_tcp.c,v 1.4 2006/12/25 19:05:41 reyk Exp $ */ /* * Copyright (c) 2006 Pierre-Yves Ritschard <pyr@spootnik.org> @@ -79,8 +79,7 @@ check_tcp(struct ctl_tcp_event *cte) tcp_host_up(s, cte); return; } - tv.tv_sec = cte->table->timeout / 1000; - tv.tv_usec = cte->table->timeout % 1000; + bcopy(&cte->table->timeout, &tv, sizeof(tv)); event_once(s, EV_TIMEOUT|EV_WRITE, tcp_write, cte, &tv); return; bad: 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 <pyr@spootnik.org> @@ -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 <v.string> interface %type <v.number> number %type <v.host> host +%type <v.tv> 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; diff --git a/usr.sbin/relayd/relayd.h b/usr.sbin/relayd/relayd.h index 4ca1519bae2..89532b6baf6 100644 --- a/usr.sbin/relayd/relayd.h +++ b/usr.sbin/relayd/relayd.h @@ -184,7 +184,7 @@ struct table { int up; in_port_t port; int retcode; - int timeout; + struct timeval timeout; char name[TABLE_NAME_SIZE]; char path[MAXPATHLEN]; char digest[41]; /* length of sha1 digest * 2 */ @@ -226,7 +226,7 @@ struct hostated { int icmp6_sock; int tablecount; int servicecount; - int timeout; + struct timeval timeout; struct table empty_table; struct event ev; struct tablelist tables; |