

## RISC V ARCH TEST

### TASK 05

**Test Description :** First, set up the Level 1 and Level 0 page table entries. Then, write some instructions in the Data\_and\_int\_page section. After that, test for instruction load, and store page faults from that section, which is mapped through MMU.

Virtual address space start from 0x80000000

Set root page PTE

```

1 re 0: 3 0x8000012c (0x00a59593) x11 0x20000c00
2 re 0: 0x80000130 (0x00c5e5b3) or      a1, a1, a2
3 re 0: 3 0x80000130 (0x00c5e5b3) x11 0x20000c01
4 re 0: 0x80000134 (0x00b2a023) sw      a1, 0(t0)
5 re 0: 3 0x80000134 (0x00b2a023) mem 0x80002800 0x20000c01
6 re 0: 0x80000138 (0x00008067) ret

```

Set leaf page entry with XWR and Access bit and dirty high

```

1 0: 3 0x80000158 (0x00a59593) x11 0x20001000
2 0: 0x8000015c (0x00c5e5b3) or      a1, a1, a2
3 0: 3 0x8000015c (0x00c5e5b3) x11 0x200010cf
4 0: 0x80000160 (0x00b2a023) sw      a1, 0(t0)
5 0: 3 0x80000160 (0x00b2a023) mem 0x80003000 0x200010cf
6 0: 0x80000164 (0x00008067) ret

```

Setup satap register with mode and PPN

```

1 08 core 0: 3 0x80000074 (0x0062e2b3) x5 0x80080002
2 09 core 0: 0x80000078 (0x18029073) csrw satp, t0
3 10 core 0: 3 0x80000078 (0x18029073) c384 satp 0x80080002
4 11 core 0: 0x8000007c (0x00000513) li      a0, 0

```

Switch to Supervisor mode and make sure mpec hold virtual address

```

1 core 0: 0x800001a8 (0x30200073) mret
2 core 0: 3 0x800001a8 (0x30200073) c768_mstatus 0x00000080 c784_mstatus
3 core 0: >>> _start
4 core 0: 0x80000000 (0x00100513) li      a0, 1
5 core 0: 1 0x80000000 (0x00100513) x10 0x00000001
6 core 0: 0x80000004 (0x00200593) li      a1, 2

```

Now call Ecall which switch supervisor mode to machine exception trap handler

```

1 0 core 0: 0x8000001c (0x00000073) ecall
2 1 core 0: exception trap_supervisor_ecall, epc 0x8000001c
3 2 core 0: >>> trap_handler
4 3 core 0: 0x800001ac (0x342022f3) csrr      t0, mcause
5 4 core 0: 3 0x800001ac (0x342022f3) x5 0x00000009
6 5 core 0: 0x800001ac (0x342022f3) x5 0x00000009

```

Trap handler switch the and jump to main code linst\_page\_fault and change the level 0 PTE entry permissions ,

# RISC V ARCH TEST

## TASK 05

```

0: 3 0x800001f8 (0x00000313) x6 0x00000000
0: 0x800001fc (0x30200073) mret
0: 3 0x800001fc (0x30200073) c768_mstatus 0x00000080 c78
0: >>> gen_inst_page_fault
0: 0x80000088 (0x80000537) lui      a0, 0x80000

```

PTE permission becomes only READ WRITe WHICH cause the inst page fault

```

0: 0x00000100 (0x00002a023) sw      a1, 0(t0)
0: 3 0x80000160 (0x00b2a023) mem 0x80003000 0x200010c1
0: 0x80000164 (0x00008067) ret

```

Switch to supervisor mode make sure mepc loaded with virtual address and this cause the inst\_page\_fault

```

core 0: 0x800001a4 (0x34109373) csrrw t1, mepc, ra
core 0: 3 0x800001a4 (0x34109373) x6 0x80000088 c833_mepc 0x80000020
core 0: 0x800001a8 (0x30200073) mret
core 0: 3 0x800001a8 (0x30200073) c768_mstatus 0x00000088 c784_mstatush 0x00000000
core 0: exception trap_instruction_page_fault, epc 0x80000020
core 0:           tval 0x80000020
core 0: >>> trap_handler
core 0: 0x800001ac (0x342022f3) csrr t0, mcause

```

Then trap handler jump to main code according to mcause after that level 0 PTE permission updated to test load page fault and

```

core 0: 3 0x800001a4 (0x34109373) x6 0x00000020 c833_mepc 0x80000020
core 0: 0x800001a8 (0x30200073) mret
core 0: 3 0x800001a8 (0x30200073) c768_mstatus 0x00000088 c784_mstatush 0x00000000
core 0: >>> main
core 0: 0x80000020 (0x80000537) lui      a0, 0x80000
core 0: 1 0x80000020 (0x80000537) x10 0x80000000
core 0: 0x80000024 (0x12450513) addi    a0, a0, 292
core 0: 1 0x80000024 (0x12450513) x10 0x80000124
core 0: 0x80000028 (0x00052583) lw      a1, 0(a0)
core 0: exception trap load page fault, epc 0x80000028
core 0:           tval 0x80000124
core 0: >>> trap_handler
core 0: 0x800001ac (0x342022f3) csrr t0, mcause

```

**RISC V ARCH TEST  
TASK 05**

Now trap handler perform same operation but now set persian for store page fault

```
core 0: 0x800001a8 (0x30200073) mret
core 0: 3 0x800001a8 (0x30200073) c768_mstatus 0x00000088 c784_mstatush 0x00000000
core 0: 0x8000002c (0x80000537) lui    a0, 0x80000
core 0: 1 0x8000002c (0x80000537) x10   a0, 0x80000000
core 0: 0x80000030 (0x12450513) addi   a0, a0, 292
core 0: 1 0x80000030 (0x12450513) x10   0x80000124
core 0: 0x80000034 (0x02800593) li     a1, 40
core 0: 1 0x80000034 (0x02800593) x11   0x00000028
core 0: 0x80000038 (0x00b52023) sw     a1, 0(a0)
core 0: exception trap store page fault, epc 0x80000038
core 0:           tval 0x80000124
core 0: >>> trap_handler
```

As we all tested write ,read exceted faults generated by permission now trap handler jump to main then it jump to test\_pass , Hart is in m mode at time of exit