diff options
author | Pierre-Yves Ritschard <pyr@cvs.openbsd.org> | 2007-01-20 16:32:11 +0000 |
---|---|---|
committer | Pierre-Yves Ritschard <pyr@cvs.openbsd.org> | 2007-01-20 16:32:11 +0000 |
commit | 77528926018f660467f175dc5b7b4d1a72be8c83 (patch) | |
tree | 38776751886270ec235780ebaca790edd07882d3 /usr.sbin/relayd | |
parent | b66f071513c2b2fdec943187190a5d73d8576f55 (diff) |
when retrying a write, the position was previously not updated.
ok reyk@
Diffstat (limited to 'usr.sbin/relayd')
-rw-r--r-- | usr.sbin/relayd/check_tcp.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/usr.sbin/relayd/check_tcp.c b/usr.sbin/relayd/check_tcp.c index f5142118c8e..7195a216710 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.10 2007/01/12 16:43:01 pyr Exp $ */ +/* $OpenBSD: check_tcp.c,v 1.11 2007/01/20 16:32:10 pyr Exp $ */ /* * Copyright (c) 2006 Pierre-Yves Ritschard <pyr@spootnik.org> @@ -139,9 +139,9 @@ tcp_host_up(int s, struct ctl_tcp_event *cte) cte->validate_close = check_send_expect; break; } - cte->req = cte->table->sendbuf; if (cte->table->sendbuf != NULL) { + cte->req = cte->table->sendbuf; event_again(&cte->ev, s, EV_TIMEOUT|EV_WRITE, tcp_send_req, &cte->tv_start, &cte->table->timeout, cte); return; @@ -159,7 +159,6 @@ tcp_send_req(int s, short event, void *arg) { struct ctl_tcp_event *cte = arg; int bs; - int pos; int len; if (event == EV_TIMEOUT) { @@ -167,10 +166,9 @@ tcp_send_req(int s, short event, void *arg) hce_notify_done(cte->host, "tcp_send_req: timeout"); return; } - pos = 0; len = strlen(cte->req); do { - bs = write(s, cte->req + pos, len); + bs = write(s, cte->req, len); if (bs == -1) { if (errno == EAGAIN || errno == EINTR) goto retry; @@ -179,7 +177,7 @@ tcp_send_req(int s, short event, void *arg) hce_notify_done(cte->host, "tcp_send_req: write"); return; } - pos += bs; + cte->req += bs; len -= bs; } while (len > 0); |