



# CORES TG – May 14 2020

Arjan Bink arjan.bink@silabs.com

Jérôme Quevremont jerome.quevremont@thalesgroup.com

Davide Schiavone davide@openhwgroup.org



#### Introductions



- Arjan Bink (Chair)
- Jérôme Quevremont (Vice-chair)

- Davide Schiavone (Director of Engineering)
- Everybody on the call
  - Welcome!
  - Can you please introduce yourself?



## Outline



- Scope / charter
- Cores
- Status of CV32E40P
- Call to action
- Next meetings



© OpenHW Group

## Scope / Charter



- Provide support to the OpenHW TWG\*, specifically in aiding the definition of the cores IP roadmap and selection of donated core IP
- Obtain, develop, and, maintain selected donated and new Core IPs based on Roadmap
- Alignment and ratification of feature proposals and contributions from members and the open-source community
- Planning and coordination of development efforts, including assignment and tracking specific features, issues, and documentation tasks
- Open-source delivery of production quality IP core releases guaranteed to inter-operate with industry standard tools, flows, and interfaces including relevant documentation
- Generation and maintenance of OpenHW specific standard proposals
  - Contribution to the RISC-V foundation via relevant proposals (as required)

© OpenHW Group





<sup>\*</sup> Actual roadmap definition and donation acceptance is performed at TWG level using inputs from our Cores TG and the other TGs

# Cores – Under design/verification\* or under discussion

| Core     | Family | Key features                                                                                         | State                                                                                                                               | Comment       |
|----------|--------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------|
| CV32E40P | CORE-V | RV32IM[F]CZfenceiZicsrXpulp[Xpulpzfinx]<br>M-mode, OBI bus interfaces, CLINT, 4-stage<br>pipeline    | Feature set frozen Under design/verification                                                                                        | RI5CY         |
| CV32E40  | CORE-V | RV32IM[F]CBPZfenceiZicsr[Zfinx]Xpulp<br>PMP, M/U-mode, OBI bus interfaces, CLIC,<br>4-stage pipeline | Feature set proposed Schedule after CV32E40P Optional Atomic extension?                                                             |               |
| CV64A    | CORE-V | RV64IMA[F,D]CZicsr<br>M/S/U-mode, AXI bus interfaces, Caches,<br>MMU, TLB, 6-stage pipeline          | Ariane still maintained by ETH Zurich PULP team; when to move to OpenHW? B extension?                                               | Ariane        |
| CV32A    | TBD    | RV32IMA[F]CZicsr M/S/U-mode, AXI bus interfaces, Caches, MMU, TLB, 6-stage pipeline                  | Concept proposed by Thales<br>Additional safety/security<br>features? Hypervisor mode?<br>CV32A optimized for FPGA? B<br>extension? | 32-bit Ariane |



© OpenHW Group May 2020

<sup>\*</sup> Agreed earlier to limit initial design verification effort to one core (as initial infrastructure is under development)

## Status of CV32E40P



- Design changes done
  - Interrupt architecture changed to Basic (a.k.a. CLINT)
  - Using the agreed parameter set
    - Hardware Loop parameterization
  - Bus interface improvements
  - Tracer for verification (Imperas)
- Design changes in progress
  - Debug trigger module
  - Convert performance counters

© OpenHW Group

Sleep pin



① 105 Open 🗸 115 Closed

Author ▼

- U tracer out of order for half-word aligned fence.i bug #329 opened 7 hours ago by eroom1966
- Fence.i interaction with external cache #328 opened 3 days ago by haugoug
- MPEC and MSTATUS update before Retire signal for ebreak bug
  #325 opened 7 days ago by GTumbush
- NMI is masked by MSTATUS[MIE] #323 opened 7 days ago by Imperas
- Question regarding DM\_HALTADDRESS question
  #321 opened 8 days ago by MikeOpenHWGroup
- ① Data address is not consistent with byte enable signals #318 opened 9 days ago by Silabs-ArjanB



May 2020

## Call to action



- Asking for contributors to help fixing issues from <a href="https://github.com/openhwgroup/cv32e40p/issues">https://github.com/openhwgroup/cv32e40p/issues</a>
  - RTL fixes
  - Documentation
  - Questions
  - Future improvements (e.g. PMP, User mode)
- Asking for contributors to
  - Drive finalization of CV32E40 feature set discussion
  - Drive adoption of Ariane from ETH Zurich PULP team
  - Drive CV64A feature set discussion
  - Drive CV32A feature set discussion
- Asking for contributors to
  - Develop and maintain selected donated core IPs



## Next meetings



- Preferences for frequency, date & time?
  - E.g. 16:00 CEST -> 7am in California, 10am in Ottawa, 10pm in China?
- Partner presentations (please ask us for a slot) ~15 minutes
  - Introduction of partner
  - How can you benefit from OpenHW?
    - Key interest?
  - How can you contribute to OpenHW?
    - On which Core can you commit resources (what are your plans)?

© OpenHW Group

- On Design?
- On Verification?
- On Software?
- On Hardware?
- Open to suggestion for meeting topics

