aboutsummaryrefslogtreecommitdiff
path: root/tools/regression
diff options
context:
space:
mode:
authorPawel Jakub Dawidek <pjd@FreeBSD.org>2010-08-06 19:16:20 +0000
committerPawel Jakub Dawidek <pjd@FreeBSD.org>2010-08-06 19:16:20 +0000
commitfeb681311396dbf87795a2e751fc4a9c1b8e0240 (patch)
tree03fcb00b671e08b6c029ee47263d197f1eeed6af /tools/regression
parent5ec432ed824f6f230c9af57af056fb1edcfa094d (diff)
downloadsrc-feb681311396dbf87795a2e751fc4a9c1b8e0240.tar.gz
src-feb681311396dbf87795a2e751fc4a9c1b8e0240.zip
Implement two new syscalls: bind(2) and connect(2) for operating on UNIX
domain sockets.
Notes
Notes: svn path=/head/; revision=210951
Diffstat (limited to 'tools/regression')
-rw-r--r--tools/regression/fstest/fstest.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/tools/regression/fstest/fstest.c b/tools/regression/fstest/fstest.c
index e058e0a20d30..b6cbeb0ff912 100644
--- a/tools/regression/fstest/fstest.c
+++ b/tools/regression/fstest/fstest.c
@@ -28,6 +28,8 @@
#include <sys/param.h>
#include <sys/stat.h>
+#include <sys/socket.h>
+#include <sys/un.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
@@ -63,6 +65,8 @@ enum action {
ACTION_SYMLINK,
ACTION_RENAME,
ACTION_MKFIFO,
+ ACTION_BIND,
+ ACTION_CONNECT,
ACTION_CHMOD,
#ifdef HAS_LCHMOD
ACTION_LCHMOD,
@@ -110,6 +114,8 @@ static struct syscall_desc syscalls[] = {
{ "symlink", ACTION_SYMLINK, { TYPE_STRING, TYPE_STRING, TYPE_NONE } },
{ "rename", ACTION_RENAME, { TYPE_STRING, TYPE_STRING, TYPE_NONE } },
{ "mkfifo", ACTION_MKFIFO, { TYPE_STRING, TYPE_NUMBER, TYPE_NONE } },
+ { "bind", ACTION_BIND, { TYPE_STRING, TYPE_NONE } },
+ { "connect", ACTION_CONNECT, { TYPE_STRING, TYPE_NONE } },
{ "chmod", ACTION_CHMOD, { TYPE_STRING, TYPE_NUMBER, TYPE_NONE } },
#ifdef HAS_LCHMOD
{ "lchmod", ACTION_LCHMOD, { TYPE_STRING, TYPE_NUMBER, TYPE_NONE } },
@@ -496,6 +502,32 @@ call_syscall(struct syscall_desc *scall, char *argv[])
case ACTION_MKFIFO:
rval = mkfifo(STR(0), (mode_t)NUM(1));
break;
+ case ACTION_BIND:
+ {
+ struct sockaddr_un sun;
+
+ sun.sun_family = AF_UNIX;
+ strlcpy(sun.sun_path, STR(0), sizeof(sun.sun_path));
+ sun.sun_len = SUN_LEN(&sun);
+ rval = socket(AF_UNIX, SOCK_STREAM, 0);
+ if (rval < 0)
+ break;
+ rval = bind(rval, (struct sockaddr *)&sun, sizeof(sun));
+ break;
+ }
+ case ACTION_CONNECT:
+ {
+ struct sockaddr_un sun;
+
+ sun.sun_family = AF_UNIX;
+ strlcpy(sun.sun_path, STR(0), sizeof(sun.sun_path));
+ sun.sun_len = SUN_LEN(&sun);
+ rval = socket(AF_UNIX, SOCK_STREAM, 0);
+ if (rval < 0)
+ break;
+ rval = connect(rval, (struct sockaddr *)&sun, sizeof(sun));
+ break;
+ }
case ACTION_CHMOD:
rval = chmod(STR(0), (mode_t)NUM(1));
break;