From c6bbf615e5c77ec273b954c11cef95df3d6f7286 Mon Sep 17 00:00:00 2001 From: dzwdz Date: Sun, 17 Jul 2022 20:28:53 +0200 Subject: kernel/virt_cpy: error struct, better error handling --- src/user/tests/main.c | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) (limited to 'src/user/tests/main.c') diff --git a/src/user/tests/main.c b/src/user/tests/main.c index 5bfd3aa..b4587f9 100644 --- a/src/user/tests/main.c +++ b/src/user/tests/main.c @@ -1,8 +1,9 @@ #define TEST_MACROS -#include -#include +#include #include #include +#include +#include static void run_forked(void (*fn)()) { if (!fork()) { @@ -16,6 +17,7 @@ static void run_forked(void (*fn)()) { } +const char *tmpfilepath = "/tmp/.test_internal"; static void test_await(void) { /* creates 16 child processes, each returning a different value. then checks @@ -186,6 +188,17 @@ static void test_malloc(void) { free(p1); } +static void test_efault(void) { + char *invalid = (void*)0x1000; + handle_t h; + + assert((h = _syscall_open(tmpfilepath, strlen(tmpfilepath), OPEN_CREATE))); + assert(_syscall_write(h, "dzwdz sucks ass!", 16, 0) == 16); + assert(_syscall_write(h, invalid, 16, 0) == -EFAULT); + assert(_syscall_write(h, "dzwdz is cool!!!", 16, 0) == 16); + close(h); +} + static void test_misc(void) { assert(_syscall(~0, 0, 0, 0, 0) < 0); /* try making an invalid syscall */ } @@ -201,5 +214,6 @@ void test_all(void) { run_forked(test_malloc); run_forked(test_pipe); run_forked(test_semaphore); + run_forked(test_efault); run_forked(test_misc); } -- cgit v1.2.3