☐ riscv-software-src / riscv-isa-sim (Public) <> Code 11 Pull requests 29 Actions Projects Wiki • Issues 174 Jump to bottom

## [Bug Report] Wrong exception priority during access memory #971

Open Phantom1003 opened this issue on Apr 11 · 4 comments

New issue

```
Phantom1003 commented on Apr 11
                                                                                               Contributor
Let's take the load instruction as an example:
  riscv-isa-sim/riscv/mmu.h
  Lines 99 to 125 in 0f15aa0
   99
           #define load_func(type, prefix, xlate_flags) \
  100
             inline type##_t prefix##_##type(reg_t addr, bool require_alignment = false) { \
                if (unlikely(addr & (sizeof(type##_t)-1))) { \
  101
                  if (require_alignment) load_reserved_address_misaligned(addr); \
  102
                  else return misaligned_load(addr, sizeof(type##_t), xlate_flags); \
  103
  104
                } \
  105
                reg_t vpn = addr >> PGSHIFT; \
                size_t size = sizeof(type##_t); \
  106
                if ((xlate_flags) == 0 && likely(tlb_load_tag[vpn % TLB_ENTRIES] == vpn)) { \
  107
  108
                  if (proc) READ_MEM(addr, size); \
```

At line 101, load will first check if it is aligned, then at line 122 it will try to access the address in the load\_slow\_path function.

```
riscv-isa-sim/riscv/mmu.cc
Lines 142 to 162 in 0f15aa0
142
         void mmu_t::load_slow_path(reg_t addr, reg_t len, uint8_t* bytes, uint32_t xlate_flags
143
           reg_t paddr = translate(addr, len, LOAD, xlate_flags);
144
145
146
           if (auto host_addr = sim->addr_to_mem(paddr)) {
             memcpy(bytes, host_addr, len);
147
             if (tracer.interested_in_range(paddr, paddr + PGSIZE, LOAD))
148
               tracer.trace(paddr, len, LOAD);
149
             else if (xlate_flags == 0)
150
```



In load\_slow\_path, it will first check if it is legal address at line 153, and the watch point will be checked at the end of the function.

Briefly, the order of priority is as follows: trap\_load\_address\_misaligned > trap\_load\_access\_fault > trap\_breakpoint

However, in the specification, trap\_breakpoint has a higher priority than the others:

| Priority | Exc. Code                        | Description                                               |  |
|----------|----------------------------------|-----------------------------------------------------------|--|
| Highest  | 3                                | Instruction address breakpoint                            |  |
|          |                                  | During instruction address translation:                   |  |
|          | 12, 1                            | First encountered page fault or access fault              |  |
|          |                                  | With physical address for instruction:                    |  |
|          | 1                                | 1 Instruction access fault                                |  |
|          | 2 Illegal instruction            |                                                           |  |
|          | 0 Instruction address misaligned |                                                           |  |
|          | 8, 9, 11 Environment call        |                                                           |  |
|          | 3 Environment break              |                                                           |  |
|          | 3                                | Load/store/AMO address breakpoint                         |  |
|          |                                  | Optionally:                                               |  |
|          | 4, 6                             | Load/store/AMO address misaligned                         |  |
|          |                                  | During address translation for an explicit memory access: |  |
|          | 13, 15, 5, 7                     | First encountered page fault or access fault              |  |
|          |                                  | With physical address for an explicit memory access:      |  |
|          | 5, 7                             | Load/store/AMO access fault                               |  |
|          |                                  | If not higher priority:                                   |  |
| Lowest   | 4, 6                             | Load/store/AMO address misaligned                         |  |

We also co-simulate with rocket to check this point, rocket threw a breakpoint exception, while spike threw an error misaligned exception.

The test point is at 0x800001c0 where loading a misaligned illegal address 0x100004001:

```
3 0x00800001bc (0x7a261073)

core 0: 0x0000000800001bc (0x7a261073) csrw tdata2, a2

3 0x0080000004 (0x34302f73) x30 0x0000000100004001

core 0: 0x00000000800001c0 (0x00062603) lw a2, 0(a2)

core 0: exception trap_load_address_misaligned, epc 0x00000000800001c0

core 0: tval 0x0000000100004001

core 0: 0x0000000080000004 (0x34302f73) csrr t5, mtval

3 0x0080000008 (0x34202f73) x30 0x00000000000003

core 0: 0x0000000080000008 (0x34202f73) csrr t5, mcause

[error] WDATA SIM 00000000000000000
```

[error] check board clear 30 error
[CJ] integer register Judge Failed

spike-0.zip

scottj97 commented on Apr 11

Collaborator

I believe this is a duplicate of #538

Phantom1003 commented on Apr 11

Contributor

Author

Yes, but the priority of the misaligned exception is also wrong, which is outside of the load\_slow\_path function.

scottj97 commented on Apr 11

Collaborator

**@timsifive** perhaps this is of interest to you, since you're doing some trigger work now.

timsifive commented on Apr 11

Collaborator

I agree that this is wrong, and a (exceptionally clearly described) problem. It's been a long time since I added that trigger code. I'm not sure how to raise the trigger priority while minimizing the performance impact.

I might have time to look at this in a few weeks, when I'm back from vacation.



timsifive added a commit that referenced this issue on May 25

Don't check alignment before load\_slow\_path() ...

37fe50b

timsifive added a commit that referenced this issue on May 25

Fix trigger store priority. ...

✓ d392e69

timsifive mentioned this issue on May 25

Check triggers before checking alignment #1013

ใ ┆ Closed

| Ç              | timsifive added a commit that referenced this issue on May 26 |           |
|----------------|---------------------------------------------------------------|-----------|
|                | <pre>Don't check alignment before load_slow_path()</pre>      | a315c61   |
| Ç              | timsifive added a commit that referenced this issue on May 26 |           |
|                | Fix trigger store priority                                    | ✓ 3ce7a51 |
| ÇŽ             | timsifive added a commit that referenced this issue on May 27 |           |
|                | <pre>Check for alignment in load_slow_path()</pre>            | fb8eb2a   |
| Ç              | timsifive added a commit that referenced this issue on May 27 |           |
|                | Fix trigger store priority                                    | 9cb3499   |
| Ç              | timsifive added a commit that referenced this issue on Jun 10 |           |
|                | Check for alignment in load_slow_path()                       | bb65ba4   |
| ÇŽ             | timsifive added a commit that referenced this issue on Jun 10 |           |
|                | Fix trigger store priority                                    | 60b0саа   |
| Assign         |                                                               |           |
| No on          | e assigned                                                    |           |
| Labels<br>None |                                                               |           |
| Projec         | ts                                                            |           |
| None           |                                                               |           |
| Milest         | one                                                           |           |
| No mi          | estone                                                        |           |
| Devel          | ppment                                                        |           |

Successfully merging a pull request may close this issue.

## Check triggers before checking alignment

riscv-software-src/riscv-isa-sim

## 3 participants





