forked from pool/libseccomp
77 lines
2.7 KiB
Diff
77 lines
2.7 KiB
Diff
|
From 13e0bae9571c195ee979a66b329aa538b87ee65d Mon Sep 17 00:00:00 2001
|
||
|
From: Paul Moore <paul@paul-moore.com>
|
||
|
Date: Tue, 19 Apr 2016 10:58:34 -0400
|
||
|
Subject: [PATCH] tests: replace socket syscall references in 15-basic-resolver
|
||
|
|
||
|
On 32-bit x86 the resolved socket syscall() doesn't always resolve to
|
||
|
the __NR_socket value due to the direct wired socket syscall so
|
||
|
replace it with the read() syscall to ensure the test doesn't fail.
|
||
|
|
||
|
Signed-off-by: Paul Moore <paul@paul-moore.com>
|
||
|
---
|
||
|
tests/15-basic-resolver.c | 8 ++++----
|
||
|
tests/15-basic-resolver.py | 6 +++---
|
||
|
2 files changed, 7 insertions(+), 7 deletions(-)
|
||
|
|
||
|
diff --git a/tests/15-basic-resolver.c b/tests/15-basic-resolver.c
|
||
|
index eff54fe..b3c9497 100644
|
||
|
--- a/tests/15-basic-resolver.c
|
||
|
+++ b/tests/15-basic-resolver.c
|
||
|
@@ -31,7 +31,7 @@ int main(int argc, char *argv[])
|
||
|
|
||
|
if (seccomp_syscall_resolve_name("open") != __NR_open)
|
||
|
goto fail;
|
||
|
- if (seccomp_syscall_resolve_name("socket") != __NR_socket)
|
||
|
+ if (seccomp_syscall_resolve_name("read") != __NR_read)
|
||
|
goto fail;
|
||
|
if (seccomp_syscall_resolve_name("INVALID") != __NR_SCMP_ERROR)
|
||
|
goto fail;
|
||
|
@@ -40,7 +40,7 @@ int main(int argc, char *argv[])
|
||
|
"open") != __NR_open)
|
||
|
goto fail;
|
||
|
if (seccomp_syscall_resolve_name_arch(SCMP_ARCH_NATIVE,
|
||
|
- "socket") != __NR_socket)
|
||
|
+ "read") != __NR_read)
|
||
|
goto fail;
|
||
|
if (seccomp_syscall_resolve_name_arch(SCMP_ARCH_NATIVE,
|
||
|
"INVALID") != __NR_SCMP_ERROR)
|
||
|
@@ -51,8 +51,8 @@ int main(int argc, char *argv[])
|
||
|
goto fail;
|
||
|
free(name);
|
||
|
|
||
|
- name = seccomp_syscall_resolve_num_arch(SCMP_ARCH_NATIVE, __NR_socket);
|
||
|
- if (name == NULL || strcmp(name, "socket") != 0)
|
||
|
+ name = seccomp_syscall_resolve_num_arch(SCMP_ARCH_NATIVE, __NR_read);
|
||
|
+ if (name == NULL || strcmp(name, "read") != 0)
|
||
|
goto fail;
|
||
|
free(name);
|
||
|
|
||
|
diff --git a/tests/15-basic-resolver.py b/tests/15-basic-resolver.py
|
||
|
index 329754e..12c4d7d 100755
|
||
|
--- a/tests/15-basic-resolver.py
|
||
|
+++ b/tests/15-basic-resolver.py
|
||
|
@@ -33,7 +33,7 @@ def test():
|
||
|
# this differs from the native test as we don't support the syscall
|
||
|
# resolution functions by themselves
|
||
|
f.add_rule(ALLOW, "open")
|
||
|
- f.add_rule(ALLOW, "socket")
|
||
|
+ f.add_rule(ALLOW, "read")
|
||
|
try:
|
||
|
f.add_rule(ALLOW, "INVALID")
|
||
|
except RuntimeError:
|
||
|
@@ -43,9 +43,9 @@ def test():
|
||
|
sys_name = resolve_syscall(Arch(), sys_num)
|
||
|
if (sys_name != "open"):
|
||
|
raise RuntimeError("Test failure")
|
||
|
- sys_num = resolve_syscall(Arch(), "socket")
|
||
|
+ sys_num = resolve_syscall(Arch(), "read")
|
||
|
sys_name = resolve_syscall(Arch(), sys_num)
|
||
|
- if (sys_name != "socket"):
|
||
|
+ if (sys_name != "read"):
|
||
|
raise RuntimeError("Test failure")
|
||
|
|
||
|
test()
|
||
|
--
|
||
|
2.6.6
|
||
|
|