diff options
Diffstat (limited to 'examples/client.c')
-rw-r--r-- | examples/client.c | 31 |
1 files changed, 25 insertions, 6 deletions
diff --git a/examples/client.c b/examples/client.c index cef13670..714e8d42 100644 --- a/examples/client.c +++ b/examples/client.c @@ -61,8 +61,11 @@ static void debug_log(const char *line, void *argp) { static void flush_egress(struct ev_loop *loop, struct conn_io *conn_io) { static uint8_t out[MAX_DATAGRAM_SIZE]; + quiche_send_info send_info; + while (1) { - ssize_t written = quiche_conn_send(conn_io->conn, out, sizeof(out)); + ssize_t written = quiche_conn_send(conn_io->conn, out, sizeof(out), + &send_info); if (written == QUICHE_ERR_DONE) { fprintf(stderr, "done writing\n"); @@ -74,7 +77,10 @@ static void flush_egress(struct ev_loop *loop, struct conn_io *conn_io) { return; } - ssize_t sent = send(conn_io->sock, out, written, 0); + ssize_t sent = sendto(conn_io->sock, out, written, 0, + (struct sockaddr *) &send_info.to, + send_info.to_len); + if (sent != written) { perror("failed to send"); return; @@ -96,7 +102,13 @@ static void recv_cb(EV_P_ ev_io *w, int revents) { static uint8_t buf[65535]; while (1) { - ssize_t read = recv(conn_io->sock, buf, sizeof(buf), 0); + struct sockaddr_storage peer_addr; + socklen_t peer_addr_len = sizeof(peer_addr); + memset(&peer_addr, 0, peer_addr_len); + + ssize_t read = recvfrom(conn_io->sock, buf, sizeof(buf), 0, + (struct sockaddr *) &peer_addr, + &peer_addr_len); if (read < 0) { if ((errno == EWOULDBLOCK) || (errno == EAGAIN)) { @@ -108,7 +120,13 @@ static void recv_cb(EV_P_ ev_io *w, int revents) { return; } - ssize_t done = quiche_conn_recv(conn_io->conn, buf, read); + quiche_recv_info recv_info = { + (struct sockaddr *) &peer_addr, + + peer_addr_len, + }; + + ssize_t done = quiche_conn_recv(conn_io->conn, buf, read, &recv_info); if (done < 0) { fprintf(stderr, "failed to process packet\n"); @@ -269,8 +287,9 @@ int main(int argc, char *argv[]) { return -1; } - quiche_conn *conn = quiche_connect(host, (const uint8_t *) scid, - sizeof(scid), config); + quiche_conn *conn = quiche_connect(host, (const uint8_t*) scid, sizeof(scid), + peer->ai_addr, peer->ai_addrlen, config); + if (conn == NULL) { fprintf(stderr, "failed to create connection\n"); return -1; |