diff options
author | deepak0414 <deepak0414@users.noreply.github.com> | 2023-02-02 12:51:50 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-02 12:51:50 -0800 |
commit | 982f93f5c55f6e7931c01afb082f5ca42cffddab (patch) | |
tree | 2e4fab47bcd19bccb66d2945761f237d334245d1 /v/vm.c | |
parent | 34a1175291f9531e85afdb89aaa77707f45fc8e4 (diff) | |
download | env-982f93f5c55f6e7931c01afb082f5ca42cffddab.zip env-982f93f5c55f6e7931c01afb082f5ca42cffddab.tar.gz env-982f93f5c55f6e7931c01afb082f5ca42cffddab.tar.bz2 |
env: trap and page fault filter mechanism (#40)
Certain tests (particularly negative) may require a fault to occur.
However in order to pass the tests, page fault and traps must return back
to the tests. This patch add support for page fault and trap filtering
in env.
Signed-off-by: Deepak Gupta <debug@rivosinc.com>
Diffstat (limited to 'v/vm.c')
-rw-r--r-- | v/vm.c | 15 |
1 files changed, 15 insertions, 0 deletions
@@ -136,8 +136,14 @@ static void evict(unsigned long addr) } } +extern int pf_filter(uintptr_t addr, uintptr_t *pte, int *copy); +extern int trap_filter(trapframe_t *tf); + void handle_fault(uintptr_t addr, uintptr_t cause) { + uintptr_t filter_encodings = 0; + int copy_page = 1; + assert(addr >= PGSIZE && addr < MAX_TEST_PAGES * PGSIZE); addr = addr/PGSIZE*PGSIZE; @@ -159,6 +165,11 @@ void handle_fault(uintptr_t addr, uintptr_t cause) freelist_tail = 0; uintptr_t new_pte = (node->addr >> PGSHIFT << PTE_PPN_SHIFT) | PTE_V | PTE_U | PTE_R | PTE_W | PTE_X; + + if (pf_filter(addr, &filter_encodings, ©_page)) { + new_pte = (node->addr >> PGSHIFT << PTE_PPN_SHIFT) | filter_encodings; + } + user_llpt[addr/PGSIZE] = new_pte | PTE_A | PTE_D; flush_page(addr); @@ -177,6 +188,10 @@ void handle_fault(uintptr_t addr, uintptr_t cause) void handle_trap(trapframe_t* tf) { + if (trap_filter(tf)) { + pop_tf(tf); + } + if (tf->cause == CAUSE_USER_ECALL) { int n = tf->gpr[10]; |