diff options
| author | Daniel Stenberg <daniel@haxx.se> | 2019-08-07 12:49:27 +0200 | 
|---|---|---|
| committer | Daniel Stenberg <daniel@haxx.se> | 2019-08-07 12:51:52 +0200 | 
| commit | 1f145b02d95f42ffba23fa6ea6a867aeba3cbdc1 (patch) | |
| tree | b05d443a2c9bb1f193a4c3e51928025b9e08d3a8 /lib | |
| parent | 7a83e1d1d43740d979a2db78a7e944f09fe9b73a (diff) | |
quiche: make use of the connection timeout API properly
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/urldata.h | 1 | ||||
| -rw-r--r-- | lib/vquic/quiche.c | 10 | 
2 files changed, 11 insertions, 0 deletions
diff --git a/lib/urldata.h b/lib/urldata.h index b3b1263c6..eabb1b5c7 100644 --- a/lib/urldata.h +++ b/lib/urldata.h @@ -1227,6 +1227,7 @@ typedef enum {    EXPIRE_SPEEDCHECK,    EXPIRE_TIMEOUT,    EXPIRE_TOOFAST, +  EXPIRE_QUIC,    EXPIRE_LAST /* not an actual timer, used as a marker only */  } expire_id; diff --git a/lib/vquic/quiche.c b/lib/vquic/quiche.c index 67c2b1b42..c4e7b03fe 100644 --- a/lib/vquic/quiche.c +++ b/lib/vquic/quiche.c @@ -209,6 +209,9 @@ static CURLcode process_ingress(struct connectdata *conn, int sockfd)    uint8_t *buf = (uint8_t *)data->state.buffer;    size_t bufsize = data->set.buffer_size; +  /* in case the timeout expired */ +  quiche_conn_on_timeout(qs->conn); +    do {      recvd = recv(sockfd, buf, bufsize, 0);      if((recvd < 0) && ((errno == EAGAIN) || (errno == EWOULDBLOCK))) @@ -241,6 +244,7 @@ static CURLcode flush_egress(struct connectdata *conn, int sockfd)    ssize_t sent;    struct quicsocket *qs = &conn->quic;    static uint8_t out[1200]; +  int64_t timeout_ns;    do {      sent = quiche_conn_send(qs->conn, out, sizeof(out)); @@ -260,6 +264,12 @@ static CURLcode flush_egress(struct connectdata *conn, int sockfd)      }    } while(1); +  /* time until the next timeout event, as nanoseconds. */ +  timeout_ns = quiche_conn_timeout_as_nanos(qs->conn); +  if(timeout_ns) +    /* expire uses milliseconds */ +    Curl_expire(conn->data, (timeout_ns + 999999) / 1000000, EXPIRE_QUIC); +    return CURLE_OK;  }  | 
