diff options
-rw-r--r-- | src/lib/libkogata/syscall.c | 6 | ||||
-rw-r--r-- | src/tests/utests/fs1/test.c | 22 | ||||
l--------- | src/tests/utests/fs2/Makefile | 1 | ||||
-rw-r--r-- | src/tests/utests/fs2/test.c | 30 | ||||
l--------- | src/tests/utests/subfs/Makefile | 1 | ||||
-rw-r--r-- | src/tests/utests/subfs/test.c | 32 |
6 files changed, 77 insertions, 15 deletions
diff --git a/src/lib/libkogata/syscall.c b/src/lib/libkogata/syscall.c index 37b2a1a..c79096e 100644 --- a/src/lib/libkogata/syscall.c +++ b/src/lib/libkogata/syscall.c @@ -91,7 +91,7 @@ int get_mode(fd_t file) { } bool make_fs(const char* name, const char* driver, fd_t source, const char* options) { - sc_make_fs_args_t args = { + volatile sc_make_fs_args_t args = { .driver = driver, .driver_strlen = strlen(driver), .fs_name = name, @@ -107,7 +107,7 @@ bool fs_add_source(const char* fs, fd_t source, const char* options) { return call(SC_FS_ADD_SRC, (uint32_t)fs, strlen(fs), source, (uint32_t)options, strlen(options)); } bool fs_subfs(const char* name, const char* orig_fs, const char* root, int ok_modes) { - sc_subfs_args_t args = { + volatile sc_subfs_args_t args = { .new_name = name, .new_name_strlen = strlen(name), .from_fs = orig_fs, @@ -117,7 +117,7 @@ bool fs_subfs(const char* name, const char* orig_fs, const char* root, int ok_mo .ok_modes = ok_modes, .bind_to_pid = 0 }; - return call(SC_SUBFS, (uint32_t)&args, 0, 0, 0, 0); + return call(SC_SUBFS, (uint32_t)(&args), 0, 0, 0, 0); } void fs_remove(const char* name) { call(SC_RM_FS, (uint32_t)name, strlen(name), 0, 0, 0); diff --git a/src/tests/utests/fs1/test.c b/src/tests/utests/fs1/test.c index bab4d07..79db13b 100644 --- a/src/tests/utests/fs1/test.c +++ b/src/tests/utests/fs1/test.c @@ -17,20 +17,18 @@ int main(int argc, char **argv) { dbg_printf("- '%s' %p %d\n", x.name, x.st.type, x.st.size); if (x.st.type == FT_REGULAR) { char buf[256]; - strcpy(buf, "dev:/"); - strcpy(buf+5, x.name); + strcpy(buf, "io:/"); + strcpy(buf+4, x.name); dbg_printf("trying to open %s...\n", buf); fd_t ff = open(buf, FM_READ); - if (ff != 0) { - dbg_printf("ok, open as %d\n", ff); - char* cont = malloc(x.st.size + 1); - ASSERT(read(ff, 0, x.st.size, cont) == x.st.size); - cont[x.st.size] = 0; - dbg_printf("> '%s'\n", cont); - close(ff); - } else { - dbg_printf("Could not open '%s'\n", buf); - } + ASSERT(ff != 0); + + dbg_printf("ok, open as %d\n", ff); + char* cont = malloc(x.st.size + 1); + ASSERT(read(ff, 0, x.st.size, cont) == x.st.size); + cont[x.st.size] = 0; + dbg_printf("> '%s'\n", cont); + close(ff); } } close(f); diff --git a/src/tests/utests/fs2/Makefile b/src/tests/utests/fs2/Makefile new file mode 120000 index 0000000..4630a7c --- /dev/null +++ b/src/tests/utests/fs2/Makefile @@ -0,0 +1 @@ +../rules.make
\ No newline at end of file diff --git a/src/tests/utests/fs2/test.c b/src/tests/utests/fs2/test.c new file mode 100644 index 0000000..f993c8e --- /dev/null +++ b/src/tests/utests/fs2/test.c @@ -0,0 +1,30 @@ +#include <string.h> + +#include <malloc.h> + +#include <syscall.h> +#include <debug.h> + +int main(int argc, char **argv) { + dbg_print("Hello, world! from user process.\n"); + + fd_t f = open("io:/mod", FM_READDIR); + dbg_printf("openned io:/mod as %d\n", f); + ASSERT(f != 0); + + dirent_t x; + size_t ent_no = 0; + ASSERT (readdir(f, ent_no++, &x)); + + ASSERT(!strcmp(x.name, "init.bin")); + ASSERT(x.st.type == FT_REGULAR); + + ASSERT(!readdir(f, ent_no++, &x)); + close(f); + + dbg_printf("(TEST-OK)\n"); + + return 0; +} + +/* vim: set ts=4 sw=4 tw=0 noet :*/ diff --git a/src/tests/utests/subfs/Makefile b/src/tests/utests/subfs/Makefile new file mode 120000 index 0000000..4630a7c --- /dev/null +++ b/src/tests/utests/subfs/Makefile @@ -0,0 +1 @@ +../rules.make
\ No newline at end of file diff --git a/src/tests/utests/subfs/test.c b/src/tests/utests/subfs/test.c new file mode 100644 index 0000000..2612939 --- /dev/null +++ b/src/tests/utests/subfs/test.c @@ -0,0 +1,32 @@ +#include <string.h> + +#include <malloc.h> + +#include <syscall.h> +#include <debug.h> + +int main(int argc, char **argv) { + dbg_print("Hello, world! from user process.\n"); + + ASSERT(fs_subfs("mod", "io", "/mod", FM_READ | FM_READDIR)); + + fd_t f = open("mod:/", FM_READDIR); + dbg_printf("openned mod:/ as %d\n", f); + ASSERT(f != 0); + + dirent_t x; + size_t ent_no = 0; + ASSERT (readdir(f, ent_no++, &x)); + + ASSERT(!strcmp(x.name, "init.bin")); + ASSERT(x.st.type == FT_REGULAR); + + ASSERT(!readdir(f, ent_no++, &x)); + close(f); + + dbg_printf("(TEST-OK)\n"); + + return 0; +} + +/* vim: set ts=4 sw=4 tw=0 noet :*/ |