diff options
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/tcpbench/tcpbench.c | 54 |
1 files changed, 32 insertions, 22 deletions
diff --git a/usr.bin/tcpbench/tcpbench.c b/usr.bin/tcpbench/tcpbench.c index 648eeccfde1..5fbcf7dfbb2 100644 --- a/usr.bin/tcpbench/tcpbench.c +++ b/usr.bin/tcpbench/tcpbench.c @@ -737,30 +737,18 @@ serverloop(kvm_t *kvmh, u_long ktcbtab, struct addrinfo *aitop) exit(1); } -static void __dead -clientloop(kvm_t *kvmh, u_long ktcbtab, struct addrinfo *aitop, int nconn) +void +clientconnect(struct addrinfo *aitop, struct pollfd *pfd, int nconn) { + char tmp[128]; struct addrinfo *ai; - struct statctx *psc; - struct pollfd *pfd; - char tmp[128], *buf; - int i, r, herr, sock = -1; - u_int scnt = 0; - ssize_t n; - - if ((buf = malloc(Bflag)) == NULL) - err(1, "malloc"); + int i, r, sock; - if ((pfd = calloc(nconn, sizeof(*pfd))) == NULL) - err(1, "clientloop pfd calloc"); - if ((psc = calloc(nconn, sizeof(*psc))) == NULL) - err(1, "clientloop psc calloc"); - for (i = 0; i < nconn; i++) { for (sock = -1, ai = aitop; ai != NULL; ai = ai->ai_next) { saddr_ntop(ai->ai_addr, ai->ai_addrlen, tmp, sizeof(tmp)); - if (vflag && scnt == 0) + if (vflag && i == 0) fprintf(stderr, "Trying %s\n", tmp); if ((sock = socket(ai->ai_family, ai->ai_socktype, ai->ai_protocol)) == -1) { @@ -803,14 +791,36 @@ clientloop(kvm_t *kvmh, u_long ktcbtab, struct addrinfo *aitop, int nconn) pfd[i].fd = sock; pfd[i].events = POLLOUT; + } + freeaddrinfo(aitop); + + if (vflag && nconn > 1) + fprintf(stderr, "%u connections established\n", nconn); +} + +static void __dead +clientloop(kvm_t *kvmh, u_long ktcbtab, struct addrinfo *aitop, int nconn) +{ + struct statctx *psc; + struct pollfd *pfd; + char *buf; + int i, sock = -1; + ssize_t n; + + if ((pfd = calloc(nconn, sizeof(*pfd))) == NULL) + err(1, "clientloop pfd calloc"); + if ((psc = calloc(nconn, sizeof(*psc))) == NULL) + err(1, "clientloop psc calloc"); + + clientconnect(aitop, pfd, nconn); + + for (i = 0; i < nconn; i++) { stats_prepare(psc + i, sock, kvmh, ktcbtab); mainstats.nconns++; - scnt++; } - freeaddrinfo(aitop); - if (vflag && scnt > 1) - fprintf(stderr, "%u connections established\n", scnt); + if ((buf = malloc(Bflag)) == NULL) + err(1, "malloc"); arc4random_buf(buf, Bflag); print_header(); @@ -818,7 +828,7 @@ clientloop(kvm_t *kvmh, u_long ktcbtab, struct addrinfo *aitop, int nconn) while (!done) { if (proc_slice) { - process_slice(psc, scnt); + process_slice(psc, nconn); stats_cleanslice(); proc_slice = 0; } |