Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/rump/rumpkern Execute a variety of syscalls in the str...
details: https://anonhg.NetBSD.org/src/rev/7742a0e9f1a5
branches: trunk
changeset: 760733:7742a0e9f1a5
user: pooka <pooka%NetBSD.org@localhost>
date: Wed Jan 12 12:32:53 2011 +0000
description:
Execute a variety of syscalls in the stress test, including opening
files and sockets.
diffstat:
tests/rump/rumpkern/h_client/h_stresscli.c | 79 +++++++++++++++++++++++++++--
tests/rump/rumpkern/t_sp.sh | 7 +-
2 files changed, 77 insertions(+), 9 deletions(-)
diffs (180 lines):
diff -r 7672356d51e8 -r 7742a0e9f1a5 tests/rump/rumpkern/h_client/h_stresscli.c
--- a/tests/rump/rumpkern/h_client/h_stresscli.c Wed Jan 12 11:39:20 2011 +0000
+++ b/tests/rump/rumpkern/h_client/h_stresscli.c Wed Jan 12 12:32:53 2011 +0000
@@ -1,11 +1,15 @@
-/* $NetBSD: h_stresscli.c,v 1.7 2011/01/12 11:37:45 pooka Exp $ */
+/* $NetBSD: h_stresscli.c,v 1.8 2011/01/12 12:32:53 pooka Exp $ */
#include <sys/types.h>
#include <sys/atomic.h>
#include <sys/sysctl.h>
#include <sys/wait.h>
+#include <sys/socket.h>
+
+#include <netinet/in.h>
#include <err.h>
+#include <fcntl.h>
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
@@ -15,7 +19,7 @@
#include <rump/rump_syscalls.h>
#include <rump/rumpclient.h>
-static unsigned int syscalls;
+static unsigned int syscalls, bindcalls;
static pid_t mypid;
static volatile sig_atomic_t doquit;
@@ -30,15 +34,57 @@
static char hostnamebuf[128];
#define HOSTNAMEBASE "rumpclient"
+static int iskiller;
+
static void *
client(void *arg)
{
char buf[256];
+ struct sockaddr_in sin;
size_t blen;
+ int port = (int)(uintptr_t)arg;
+ int s, fd, x;
+
+ memset(&sin, 0, sizeof(sin));
+ sin.sin_family = AF_INET;
+ sin.sin_len = sizeof(sin);
+ sin.sin_port = htons(port);
while (!doquit) {
pid_t pidi;
blen = sizeof(buf);
+ s = rump_sys_socket(PF_INET, SOCK_STREAM, 0);
+ if (s == -1)
+ err(1, "socket");
+ atomic_inc_uint(&syscalls);
+
+ fd = rump_sys_open("/dev/null", O_RDWR);
+ atomic_inc_uint(&syscalls);
+
+ if (doquit)
+ goto out;
+
+ x = 1;
+ if (rump_sys_setsockopt(s, SOL_SOCKET, SO_REUSEADDR,
+ &x, sizeof(x)) == -1)
+ err(1, "reuseaddr");
+
+ /*
+ * we don't really know when the kernel handles our disconnect,
+ * so be soft about about the failure in case of a killer client
+ */
+ if (rump_sys_bind(s, (struct sockaddr*)&sin, sizeof(sin))==-1) {
+ if (!iskiller)
+ err(1, "bind to port %d failed",
+ ntohs(sin.sin_port));
+ } else {
+ atomic_inc_uint(&bindcalls);
+ }
+ atomic_inc_uint(&syscalls);
+
+ if (doquit)
+ goto out;
+
if (rump_sys___sysctl(hostnamemib, __arraycount(hostnamemib),
buf, &blen, NULL, 0) == -1)
err(1, "sysctl");
@@ -46,12 +92,28 @@
errx(1, "hostname (%s/%s) mismatch", buf, hostnamebuf);
atomic_inc_uint(&syscalls);
+ if (doquit)
+ goto out;
+
pidi = rump_sys_getpid();
if (pidi == -1)
err(1, "getpid");
if (pidi != mypid)
errx(1, "mypid mismatch");
atomic_inc_uint(&syscalls);
+
+ if (doquit)
+ goto out;
+
+ if (rump_sys_write(fd, buf, 16) != 16)
+ err(1, "write /dev/null");
+ atomic_inc_uint(&syscalls);
+
+ out:
+ rump_sys_close(fd);
+ atomic_inc_uint(&syscalls);
+ rump_sys_close(s);
+ atomic_inc_uint(&syscalls);
}
return NULL;
@@ -70,7 +132,7 @@
int ncli = 0;
int i = 0, j;
int status, thesig;
- int rounds;
+ int rounds, myport;
if (argc != 2 && argc != 3)
errx(1, "need roundcount");
@@ -79,6 +141,7 @@
if (strcmp(argv[2], "kill") != 0)
errx(1, "optional 3rd param must be kill");
thesig = SIGKILL;
+ iskiller = 1;
} else {
thesig = SIGUSR1;
}
@@ -102,11 +165,15 @@
hostnamebuf, strlen(hostnamebuf)+1) == -1)
err(1, "sethostname");
- for (j = 0; j < NTHR-1; j++)
+ for (j = 0; j < NTHR-1; j++) {
+ myport = i*NCLI + j+2;
if (pthread_create(&pt[j], NULL,
- client, NULL) != 0)
+ client,
+ (void*)(uintptr_t)myport) !=0 )
err(1, "pthread create");
- client(NULL);
+ }
+ myport = i*NCLI+1;
+ client((void *)(uintptr_t)myport);
for (j = 0; j < NTHR-1; j++)
pthread_join(pt[j], NULL);
membar_consumer();
diff -r 7672356d51e8 -r 7742a0e9f1a5 tests/rump/rumpkern/t_sp.sh
--- a/tests/rump/rumpkern/t_sp.sh Wed Jan 12 11:39:20 2011 +0000
+++ b/tests/rump/rumpkern/t_sp.sh Wed Jan 12 12:32:53 2011 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: t_sp.sh,v 1.7 2011/01/12 11:39:20 pooka Exp $
+# $NetBSD: t_sp.sh,v 1.8 2011/01/12 12:32:53 pooka Exp $
#
# Copyright (c) 2010 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -42,7 +42,7 @@
test_case basic basic
test_case stress_short stress 1
-test_case stress_long stress 5
+test_case stress_long stress 2
test_case stress_killer stress 5 kill
test_case fork_simple fork simple
test_case fork_pipecomm fork pipecomm
@@ -60,7 +60,8 @@
{
export RUMP_SERVER=unix://commsock
- atf_check -s exit:0 rump_server ${RUMP_SERVER}
+ atf_check -s exit:0 rump_server \
+ -lrumpvfs -lrumpnet -lrumpnet_net -lrumpnet_netinet ${RUMP_SERVER}
atf_check -s exit:0 -e ignore $(atf_get_srcdir)/h_client/h_stresscli $@
}
Home |
Main Index |
Thread Index |
Old Index