From ab7a811562ccf0cb4f77012f646208c0b6a1ffb5 Mon Sep 17 00:00:00 2001 From: bjs Date: Mon, 1 Jul 2024 10:09:24 +0000 Subject: [PATCH] (litmus_tests/exc) add some faulting exceptions litmus tests --- litmus/litmus_tests/exc/faults/MP+dmb+fault.c | 65 ++++++++++++++++++ litmus/litmus_tests/exc/faults/MP+fault+dmb.c | 66 +++++++++++++++++++ 2 files changed, 131 insertions(+) create mode 100644 litmus/litmus_tests/exc/faults/MP+dmb+fault.c create mode 100644 litmus/litmus_tests/exc/faults/MP+fault+dmb.c diff --git a/litmus/litmus_tests/exc/faults/MP+dmb+fault.c b/litmus/litmus_tests/exc/faults/MP+dmb+fault.c new file mode 100644 index 0000000..0e4135f --- /dev/null +++ b/litmus/litmus_tests/exc/faults/MP+dmb+fault.c @@ -0,0 +1,65 @@ + +#include "lib.h" + +#define VARS x, y, z +#define REGS p1x0, p1x2 + +static void P0(litmus_test_run* data) { + asm volatile( + "mov x0, #1\n\t" + "str x0, [%[x]]\n\t" + "dmb sy\n\t" + "mov x2, #1\n\t" + "str x2, [%[y]]\n\t" + : + : ASM_VARS(data, VARS), ASM_REGS(data, REGS) + : "cc", "memory", "x0", "x2" + ); +} + +static void svc_handler(void) { + asm volatile( + /* x3 = X */ + "ldr x2, [x3]\n\t" + "eret\n\t" + ); +} + +static void P1(litmus_test_run* data) { + asm volatile( + /* load variables into machine registers */ + "mov x1, %[y]\n\t" + "mov x3, %[x]\n\t" + "mov x5, %[z]\n\t" + + /* run the test */ + "ldr x0, [x1]\n\t" + "ldr x4, [x5]\n\t" + + /* extract values */ + "str x0, [%[outp1r0]]\n\t" + "str x2, [%[outp1r2]]\n\t" + "dmb st\n\t" + : + : ASM_VARS(data, VARS), ASM_REGS(data, REGS) + : "cc", "memory", "x0", "x1", "x2", "x3", "x4", "x5", "x6", "x7" /* dont touch parameter registers */ + ); +} + +litmus_test_t MP_dmb_fault = { + "MP+dmb+fault", + MAKE_THREADS(2), + MAKE_VARS(VARS), + MAKE_REGS(REGS), + INIT_STATE(3, INIT_VAR(x, 0), INIT_VAR(y, 0), INIT_UNMAPPED(z)), + .requires_pgtable = 1, + .thread_sync_handlers = + (u32 * *[]){ + (u32*[]){ NULL, NULL }, + (u32*[]){ (u32*)svc_handler, NULL }, + }, + .interesting_result = (u64[]){ + /* p1:x0 =*/1, + /* p1:x2 =*/0, + }, +}; \ No newline at end of file diff --git a/litmus/litmus_tests/exc/faults/MP+fault+dmb.c b/litmus/litmus_tests/exc/faults/MP+fault+dmb.c new file mode 100644 index 0000000..7b6ad77 --- /dev/null +++ b/litmus/litmus_tests/exc/faults/MP+fault+dmb.c @@ -0,0 +1,66 @@ + +#include "lib.h" + +#define VARS x, y, z +#define REGS p1x0, p1x2 + +static void svc_handler(void) { + asm volatile( + /* x3 = Y */ + "mov x2, #1\n\t" + "str x2, [x3]\n\t" + "eret\n\t" + ); +} + +static void P0(litmus_test_run* data) { + asm volatile( + "mov x1, %[x]\n\t" + "mov x3, %[y]\n\t" + "mov x5, %[y]\n\t" + + "mov x0, #1\n\t" + "str x0, [x1]\n\t" + "ldr x4, [x5]\n\t" + : + : ASM_VARS(data, VARS), ASM_REGS(data, REGS) + : "cc", "memory", "x0", "x1", "x2", "x3" + ); +} + +static void P1(litmus_test_run* data) { + asm volatile( + /* load variables into machine registers */ + "mov x1, %[y]\n\t" + "mov x3, %[x]\n\t" + + "ldr x0,[x1]\n\t" + "dmb sy\n\t" + "ldr x2,[x3]\n\t" + + /* extract values */ + "str x0, [%[outp1r0]]\n\t" + "str x2, [%[outp1r2]]\n\t" + : + : ASM_VARS(data, VARS), ASM_REGS(data, REGS) + : "cc", "memory", "x0", "x1", "x2", "x3", "x4", "x5", "x6", "x7" /* dont touch parameter registers */ + ); +} + +litmus_test_t MP_fault_dmb = { + "MP+fault+dmb", + MAKE_THREADS(2), + MAKE_VARS(VARS), + MAKE_REGS(REGS), + INIT_STATE(3, INIT_VAR(x, 0), INIT_VAR(y, 0), INIT_UNMAPPED(z)), + .requires_pgtable = 1, + .thread_sync_handlers = + (u32 * *[]){ + (u32*[]){ (u32*)svc_handler, NULL }, + (u32*[]){ NULL, NULL }, + }, + .interesting_result = (u64[]){ + /* p1:x0 =*/1, + /* p1:x2 =*/0, + }, +};