



**CORE-V™**



**OPENHW™**

# OpenHW Group

CORE-V: Open Source RISC-V Cores Commercial Adoption  
Lesson Learned

Rick O'Connor [rickoco@openhwgroup.org](mailto:rickoco@openhwgroup.org)

T [@rickoco](https://twitter.com/rickoco) T [@openhwgroup](https://twitter.com/openhwgroup)

[www.openhwgroup.org](http://www.openhwgroup.org)

# Outline



- OpenHW Group History
- OpenHW ~ 3 Years Later – Lessons Learned
  - Lesson 1 – Permissive Use
  - Lesson 2 – IP Quality
  - Lesson 3 – Roadmap & Ecosystem
- Summary

# OpenHW Launch June 2019



- OpenHW Group Launch at ETH Zurich 11 June 2019
- 13 Initial Sponsors & 2 Projects
- <https://riscv.org/proceedings/2019/06/risc-v-workshop-zurich-proceedings/>



## OpenHW Group Initial Sponsors



## CORE-V™ Family of RISC-V Cores



- Initial contribution of open source RISC-V cores from ETH Zurich PULP Platform
  - Very popular, industry adopted cores
- OpenHW Group becomes official committer for these repositories



| Core   | Bits/Stages     | Description                                                                                                                                                                                                                                                                                                                         |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RISCVY | 32bit / 4-stage | A 4-stage core that implements the RV32-IMC, has an optional 32-bit FPU supporting the F extension and instruction set extensions for DSP operations, including hardware loops, SIMD extensions, bit manipulation and post-increment instructions.                                                                                  |
| Ariane | 64bit / 6-stage | A 6-stage, single issue, in-order CPU implementing RV64IMCD extensions with three privilege levels M, S, U to fully support a Unix-like (Linux, BSD, etc.) operating system. It has configurable size, separate TLBs, a hardware PTW and branch-prediction (branch target buffer, branch history table and a return address stack). |



© OpenHW Group - RISC-V / WOSH ETH Zurich

11 June 2019

5



© OpenHW Group - RISC-V / WOSH ETH Zurich

11 June 2019

14



© OpenHW Group

June 2023

3



**OPENHW<sup>®</sup>**  
GROUP  
PROVEN PROCESSOR IP

and **CORE-V<sup>®</sup>**



- OpenHW Group is a not-for-profit, global organization registered in Canada and Europe. The OpenHW ecosystem is driven by members (corporate & academic) and individual contributors where HW and SW designers collaborate in developing open-source cores, related IP, tools and SW such as the CORE-V Family of open-source RISC-V processors
  - International footprint with developers in North America, Europe and Asia
  - Providing an infrastructure for hosting high quality open-source HW developments in line with industry best practices
  - Strong support from industry, academia and individual contributors worldwide



**OPENHW<sup>®</sup>**  
GROUP  
PROVEN PROCESSOR IP



# Industry Members

## 104+ Members & Partners



em microelectronic



**OPENHW<sup>®</sup>**  
GROUP  
PROVEN PROCESSOR IP





**OPENHW**<sup>®</sup>  
GROUP  
PROVEN PROCESSOR IP



ALMA MATER STUDIORUM  
UNIVERSITÀ DI BOLOGNA

**HARVEY  
MUDD  
COLLEGE**



中国科学院计算技术研究所  
INSTITUTE OF COMPUTING TECHNOLOGY, CHINESE ACADEMY OF SCIENCES



OKLAHOMA STATE  
UNIVERSITY

POLYTECHNIQUE  
MONTRÉAL  
WORLD-CLASS  
ENGINEERING



R RIOS

SFU

SIMON FRASER  
UNIVERSITY

SCIENCES  
SORBONNE  
UNIVERSITÉ

**TECHNION**  
Israel Institute  
of Technology



uOttawa

University of  
Reading

UC SANTA BARBARA



**OPENHW**<sup>®</sup>  
GROUP  
PROVEN PROCESSOR IP

# Academic Members

## 104+ Members & Partners



**CMC**  
MICROSYSTEMS

csem ETH zürich

**ETS**  
Le génie pour l'industrie  
ÉCOLE DE  
TECHNOLOGIE  
SUPÉRIEURE  
Université du Québec

UNIVERSITY OF  
Southampton



UNIVERSITY OF  
TORONTO



Science and  
Technology  
Facilities Council



# Partner Ecosystem

104+ Members & Partners



AMD  
XILINX

aws cādēnē



OpenUK ◆ ORCRO

Accounting, Legal, Banking



NORTON ROSE FULBRIGHT



# Working Groups & Task Groups



- Board of Directors approves elected Chairs of Working Groups and has final approval of working group recommendations
- Technical Working Group
  - Cores Task Group
  - Verification Task Group
  - SW Task Group
  - HW Task Group
- Marketing Working Group
  - University Outreach Task Group
- OpenHW Asia Working Group
- OpenHW Europe Working Group
- Together with internal OpenHW Group engineering staff, member company development engineers (FTEs / ACs) establish and execute OpenHW Group projects
  - 20+ active projects across CORE-V RTL, Verification, GCC / LLVM, IDE, RTOS, FPGA, SoC, etc. with more projects in the pipeline



# OpenHW Cores Task Group

- Chair: Arjan Bink, Silicon Laboratories
- Vice-Chair: Jérôme Quévremont, Thales Research & Technology
- develop feature and functionality roadmap and the open-source IP for the cores within the OpenHW Group such as the CORE-V Family of open-source RISC-V processors.
- Initial contribution of open-source RISC-V cores from [ETH Zurich PULP Platform](#) and the OpenHW Group is the [official committer for these repositories](#)



**THALES**

**ETHzürich**  **PULP**  
Parallel Ultra Low Power

| Core             | Bits/Stage              | Description                                                                                                                                                                                                                                                                                                                                         |
|------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CVE4<br>(RI5CY)  | 32bit /<br>4-stage      | A family of 4-stage cores that implement, RV32IMFCXpulp, optional 32-bit FPU, instruction set extensions for DSP operations including HW loops, SIMD extensions, bit manipulation and post-increment instructions.                                                                                                                                  |
| CVA6<br>(Ariane) | 32 & 64bit /<br>6-stage | A family of 6-stage, single issue, in-order CPU cores implementing RV64GC extensions with three privilege levels M, S, U to fully support a Unix-like (Linux, BSD, etc.) operating system. The cores have configurable size, separate TLBs, a HW PTW and branch-prediction (branch target buffer, branch history table and a return address stack). |



# CORE-V® Cores Roadmap



| CORE                                                                                                                                                           | TRL TARGET | 2020 |    |    |    | 2021 |    |    |    | 2022 |    |    |    | 2023 |         |    |    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------|----|----|----|------|----|----|----|------|----|----|----|------|---------|----|----|
|                                                                                                                                                                |            | Q1   | Q2 | Q3 | Q4 | Q1   | Q2 | Q3 | Q4 | Q1   | Q2 | Q3 | Q4 | Q1   | Q2      | Q3 | Q4 |
| CVA6:<br>CV32A60X                                                                                                                                              | 4          |      |    | PC | PL |      |    | PA |    |      |    |    |    |      | PF      |    |    |
| CV32A60X is RV32IMCA with CV-X-IF support; 2023 target is TRL4. CVA6 family targets RV[32,64]GC @TRL5.                                                         |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CVA5                                                                                                                                                           | 3          |      |    |    |    |      | PC |    |    |      |    |    |    |      |         |    |    |
| RV32IMA soft-core for FPGA                                                                                                                                     |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV-WALLY                                                                                                                                                       | 4          |      |    |    |    |      |    |    |    | PC   | PL | PA |    | PF   | 2024 Q4 |    |    |
| RV32I, RV32E, and RV64I, 5-stage, support for A, C, D, F, and M extensions, and optional caches, branch prediction, virtual memory, AHB, RAMs, and peripherals |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV32E40PV1                                                                                                                                                     | 5          | PC   | PL | PA | PF |      |    |    |    |      |    |    |    |      |         |    |    |
| RV32IMC                                                                                                                                                        |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV32E40PV2                                                                                                                                                     | 5          |      |    | PC | PL |      |    | PA |    | PF   |    |    |    |      |         |    |    |
| RV32IMC[Zicount_Zicsr_Zifencei][PULP_XPULP][PULP_CLUSTER][PULP_ZFINX]                                                                                          |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV32E41                                                                                                                                                        | 3          |      |    | PC |    |      |    |    |    |      |    |    |    |      |         |    |    |
| RV32IMC[Zicount_Zicsr_Zifencei][Zce][Zfinx][PULP_XPULP][PULP_CLUSTER]                                                                                          |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV32E40X                                                                                                                                                       | 5          |      |    | PL | PA |      |    |    |    |      |    |    |    | PF   |         |    |    |
| RV32[I,E][M]Zmmu)[A]Zca_Zcb_Zcmp_Zcmf[Zba_Zbb_Zbs]Zba_Zbb_Zbc_Zbs]ZicntrZihpmZicsrZifencei[X]                                                                  |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV32E40S                                                                                                                                                       | 5          |      |    | PL | PA |      |    |    |    |      |    |    |    | PF   |         |    |    |
| RV32[I,E][M]Zmmul]Zca_Zcb_Zcmp_Zcmf[Zba_Zbb_Zbs]Zba_Zbb_Zbc_Zbs]ZicsrZifencei[X secure @ TRL5                                                                  |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |
| CV32E20                                                                                                                                                        | 5          |      |    | PC |    | PL   |    |    | PA |      | PF |    |    |      |         |    |    |
| RV32[I,E][M]Zicount_Zicsr_Zifencei[_Zce]                                                                                                                       |            |      |    |    |    |      |    |    |    |      |    |    |    |      |         |    |    |

OpenHW Project Gates



Project  
Concept



Project  
Launch



Plan  
Approved



Project  
Freeze

# OpenHW Collaboration Stats



CoderStats(openhwgroup)

GitHub user name

Get Stats

OpenHW Group



Joined GitHub 27 May 2019

openhwgroup  
www.openhwgroup.org  
Ottawa, Ontario, Canada

Repo types



</> Pushed to repos

54

Main languages

10

Total issues

769

Total forks

1627

Total stars

4171

Followers

326

Following

0

## Summary

OpenHW Group has 55 repositories on GitHub, the latest 55 with user activity were loaded from GitHub's web service for this evaluation. OpenHW Group has pushed to 54 of these repositories. This is a high ratio congratulations!

10 different main languages were identified across all repos pushed to. The main language is the one with the largest amount of code in a given repository, as identified by GitHub's [linguist](#). Assuming a basic level of proficiency in all these languages OpenHW Group can be considered hyperpolyglot in the world of computer languages. [SystemVerilog](#) occurs most frequently - 14 times - as the main repo language.

The total number of forks across all pushed to repositories indicates that the GitHub projects OpenHW Group contributes to are actually used by other people.

## Rankings

### Languages



### Issues



### Forks



### Stars



# Silicon Labs OpenHW Leadership



"As a leader in secure, intelligent wireless technology for a more connected world, Silicon Labs products need efficient, low-cost, customizable processor cores to realize our customers' performance requirements.

The OpenHW CORE-V CVE4 family of open-source RISC-V cores satisfy these requirements, and Silicon Labs has taken a leadership position within the OpenHW ecosystem to help drive the execution of various CORE-V CVE4 projects.

A range of Silicon Labs SoC products have adopted various CVE4 cores and have launched into high-volume production," said Daniel Cooley, Silicon Labs CTO & Board Member, OpenHW Group.



# Thales OpenHW Leadership

"In 2018, Thales joined the RISC-V Foundation to help design the RISC-V open instruction set and above all to rally manufacturers and academics around a subject that is crucial for our sovereignty.

In 2019, Thales was a founding member of the OpenHW Group and has taken a leadership role within open-source hardware communities to design processors for critical embedded systems, particularly in the aerospace, defence and cybersecurity sectors with a particular focus on the OpenHW CORE-V CVA6 processor.

Open-source solutions for hardware as well as software are becoming more integral than ever to Thales's innovation strategy." said Daniel Glazman, VP Software Technologies at Thales.



# TALES

# Open Source HW Adoption Lessons



- Lesson 1 - Permissive use
  - permissive open-source licensing and processes to minimize business and legal risks
- Lesson 2 - IP quality
  - harness community best-in-class design and verification methods and contributions
- Lesson 3 - Roadmap & Ecosystem
  - ensure availability of IDE, RTOS / OS ports, physical design etc. and create a roadmap of cores covering a range of PPA metrics

# Open Source License Usage



Permissive vs. Copy-left Licenses Over Time



Top Open Source Licenses in 2021



<https://www.whitesourcesoftware.com/resources/blog/open-source-licenses-trends-and-predictions/>

# HW Companies & Open Source



- Large Systems & Semiconductor companies have very deep patent portfolios
- Copyleft / GPL style licenses are generally seen to pose a greater risk of unwanted patent exposure
- Companies need to see commercial benefit to 'give back' and not be forced to give back through license terms
- Apache provides permissive terms with both copyright and patent grants – also, most HW companies have already accepted Apache for SW projects
- But is Apache enough?

# Solderpad Hardware License 2.1

- A permissive open hardware license
- Based on, and acts as an exception to, Apache-2.0
- SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1
- Covers physical hardware as well as open silicon and gateware
- Modifies, clarifies and extends various Apache definitions, and the scope of rights to explicitly cover hardware
- Not specifically OSI approved, but we know it falls within the OSI definition of “open source” because any licensee can treat as plain Apache-2.0
- <http://solderpad.org/licenses/SHL-2.1/>



# Open Source HW Adoption Lessons



- Lesson 1 - Permissive use
  - permissive open-source licensing and processes to minimize business and legal risks
- Lesson 2 - IP quality
  - harness community best-in-class design and verification methods and contributions
- Lesson 3 - Roadmap & Ecosystem
  - ensure availability of IDE, RTOS / OS ports, physical design etc. and create a roadmap of cores covering a range of PPA metrics

# OpenHW Verification Task Group



- Chair: Simon Davidmann, Imperas
- Vice-Chair: Jean-Roch Coulon, Thales Silicon Security

**imperas**

**THALES**

- Develop best in class verification test bench environments for the cores and IP blocks developed within the OpenHW Group.

# Industry Standard Tools



- Use industry standard languages and verification methods



- Open-Source projects need to fit easily into ecosystem companies' existing EDA tool flow. Leverage the best commercial tools for the job



# Next Gen: universal UVM environment for CORE-V Verif



# Open Source HW Adoption Lessons



- Lesson 1 - Permissive use
  - permissive open-source licensing and processes to minimize business and legal risks
- Lesson 2 - IP quality
  - harness community best-in-class design and verification methods and contributions
- Lesson 3 - Roadmap & Ecosystem
  - ensure availability of IDE, RTOS / OS ports, physical design etc. and create a roadmap of cores covering a range of PPA metrics

# SW Task Group



- Chair: Jeremy Bennett, Embecosm
- Vice-Chair: Yunhai Shang, Alibaba T-Head
- Define, develop and support SW tool chain, operating system ports and firmware for the cores and IP developed within the OpenHW Group
- SW TG active projects include: GCC / LLVM, IDEs, FreeRTOS, HAL, CORE-V MCU SDK, etc.





# CORE-V® IDE

- CORE-V IDE is an open-source development under the SW TG at the OpenHW Group
- Eclipse based IDE for CORE-V development
- Includes the GCC Toolchain for CORE-V
- OpenOCD Debug Support
- “Ready-to-run” examples for Digilent FPGA boards
- Getting started guides

ASHLING

EMBECOSM®

OPENHW®

The screenshot displays the Eclipse-based CORE-V IDE interface. It includes several perspectives:

- Debug:** Shows the Project Explorer with two projects: "sum\_arm [Ashling Opella-XD ARM Debugging]" and "sum\_riscv [Ashling Opella-XD RISC-V Debugging]". The "sum\_riscv" project has a suspended thread at startup.5:39 0x212.
- Disassembly:** Shows assembly code for "startup.s" and "calculate\_sum". The assembly code for "calculate\_sum" is as follows:

```

    .global _start
    .type _start, @function
_start:
    .clear minstret
    #csrw minstret, zero
    .clear registers
    s=0;
    s = val1+val2;
    return s;
int main()
{
    unsigned long count=0;
    int sum;
    for(int i=1;i++)
    {
        sum = calculate_sum(*int*value,i);
        if(sum == 0)
        {
            count++;
        }
    }
    return 0;
}

```

- Registers:** Shows register values for x0 through x19.
- Memory Browser:** Shows memory dump at address 0x14800120.
- Console:** Shows the output of the assembly code.
- Launch Configurations:** Shows favorite launch configurations: "Ashling Opella-XD ARM Debugging", "Ashling Opella-XD RISC-V Debugging", and "Launch Group".
- Breakpoints:** Shows a breakpoint at line 11 of "sum.c".

ECLIPSE  
FOUNDATION

# HW Task Group



- Chair: Hugh Pollitt-Smith, CMC Microsystems
- Vice-Chair: Tim Saxe, QuickLogic
- define, develop and support SoC and FPGA based evaluation / development platforms for the cores and IP developed within the OpenHW Group.





# CORE-V® FPGA Emulation



- CORE-V projects leverage Digilent NexysA7 & Genesys2 FPGA boards for soft-core bring up for both CVE4 and CVA6 Families



ASHLING

Opella LD  
Debug Probe



# CORE-V® MCU in fab now



- Real Time Operating System (e.g. FreeRTOS) capable ~300+MHz CV32E4 MCU
- Embedded FPGA fabric with hardware accelerators from QuickLogic
- Multiple low power peripheral interfaces (SPI, GPIO, I2C, HyperRAM, CAMIF, etc) for interfacing with sensors, displays, and connectivity modules
- Built in 22FDX with



# CORE-V® MCU DevKit



[OpenHW CORE-V DevKits](#)

- CORE-V MCU SoC
  - CV32E40P processor core
  - Quicklogic ArticPro eFPGA
  - Global Foundries 22FDX
- Ashling Opella-LD onboard JTAG debug module
- USB-C for terminal and onboard debug access
- JTAG connector for external debug access
- Espressif AWS IoT ExpressLink Module for AWS IoT cloud interconnect
- mikroBUS onboard socket, allowing access to a vast range of mikroBUS modules
- 40 pin expansion header
- I2C temperature sensor
- Early Access CORE-V MCU DevKits can be reserved on the [GroupGets campaign page](#) (quantities are limited)

# CVA6 - dual core SMP Linux on Genesys2



OpenPiton



CVA6-SDK



```
masgia@masgia-Inspiron-5579: ~
File Edit View Search Terminal Help
[ 12.300457] lib0c2c000 uart: ttys0 at MMIO 0x1f0c2c000 (irq = 1, base_baud = 4100000) is a 16550
[ 12.580437] fff0c2c000.uart: ttys0 at MMIO 0x1f0c2c000 (irq = 1, base_baud = 4166687) is a 16550
[ 13.413954] printk: console [ttys0] enabled
[ 13.413954] printk: console [ttys0] enabled
[ 13.432853] piton_sd:v1.0 Apr 26, 2019
[ 13.432853] piton_sd:v1.0 Apr 26, 2019
[ 13.432853] piton_sd:v1.0 Apr 26, 2019
[ 13.432853] piton_sd: piton_sd1 piton_sd2
[ 18.280307] piton_sd: piton_sd1 piton_sd2
[ 18.313435] libphy: Fixed MDIO Bus: probed
[ 18.313435] libphy: Fixed MDIO Bus: probed
[ 18.329267] xilinx_emaclite fff0d00000.ethernet: Device Tree Probing
[ 18.329267] xilinx_emaclite fff0d00000.ethernet: Device Tree Probing
[ 18.345813] libphy: Xilinx EmacLite MDIO: probed
[ 18.345813] libphy: Xilinx EmacLite MDIO: probed
[ 18.365367] xilinx_emaclite fff0d00000.ethernet: MAC address is now 00:18:3e:02:e3:e5
[ 18.365367] xilinx_emaclite fff0d00000.ethernet: MAC address is now 00:18:3e:02:e3:e5
[ 18.391571] xilinx_emaclite fff0d00000.ethernet: Xilinx EmacLite at 0x(__ptrval__) mapped to 0x(__ptrval__)
[ 18.391571] xilinx_emaclite fff0d00000.ethernet: Xilinx EmacLite at 0x(__ptrval__) mapped to 0x(__ptrval__)
[ 18.415544] ehci_hcd: USB 2.0 'Enhanced' Host Controller (EHCI) Driver
[ 18.415544] ehci_hcd: USB 2.0 'Enhanced' Host Controller (EHCI) Driver
[ 18.437508] usbcore: registered new interface driver ushid
[ 18.437508] usbcore: registered new interface driver ushid
[ 18.448971] ushid: USB HID core driver
[ 18.448971] ushid: USB HID core driver
[ 18.478182] NET: Registered protocol family 10
[ 18.478182] NET: Registered protocol family 10
[ 18.510941] Segment Routing with IPv6
[ 18.510941] Segment Routing with IPv6
[ 18.520527] sit: IPv6, IPv4 and MPLS over IPv4 tunneling driver
[ 18.520527] sit: IPv6, IPv4 and MPLS over IPv4 tunneling driver
[ 18.546628] NET: Registered protocol family 17
[ 18.546628] NET: Registered protocol family 17
[ 18.561907] Key type dns_resolver registered
[ 18.561907] Key type dns_resolver registered
[ 18.851667] Freeing unused kernel memory: 6724K
[ 18.851667] Freeing unused kernel memory: 6724K
[ 18.860994] This architecture does not have kernel memory protection.
[ 18.860994] This architecture does not have kernel memory protection.
[ 18.874036] Run /init as init process
[ 18.874036] Run /init as init process
Starting logging: OK
Initializing random number generator... [ 21.273658] random: dd: uninitialized urandom read (512 bytes read)
[ 21.273658] random: dd: uninitialized urandom read (512 bytes read)
done.
Starting rpcbind: OK
[ 22.539276] random: ssh-keygen: uninitialized urandom read (32 bytes read)
[ 22.539276] random: ssh-keygen: uninitialized urandom read (32 bytes read)
Starting sshd: [ 22.799293] random: sshd: uninitialized urandom read (32 bytes read)
[ 22.799293] random: sshd: uninitialized urandom read (32 bytes read)
OK
NFS preparation skipped, OK

Welcome to Buildroot
buildroot login: root
#
CTRL-A Z for help | 115200 8N1 | NOR | Minicom 2.7.1 | VT102 | Offline | ttyUSB0
```

# Open HW ~3 Years Later Lessons Learned



- Lesson 1 - Permissive use
  - permissive open-source licensing and processes to minimize business and legal risks
- Lesson 2 - IP quality
  - harness community best-in-class design and verification methods and contributions
- Lesson 3 - Roadmap & Ecosystem
  - ensure availability of IDE, RTOS / OS ports, physical design etc. and create a roadmap of cores covering a range of PPA metrics



GROUP  
**OPENHW**<sup>®</sup>  
PROVEN PROCESSOR IP

and  **CORE-V**<sup>®</sup>



- OpenHW Group & CORE-V Family of open-source RISC-V cores for use in high-volume production SoCs
  - Visit [www.openhwgroup.org](http://www.openhwgroup.org) for community information
  - Visit OpenHW GitHub <https://github.com/openhwgroup> for projects
  - Learn more at [OpenHW TV](#)
- Follow us on Twitter [@openhwgroup](#) & [LinkedIn OpenHW Group](#)