summaryrefslogtreecommitdiff
path: root/src/cmd
diff options
context:
space:
mode:
authordzwdz2024-05-11 22:05:04 +0200
committerdzwdz2024-05-11 22:05:04 +0200
commit15e02a470652a5d4ef87485b5ae12afc06dc53f8 (patch)
treee27e410885abe69d4fd20211a27e0196392993a4 /src/cmd
parentec3d2400db15e6911138d88f95cae141a9da2130 (diff)
kernel: DUP_RDONLY and DUP_WRONLY
I probably should've tested DUP_WRONLY too, now that I think about it. TODO?
Diffstat (limited to 'src/cmd')
-rw-r--r--src/cmd/tests/kernel/miscsyscall.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/cmd/tests/kernel/miscsyscall.c b/src/cmd/tests/kernel/miscsyscall.c
index 1317720..883fcee 100644
--- a/src/cmd/tests/kernel/miscsyscall.c
+++ b/src/cmd/tests/kernel/miscsyscall.c
@@ -326,6 +326,40 @@ static void test_getnull(void) {
close(h2);
}
+static void test_dup_ro(void) {
+ char buf[2];
+
+ /* runs two times, trying to close either the original handle or the dup'd
+ * one. */
+ for (int i = 0; i < 2; i++) {
+ hid_t h = _sys_open(TMPFILEPATH, strlen(TMPFILEPATH), OPEN_CREATE | OPEN_RW);
+ test(0 <= h);
+ hid_t h2 = _sys_dup(h, 0, DUP_SEARCH | DUP_RDONLY);
+ test(0 <= h2);
+
+ test(_sys_write(h, "hi", 2, 0, 0) == 2);
+ test(_sys_write(h2, "no", 2, 0, 0) == -EACCES);
+
+ test(_sys_read(h, buf, 2, 0) == 2);
+ test(memcmp(buf, "hi", 2) == 0);
+ test(_sys_read(h2, buf, 2, 0) == 2);
+ test(memcmp(buf, "hi", 2) == 0);
+
+ if (i == 0) {
+ _sys_close(h);
+ test(_sys_read(h2, buf, 2, 0) == 2);
+ test(memcmp(buf, "hi", 2) == 0);
+ _sys_close(h2);
+ } else {
+ _sys_close(h2);
+ test(_sys_write(h, "ay", 2, 0, 0) == 2);
+ test(_sys_read(h, buf, 2, 0) == 2);
+ test(memcmp(buf, "ay", 2) == 0);
+ _sys_close(h);
+ }
+ }
+}
+
void r_k_miscsyscall(void) {
run_test(test_await);
run_test(test_await2);
@@ -338,4 +372,5 @@ void r_k_miscsyscall(void) {
run_test(test_badopen);
run_test(test_timer);
run_test(test_getnull);
+ run_test(test_dup_ro);
}