summaryrefslogtreecommitdiff
path: root/regress
diff options
context:
space:
mode:
authoranton <anton@cvs.openbsd.org>2019-05-14 20:48:46 +0000
committeranton <anton@cvs.openbsd.org>2019-05-14 20:48:46 +0000
commit492af8837ee391b4335c4e94f68f241128e427f2 (patch)
treebd493901855d580352beb5bae9418e7c7745d78b /regress
parenta28511ad23a2e9937151afc6190701f14d112692 (diff)
test different buffer sizes
Diffstat (limited to 'regress')
-rw-r--r--regress/sys/dev/kcov/Makefile15
-rw-r--r--regress/sys/dev/kcov/kcov.c51
2 files changed, 40 insertions, 26 deletions
diff --git a/regress/sys/dev/kcov/Makefile b/regress/sys/dev/kcov/Makefile
index 6e2583b715b..a6c2a72bee3 100644
--- a/regress/sys/dev/kcov/Makefile
+++ b/regress/sys/dev/kcov/Makefile
@@ -1,4 +1,4 @@
-# $OpenBSD: Makefile,v 1.9 2019/01/20 10:02:38 anton Exp $
+# $OpenBSD: Makefile,v 1.10 2019/05/14 20:48:45 anton Exp $
PROG= kcov
WARNINGS= yes
@@ -9,6 +9,9 @@ DPADD+= ${LIBPTHREAD}
MODES+= pc
MODES+= cmp
+BUFSIZES+= 1
+BUFSIZES+= 2
+
TESTS+= close
TESTS+= coverage
TESTS+= dying
@@ -21,15 +24,17 @@ REGRESS_SETUP_ONCE= setup
setup: ${PROG}
.for m in ${MODES}
-. for t in ${TESTS}
-$m-$t:
+. for b in ${BUFSIZES}
+. for t in ${TESTS}
+$m-$b-$t:
@echo "\n======== ${@} ========"
if ${SUDO} ./${PROG} -p; then \
- ${SUDO} ./${PROG} ${KCOVFLAGS} -m $m $t; \
+ ${SUDO} ./${PROG} ${KCOVFLAGS} -b $b -m $m $t; \
else \
echo "SKIPPED"; \
fi
-REGRESS_TARGETS+= $m-$t
+REGRESS_TARGETS+= $m-$b-$t
+. endfor
. endfor
.endfor
diff --git a/regress/sys/dev/kcov/kcov.c b/regress/sys/dev/kcov/kcov.c
index 295673efd80..95bc221f8ec 100644
--- a/regress/sys/dev/kcov/kcov.c
+++ b/regress/sys/dev/kcov/kcov.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kcov.c,v 1.10 2019/01/23 19:40:20 anton Exp $ */
+/* $OpenBSD: kcov.c,v 1.11 2019/05/14 20:48:45 anton Exp $ */
/*
* Copyright (c) 2018 Anton Lindqvist <anton@openbsd.org>
@@ -30,13 +30,13 @@
#include <string.h>
#include <unistd.h>
-static int test_close(int, int);
-static int test_coverage(int, int);
-static int test_dying(int, int);
-static int test_exec(int, int);
-static int test_fork(int, int);
-static int test_open(int, int);
-static int test_state(int, int);
+static int test_close(int, int, unsigned long);
+static int test_coverage(int, int, unsigned long);
+static int test_dying(int, int, unsigned long);
+static int test_exec(int, int, unsigned long);
+static int test_fork(int, int, unsigned long);
+static int test_open(int, int, unsigned long);
+static int test_state(int, int, unsigned long);
static int check_coverage(const unsigned long *, int, unsigned long, int);
static void do_syscall(void);
@@ -47,14 +47,13 @@ static int kcov_open(void);
static __dead void usage(void);
static const char *self;
-static unsigned long bufsize = 256 << 10;
int
main(int argc, char *argv[])
{
struct {
const char *name;
- int (*fn)(int, int);
+ int (*fn)(int, int, unsigned long);
int coverage; /* test must produce coverage */
} tests[] = {
{ "close", test_close, 0 },
@@ -66,7 +65,9 @@ main(int argc, char *argv[])
{ "state", test_state, 1 },
{ NULL, NULL, 0 },
};
- unsigned long *cover;
+ const char *errstr;
+ unsigned long *cover, frac;
+ unsigned long bufsize = 256 << 10;
int c, fd, i;
int error = 0;
int mode = 0;
@@ -76,8 +77,16 @@ main(int argc, char *argv[])
self = argv[0];
- while ((c = getopt(argc, argv, "Em:pv")) != -1)
+ while ((c = getopt(argc, argv, "b:Em:pv")) != -1)
switch (c) {
+ case 'b':
+ frac = strtonum(optarg, 1, 100, &errstr);
+ if (frac == 0)
+ errx(1, "buffer size fraction %s", errstr);
+ else if (frac > bufsize)
+ errx(1, "buffer size fraction too large");
+ bufsize /= frac;
+ break;
case 'E':
reexec = 1;
break;
@@ -129,7 +138,7 @@ main(int argc, char *argv[])
err(1, "mmap");
*cover = 0;
- error = tests[i].fn(fd, mode);
+ error = tests[i].fn(fd, mode, bufsize);
if (verbose)
dump(cover, mode);
if (check_coverage(cover, mode, bufsize, tests[i].coverage))
@@ -145,7 +154,7 @@ main(int argc, char *argv[])
static __dead void
usage(void)
{
- fprintf(stderr, "usage: kcov [-Epv] -t mode test\n");
+ fprintf(stderr, "usage: kcov [-Epv] [-b fraction] -t mode test\n");
exit(1);
}
@@ -242,7 +251,7 @@ kcov_disable(int fd)
* Close before mmap.
*/
static int
-test_close(int oldfd, int mode)
+test_close(int oldfd, int mode, unsigned long bufsize)
{
int fd;
@@ -255,7 +264,7 @@ test_close(int oldfd, int mode)
* Coverage of current thread.
*/
static int
-test_coverage(int fd, int mode)
+test_coverage(int fd, int mode, unsigned long bufsize)
{
kcov_enable(fd, mode);
do_syscall();
@@ -276,7 +285,7 @@ closer(void *arg)
* Close kcov descriptor in another thread during tracing.
*/
static int
-test_dying(int fd, int mode)
+test_dying(int fd, int mode, unsigned long bufsize)
{
pthread_t th;
int error;
@@ -303,7 +312,7 @@ test_dying(int fd, int mode)
* Coverage of thread after exec.
*/
static int
-test_exec(int fd, int mode)
+test_exec(int fd, int mode, unsigned long bufsize)
{
pid_t pid;
int status;
@@ -338,7 +347,7 @@ test_exec(int fd, int mode)
* Coverage of thread after fork.
*/
static int
-test_fork(int fd, int mode)
+test_fork(int fd, int mode, unsigned long bufsize)
{
pid_t pid;
int status;
@@ -373,7 +382,7 @@ test_fork(int fd, int mode)
* Open /dev/kcov more than once.
*/
static int
-test_open(int oldfd, int mode)
+test_open(int oldfd, int mode, unsigned long bufsize)
{
unsigned long *cover;
int fd;
@@ -404,7 +413,7 @@ test_open(int oldfd, int mode)
* State transitions.
*/
static int
-test_state(int fd, int mode)
+test_state(int fd, int mode, unsigned long bufsize)
{
if (ioctl(fd, KIOENABLE, &mode) == -1) {
warn("KIOSETBUFSIZE -> KIOENABLE");