aboutsummaryrefslogtreecommitdiffstats
path: root/benchmarks
diff options
context:
space:
mode:
Diffstat (limited to 'benchmarks')
-rw-r--r--benchmarks/netio/Makefile19
-rw-r--r--benchmarks/netio/distinfo6
-rw-r--r--benchmarks/netio/files/patch-Makefile22
-rw-r--r--benchmarks/netio/files/patch-netio.c374
-rw-r--r--benchmarks/netio/pkg-descr3
5 files changed, 257 insertions, 167 deletions
diff --git a/benchmarks/netio/Makefile b/benchmarks/netio/Makefile
index 313c1e0a1699..bb4def0b95ad 100644
--- a/benchmarks/netio/Makefile
+++ b/benchmarks/netio/Makefile
@@ -5,11 +5,11 @@
# $FreeBSD$
PORTNAME= netio
-PORTVERSION= 1.14
-PORTREVISION= 1
+PORTVERSION= 1.26
CATEGORIES= benchmarks net ipv6
-MASTER_SITES= http://www.netfuse.de/techarea/netio/
-DISTNAME= netio114
+MASTER_SITES= ${MASTER_SITE_LOCAL}
+MASTER_SITE_SUBDIR= arved
+DISTNAME= netio126
MAINTAINER= arved@FreeBSD.org
COMMENT= Network benchmark
@@ -19,17 +19,18 @@ USE_ZIP= yes
USE_GMAKE= yes
PLIST_FILES= bin/netio
+CFLAGS+= -DUNIX ${PTHREAD_CFLAGS}
+MAKE_ENV+= OUT="-o" LIBS=${PTHREAD_LIBS}
.if defined(WITH_IPV6)
PLIST_FILES+= bin/netio6
.endif
-post-patch:
- ${REINPLACE_CMD} -e "s,-lsocket,," ${WRKSRC}/Makefile
-
do-build:
- cd ${WRKSRC} && ${GMAKE} unix
+ cd ${WRKSRC}; \
+ ${SETENV} ${MAKE_ENV} O=.o CFLAGS="${CFLAGS}" ${GMAKE} all
.if defined(WITH_IPV6)
- cd ${WRKSRC} && ${GMAKE} unix6
+ cd ${WRKSRC}; \
+ ${MAKE_ENV} O=.6o X=6 CFLAGS="${CFLAGS} -DUSE_IPV6" ${GMAKE} all
.endif
do-install:
diff --git a/benchmarks/netio/distinfo b/benchmarks/netio/distinfo
index 8d8a3d16e431..350cb76fd091 100644
--- a/benchmarks/netio/distinfo
+++ b/benchmarks/netio/distinfo
@@ -1,3 +1,3 @@
-MD5 (netio114.zip) = 7c41f385f1c216319bfaf93639cb4a20
-SHA256 (netio114.zip) = b7b140f5d8a8ff6e97a1f568b1580f851afb67c0b755da3ebd57b7eecc36081c
-SIZE (netio114.zip) = 210744
+MD5 (netio126.zip) = e54ac24ceac94c5ea6dd143abf9752e3
+SHA256 (netio126.zip) = 86c0bdee3224477b43c0cb6161ce1a20b2a2b6d59ef37f67864227096d9e8d5c
+SIZE (netio126.zip) = 140402
diff --git a/benchmarks/netio/files/patch-Makefile b/benchmarks/netio/files/patch-Makefile
index 0527087fff19..364e94f9146c 100644
--- a/benchmarks/netio/files/patch-Makefile
+++ b/benchmarks/netio/files/patch-Makefile
@@ -1,22 +1,6 @@
---- Makefile.orig Thu Apr 19 14:21:19 2001
-+++ Makefile Sat Dec 3 15:19:39 2005
-@@ -57,9 +57,15 @@
- unix:
- $(MAKE) all CC="gcc" O=.o X= \
- CFLAGS="-DUNIX -O" LFLAGS="-s" LIBS="-lsocket" OUT=-o
-+unix6:
-+ $(MAKE) all CC="gcc" O=.6o X=6 \
-+ CFLAGS="-DUNIX -O -DUSE_IPV6" LFLAGS="-lsocket" LIBS="" OUT=-o
- unix-debug:
- $(MAKE) all CC="gcc -g" O=.o X= \
- CFLAGS="-DUNIX" LFLAGS="" LIBS="-lsocket" OUT=-o
-+unix6-debug:
-+ $(MAKE) all CC="gcc -g" O=.6o X=6 \
-+ CFLAGS="-DUNIX -DUSE_IPV6" LFLAGS="-lsocket" LIBS="" OUT=-o
- watt32:
- $(MAKE) all CC="gcc -g -O2" O=.o X=.exe OUT=-o \
- CFLAGS="-DWATT32 -I../../inc" LIBS="../../lib/libwatt.a"
-@@ -73,7 +79,7 @@
+--- Makefile.orig Sat Sep 2 13:27:40 2006
++++ Makefile Sat Sep 2 13:29:30 2006
+@@ -96,7 +96,7 @@
.SUFFIXES: .c $O
.c$O:
diff --git a/benchmarks/netio/files/patch-netio.c b/benchmarks/netio/files/patch-netio.c
index 41cc0a95ec2f..121b1fedaa92 100644
--- a/benchmarks/netio/files/patch-netio.c
+++ b/benchmarks/netio/files/patch-netio.c
@@ -1,179 +1,281 @@
---- netio.c.orig Thu Apr 19 14:21:02 2001
-+++ netio.c Sat Dec 3 16:14:21 2005
-@@ -477,14 +477,22 @@
-
- /* TCP/IP code */
-
--int nPort = 0x494F; /* "IO" */
-+int nPort = 0x494F; /* "IO" */
-+#ifdef USE_IPV6
-+struct in6_addr addr_server;
+--- netio.c.orig Tue Aug 30 16:47:18 2005
++++ netio.c Sat Sep 2 13:46:50 2006
+@@ -782,8 +782,13 @@
+ const int sobufsize = 131072;
+ int nPort = DEFAULTPORT;
+ int nAuxPort = DEFAULTPORT + 1;
++#ifdef USE_IPV6
++struct in6_addr addr_server;
++struct in6_addr addr_local;
+#else
struct in_addr addr_server;
-+#endif
+ struct in_addr addr_local;
++#endif
- void TcpIpServer(void *arg)
- {
+ int udpsocket, udpd;
+ unsigned long nUDPCount;
+@@ -794,7 +799,11 @@
char *cBuffer;
-- int bQuit = 0;
-- struct sockaddr_in sa_server, sa_client;
-+ int bQuit = 0;
+ CONTROL ctl;
+ long long nData;
+#ifdef USE_IPV6
-+ struct sockaddr_in6 sa_server, sa_client;
-+#else
-+ struct sockaddr_in sa_server, sa_client;
++ struct sockaddr_in6 sa_server, sa_client;
++#else
+ struct sockaddr_in sa_server, sa_client;
+#endif
- int server, client, length;
+ int server, client;
+ size_t length;
struct timeval tv;
- fd_set fds;
-@@ -495,17 +503,27 @@
- perror("malloc()");
- return;
+@@ -808,7 +817,11 @@
+ return THREADRESULT;
}
--
-- if ((server = socket(PF_INET, SOCK_STREAM, 0)) < 0)
-+
+
+#ifdef USE_IPV6
-+ if ((server = socket(PF_INET6, SOCK_STREAM, 0)) < 0)
-+#else
-+ if ((server = socket(PF_INET, SOCK_STREAM, 0)) < 0)
++ if ((server = socket(PF_INET6, SOCK_STREAM, 0)) < 0)
++#else
+ if ((server = socket(PF_INET, SOCK_STREAM, 0)) < 0)
+#endif
{
psock_errno("socket()");
free(cBuffer);
+@@ -818,10 +831,15 @@
+ setsockopt(server, SOL_SOCKET, SO_RCVBUF, (char *) &sobufsize, sizeof(sobufsize));
+ setsockopt(server, SOL_SOCKET, SO_SNDBUF, (char *) &sobufsize, sizeof(sobufsize));
+
++#ifdef USE_IPV6
++ sa_server.sin6_family = AF_INET6;
++ sa_server.sin6_port = htons(nPort);
++ sa_server.sin6_addr = addr_local;
++#else
+ sa_server.sin_family = AF_INET;
+ sa_server.sin_port = htons(nPort);
+ sa_server.sin_addr = addr_local;
+-
++#endif
+ if (bind(server, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
+ {
+ psock_errno("bind()");
+@@ -958,7 +976,11 @@
+ long nTime, nResult;
+ long long nData;
+ int i;
++#ifdef USE_IPV6
++ struct sockaddr_in6 sa_server;
++#else
+ struct sockaddr_in sa_server;
++#endif
+ int server;
+ int rc;
+ int nByte;
+@@ -969,7 +991,11 @@
return;
}
--
-- sa_server.sin_family = AF_INET;
-+
+
++#ifdef USE_IPV6
++ if ((server = socket(PF_INET6, SOCK_STREAM, 0)) < 0)
++#else
+ if ((server = socket(PF_INET, SOCK_STREAM, 0)) < 0)
++#endif
+ {
+ psock_errno("socket()");
+ free(cBuffer);
+@@ -979,9 +1005,16 @@
+ setsockopt(server, SOL_SOCKET, SO_RCVBUF, (char *) &sobufsize, sizeof(sobufsize));
+ setsockopt(server, SOL_SOCKET, SO_SNDBUF, (char *) &sobufsize, sizeof(sobufsize));
+
+#ifdef USE_IPV6
-+ sa_server.sin6_family = AF_INET6;
++ sa_server.sin6_family = AF_INET6;
+ sa_server.sin6_port = htons(nPort);
-+ sa_server.sin6_addr = in6addr_any;
-+#else
-+ sa_server.sin_family = AF_INET;
++ sa_server.sin6_addr = addr_server;
++
++#else
+ sa_server.sin_family = AF_INET;
sa_server.sin_port = htons(nPort);
- sa_server.sin_addr.s_addr = INADDR_ANY;
+ sa_server.sin_addr = addr_server;
+#endif
- if (bind(server, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
+ if (connect(server, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
{
-@@ -524,8 +542,12 @@
+@@ -1121,7 +1154,11 @@
+ THREAD UDP_Receiver(void *arg)
+ {
+ char *cBuffer;
++#ifdef USE_IPV6
++ struct sockaddr_in6 sa_server, sa_client;
++#else
+ struct sockaddr_in sa_server, sa_client;
++#endif
+ int rc;
+ size_t nBytes;
+
+@@ -1131,7 +1168,11 @@
+ return THREADRESULT;
}
- for (;;)
-- {
-+ {
-+#ifdef USE_IPV6
-+ printf("TCP/IP server Listening (IPv6).\n");
-+#else
- printf("TCP/IP server Listening.\n");
-+#endif
-
- FD_ZERO(&fds);
- FD_SET(server, &fds);
-@@ -575,8 +597,12 @@
- TIMER nTimer;
- long nTime;
- long nData;
-- int i;
-- struct sockaddr_in sa_server;
-+#ifdef USE_IPV6
-+ struct sockaddr_in6 sa_client;
-+#else
-+ struct sockaddr_in sa_client;
-+#endif
-+ int i;
++#ifdef USE_IPV6
++ if ((udpsocket = socket(PF_INET6, SOCK_DGRAM, 0)) < 0)
++#else
+ if ((udpsocket = socket(PF_INET, SOCK_DGRAM, 0)) < 0)
++#endif
+ {
+ psock_errno("socket(DGRAM)");
+ free(cBuffer);
+@@ -1141,9 +1182,15 @@
+ setsockopt(udpsocket, SOL_SOCKET, SO_RCVBUF, (char *) &sobufsize, sizeof(sobufsize));
+ setsockopt(udpsocket, SOL_SOCKET, SO_SNDBUF, (char *) &sobufsize, sizeof(sobufsize));
+
++#ifdef USE_IPV6
++ sa_server.sin6_family = AF_INET6;
++ sa_server.sin6_port = htons(nAuxPort);
++ sa_server.sin6_addr = addr_local;
++#else
+ sa_server.sin_family = AF_INET;
+ sa_server.sin_port = htons(nAuxPort);
+ sa_server.sin_addr = addr_local;
++#endif
+
+ if (bind(udpsocket, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
+ {
+@@ -1181,7 +1228,11 @@
+ char *cBuffer;
+ CONTROL ctl;
+ long long nData;
++#ifdef USE_IPV6
++ struct sockaddr_in6 sa_server, sa_client;
++#else
+ struct sockaddr_in sa_server, sa_client;
++#endif
+ int server, client;
+ struct timeval tv;
+ fd_set fds;
+@@ -1194,7 +1245,11 @@
+ return THREADRESULT;
+ }
+
++#ifdef USE_IPV6
++ if ((server = socket(PF_INET6, SOCK_STREAM, 0)) < 0)
++#else
+ if ((server = socket(PF_INET, SOCK_STREAM, 0)) < 0)
++#endif
+ {
+ psock_errno("socket(STREAM)");
+ free(cBuffer);
+@@ -1204,9 +1259,15 @@
+ setsockopt(server, SOL_SOCKET, SO_RCVBUF, (char *) &sobufsize, sizeof(sobufsize));
+ setsockopt(server, SOL_SOCKET, SO_SNDBUF, (char *) &sobufsize, sizeof(sobufsize));
+
++#ifdef USE_IPV6
++ sa_server.sin6_family = AF_INET6;
++ sa_server.sin6_port = htons(nAuxPort);
++ sa_server.sin6_addr = addr_local;
++#else
+ sa_server.sin_family = AF_INET;
+ sa_server.sin_port = htons(nAuxPort);
+ sa_server.sin_addr = addr_local;
++#endif
+
+ if (bind(server, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
+ {
+@@ -1252,7 +1313,11 @@
+ printf("UDP connection established ... ");
+ fflush(stdout);
+
++#ifdef USE_IPV6
++ sa_client.sin6_port = htons(nAuxPort);
++#else
+ sa_client.sin_port = htons(nAuxPort);
++#endif
+
+ for (;;)
+ {
+@@ -1345,7 +1410,11 @@
+ long nTime, nResult, nCount;
+ long long nData;
+ int i;
++#ifdef USE_IPV6
++ struct sockaddr_in6 sa_server;
++#else
+ struct sockaddr_in sa_server;
++#endif
int server;
- int rc;
+ int rc, nByte;
-@@ -585,19 +611,28 @@
- perror("malloc()");
+@@ -1355,7 +1424,11 @@
return;
}
--
-- sa_server.sin_family = AF_INET;
-- sa_server.sin_port = htons(nPort);
-- sa_server.sin_addr = addr_server;
--
-+
-+#ifdef USE_IPV6
-+ sa_client.sin6_family = AF_INET6;
-+ sa_client.sin6_port = htons(nPort);
-+ sa_client.sin6_addr = addr_server;
-+#else
-+ sa_client.sin_family = AF_INET;
-+ sa_client.sin_port = htons(nPort);
-+ sa_client.sin_addr = addr_server;
-+#endif
-+
+
+#ifdef USE_IPV6
+ if ((server = socket(PF_INET6, SOCK_STREAM, 0)) < 0)
-+#else
++#else
if ((server = socket(PF_INET, SOCK_STREAM, 0)) < 0)
-+#endif
++#endif
{
psock_errno("socket()");
free(cBuffer);
- return;
-- }
--
-- if (connect(server, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
-+ }
-+ if (connect(server, (struct sockaddr *) &sa_client, sizeof(sa_client)) < 0)
+@@ -1365,9 +1438,15 @@
+ setsockopt(server, SOL_SOCKET, SO_RCVBUF, (char *) &sobufsize, sizeof(sobufsize));
+ setsockopt(server, SOL_SOCKET, SO_SNDBUF, (char *) &sobufsize, sizeof(sobufsize));
+
++#ifdef USE_IPV6
++ sa_server.sin6_family = AF_INET6;
++ sa_server.sin6_port = htons(nAuxPort);
++ sa_server.sin6_addr = addr_server;
++#else
+ sa_server.sin_family = AF_INET;
+ sa_server.sin_port = htons(nAuxPort);
+ sa_server.sin_addr = addr_server;
++#endif
+
+ if (connect(server, (struct sockaddr *) &sa_server, sizeof(sa_server)) < 0)
{
- psock_errno("connect()");
- soclose(server);
-@@ -664,13 +699,17 @@
- {
- printf(
- #ifndef USE_NETBIOS
-+#ifdef USE_IPV6
-+ "\nUsage: netio6 [-s] [-p <port>] [<server>]\n"
-+#else
- "\nUsage: netio [-s] [-p <port>] [<server>]\n"
-+#endif
- "\n\t-s\t\trun server side of benchmark (otherwise run client)"
- "\n\t-p <port>\tuse this port instead of the default (%d)"
- "\n\t<server>\tif the client side of the benchmark is running,"
- "\n\t\t\ta server host name is required\n"
--#else
-- "\nUsage: netio [-s] [-t | -n] [-p <port>] [-a <adapter>] [<server>]\n"
-+#else
-+ "\nUsage: netio [-s] [-t | -n] [-p <port>] [-a <adapter>] [<server>]\n"
- "\n\t-s\trun server side of benchmark (otherwise run client)"
- "\n\t-t\tuse TCP/IP protocol for benchmark"
- "\n\t-p <port>\tuse this port for TCP/IP (default is %d)"
-@@ -766,14 +805,28 @@
- if (optind == argc)
- usage();
+@@ -1669,17 +1748,29 @@
+ return psock_errno("sock_init()"), 1;
-- if (isdigit(*argv[optind]))
-- addr_server.s_addr = inet_addr(argv[optind]);
-+ if (isdigit(*argv[optind])
-+#ifdef USE_IPV6
-+ || *argv[optind] == ':')
-+ inet_pton(AF_INET6, argv[optind], &addr_server);
-+#else
-+ )
-+ addr_server.s_addr = inet_addr(argv[optind]);
-+#endif
+ if (szLocal == 0)
++#ifdef USE_IPV6
++ addr_local = in6addr_any;
++#else
+ addr_local.s_addr = INADDR_ANY;
++#endif
+ else
+ {
+ if (isdigit(*szLocal))
++#ifdef USE_IPV6
++ inet_pton(AF_INET6, szLocal, &addr_local);
++#else
+ addr_local.s_addr = inet_addr(szLocal);
++#endif
else
-- {
-- if ((host = gethostbyname(argv[optind])) == NULL)
-+ {
-+#ifdef USE_IPV6
-+ if ((host = gethostbyname2(argv[optind], AF_INET6)) == NULL)
-+#else
-+ if ((host = gethostbyname(argv[optind])) == NULL)
+ {
+ if ((host = gethostbyname(szLocal)) == NULL)
+ return psock_errno("gethostbyname()"), 1;
+
++#ifdef USE_IPV6
++ addr_local = * (struct in6_addr *) (host->h_addr);
++#else
+ addr_local = * (struct in_addr *) (host->h_addr);
+#endif
+ }
+ }
+
+@@ -1689,13 +1780,21 @@
+ usage();
+
+ if (isdigit(*argv[optind]))
++#ifdef USE_IPV6
++ inet_pton(AF_INET6, argv[optind], &addr_server);
++#else
+ addr_server.s_addr = inet_addr(argv[optind]);
++#endif
+ else
+ {
+ if ((host = gethostbyname(argv[optind])) == NULL)
return psock_errno("gethostbyname()"), 1;
-- addr_server = * (struct in_addr *) (host->h_addr);
+#ifdef USE_IPV6
-+ addr_server = * (struct in6_addr *) (host->h_addr);
-+#else
-+ addr_server = * (struct in_addr *) (host->h_addr);
++ addr_server = * (struct in6_addr *) (host->h_addr);
++#else
+ addr_server = * (struct in_addr *) (host->h_addr);
+#endif
}
}
diff --git a/benchmarks/netio/pkg-descr b/benchmarks/netio/pkg-descr
index 6b3e35172504..298285deaac4 100644
--- a/benchmarks/netio/pkg-descr
+++ b/benchmarks/netio/pkg-descr
@@ -6,3 +6,6 @@ packet sizes.
One instance has to run on one machine as a server process, another
instance is used on another machine to perform the benchmark. When
executed without arguments, the program will explain its usage.
+
+Author: Kai Uwe Rommel
+WWW: http://www.ars.de/ars/ars.nsf/docs/netio/