summaryrefslogtreecommitdiff
path: root/regress
diff options
context:
space:
mode:
Diffstat (limited to 'regress')
-rw-r--r--regress/sys/kern/__syscall/Makefile5
-rw-r--r--regress/sys/kern/__syscall/__syscall.c35
2 files changed, 40 insertions, 0 deletions
diff --git a/regress/sys/kern/__syscall/Makefile b/regress/sys/kern/__syscall/Makefile
new file mode 100644
index 00000000000..e2705a916a2
--- /dev/null
+++ b/regress/sys/kern/__syscall/Makefile
@@ -0,0 +1,5 @@
+# $OpenBSD: Makefile,v 1.1 2002/02/08 21:39:22 art Exp $
+
+PROG= __syscall
+
+.include <bsd.regress.mk>
diff --git a/regress/sys/kern/__syscall/__syscall.c b/regress/sys/kern/__syscall/__syscall.c
new file mode 100644
index 00000000000..2dee210fc02
--- /dev/null
+++ b/regress/sys/kern/__syscall/__syscall.c
@@ -0,0 +1,35 @@
+/* $OpenBSD: __syscall.c,v 1.1 2002/02/08 21:39:22 art Exp $ */
+/*
+ * Written by Artur Grabowski <art@openbsd.org> 2002 Public Domain.
+ */
+#include <sys/types.h>
+#include <sys/syscall.h>
+#include <sys/wait.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <err.h>
+
+int
+main()
+{
+ int status;
+
+ switch(fork()) {
+ case -1:
+ err(1, "fork");
+ case 0:
+ __syscall(SYS_exit, (u_int64_t)17);
+ abort();
+ }
+
+ if (wait(&status) < 0)
+ err(1, "wait");
+
+ if (!WIFEXITED(status))
+ errx(1, "child didn't exit gracefully");
+
+ if (WEXITSTATUS(status) != 17)
+ errx(1, "wrong exit status");
+
+ return 0;
+}