summaryrefslogtreecommitdiff
path: root/benchmarks/kttcp/files
diff options
context:
space:
mode:
authorthorpej <thorpej>2002-06-30 21:45:06 +0000
committerthorpej <thorpej>2002-06-30 21:45:06 +0000
commitf260a56f17e7310892d2cb6f0024b09d3c6d43f7 (patch)
tree41648eb0c74e91702aef4185aa08bbc8cd640c69 /benchmarks/kttcp/files
parent4171b24025d0ed563a0a3f577b32449a1cb491e6 (diff)
downloadpkgsrc-f260a56f17e7310892d2cb6f0024b09d3c6d43f7.tar.gz
Allow a "k", "m", or "g" suffix to be added to a byte count to
multiply it by 1024, 1024 * 1024, or 1024 * 1024 * 1024, respectively.
Diffstat (limited to 'benchmarks/kttcp/files')
-rw-r--r--benchmarks/kttcp/files/kttcp.c41
1 files changed, 37 insertions, 4 deletions
diff --git a/benchmarks/kttcp/files/kttcp.c b/benchmarks/kttcp/files/kttcp.c
index 89e69794499..1a9fb3357c5 100644
--- a/benchmarks/kttcp/files/kttcp.c
+++ b/benchmarks/kttcp/files/kttcp.c
@@ -1,4 +1,4 @@
-/* $NetBSD: kttcp.c,v 1.3 2002/06/30 19:25:47 thorpej Exp $ */
+/* $NetBSD: kttcp.c,v 1.4 2002/06/30 21:45:06 thorpej Exp $ */
/*
* Copyright (c) 2002 Wasabi Systems, Inc.
@@ -40,6 +40,7 @@
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <sys/time.h>
+#include <errno.h>
#include <netdb.h>
#include <unistd.h>
#include <stdio.h>
@@ -69,6 +70,32 @@ usage(void)
exit(1);
}
+static unsigned long long
+get_bytes(const char *str)
+{
+ unsigned long long bytes;
+ char *cp;
+
+ bytes = strtoull(str, &cp, 10);
+ if (bytes == ULLONG_MAX && errno == ERANGE)
+ err(1, "%s", str);
+
+ if (cp[0] != '\0') {
+ if (cp[1] != '\0')
+ errx(1, "invalid byte count: %s", str);
+ if (cp[0] == 'k' || cp[0] == 'K')
+ bytes *= 1024;
+ else if (cp[0] == 'm' || cp[0] == 'M')
+ bytes *= 1024 * 1024;
+ else if (cp[0] == 'g' || cp[0] == 'G')
+ bytes *= 1024 * 1024 * 1024;
+ else
+ errx(1, "invalid byte count modifier: %s", str);
+ }
+
+ return (bytes);
+}
+
int
main(int argc, char *argv[])
{
@@ -81,7 +108,7 @@ main(int argc, char *argv[])
struct kttcp_io_args kio;
struct addrinfo hints, *addr, *res;
struct sockaddr_storage ss;
- unsigned long long usecs, bytespersec, bitspersec, xmitsize;
+ unsigned long long ull, usecs, bytespersec, bitspersec, xmitsize;
char connecthost[NI_MAXHOST];
socklen_t slen;
const int one = 1;
@@ -106,10 +133,14 @@ main(int argc, char *argv[])
family = PF_INET6;
break;
case 'b':
- bufsize = atoi(optarg);
+ ull = get_bytes(optarg);
+ if (ull > INT_MAX)
+ errx(1,
+ "invalid socket buffer size: %s\n", optarg);
+ bufsize = ull;
break;
case 'n':
- xmitsize = strtoll(optarg, NULL, 10);
+ xmitsize = get_bytes(optarg);
if (xmitsize > KTTCP_MAX_XMIT)
xmitsize = KTTCP_MAX_XMIT;
xmitset = 1;
@@ -174,6 +205,8 @@ main(int argc, char *argv[])
if (res == NULL)
err(2, "can't create socket");
+ printf("kttcp: socket buffer size: %d\n", bufsize);
+
if (cmd == KTTCP_IO_SEND) {
if (connect(s, res->ai_addr, res->ai_addrlen) < 0)
err(2, "connect");