





# **Functional Verification for Agile Processor Development:** A Case for Workflow Integration



























Yi-Nan Xu

Kai-Fan Wang Hua-Qiang Wang Jia-Wei Lin

Yue Jin

Lin-Juan Zhang Zi-Fei Zhang

Dan Tang

Sa Wang

Kan Shi

Ning-Hui Sun Yun-Gang Bao

## The Era of Agile Processor Development



## **Dynamic Functional Verification**

Design **Under Test** (DUT)



Model

(REF)

**Test** 

## Dynamic Functional Verification with Agile Development



### **Proposed Methods and Tools**

#### Diff-Rule Based Agile Verification (DRAV)

#### Runtime Behavioral Hints



### **Verifying RISC-V Processors**

Rocket Chip Generator



**RISC-V CPU** 

NutShell (果壳)



XiangShan (香山)



- ArchEvent
- InstrCommitEvent
- TrapEvent
- **CSRState**
- DebugModeState
- ArchIntRegState
- ArchFpRegState
- ArchIntDelayedUpdate
- ArchFpDelayedUpdate

- IntWritebackEvent
- FpWritebackEvent
- StoreEvent
- SbufferEvent
- LoadEvent
- AtomicEvent
- RefillEvent
- LrScEvent

Information Probes

**RISC-V REF** 

**Spike** 

**NEMU** 

- memcpy
- regcpy
- exec
- guided exec
- raise intr
- debug\_mem\_sync
- store commit

- csrcpy
- uarch sync
- update config
- load\_flash\_bin
- set ramsize
- disambiguation\_state

**REF Proxy Interfaces**.



## **Verifying RISC-V Processors – Cont.**

#### 33 Functional Bugs Found in NutShell

| Category          | Bug ID                                                                    | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Arithmetic        | 769669f                                                                   | 32-bit AMO instructions do not sign-extend the 32-bit operands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CSR<br>Operations | 42c8460<br>ef78025<br>5b60e9c<br>b86c319<br>6f4cd05                       | Reserved and non-writable fields in mstatus may be written by CSR instructions. The virtual address is not zero-extended to 64-bit if virtual memory is disabled. mtval/stval is incorrectly updated without considering the exception delegation. mstatus.mprv is not cleared when MRET/SRET to a mode less privileged than M. mstatus.mpp is updated and read with an illegal value (ModeH).                                                                                                                                             |
| Access<br>Control | 54367ce<br>f23acbf<br>5dd6a74<br>ccd9c7f<br>7f928a3<br>f8acb2a<br>c508b32 | An illegal jump target causes mistakenly executed load/store operations.  Misaligned LR/SC operations are not detected as address-misaligned exceptions.  Non-existent CSRs such as pmpcfg1 and pmpcfg3 are enabled in RV64.  CSRRC/CSRRCI causes write side effects when rs1=x0 or uimm[4:0]=0.  SC incorrectly updates the reservation sets that should be set by LR only.  mstatus.TVM does not intercept supervisor virtual-memory management operations.  Large pages with misaligned PPNs are not detected as page-fault exceptions. |



#### **Higher** Coverage for NutShell and REF



<a href="#"><1%</a> Performance Overhead for Snapshots
<a href="#">An Order of Magnitude Lower</a> than SOTA

## **How? Workflow Integration!**



Key Principles: Collaborative Task Delegation + Dynamic Information Exchange







# Functional Verification for Agile Processor Development: A Case for Workflow Integration

#### A Paper from the XiangShan Team



More papers at



