

#### Open-Source RISC-V Cores for use in high volume production SoCs

Rick O'Connor <u>rickoco@openhwgroup.org</u> T <u>@rickoco</u> T <u>@openhwgroup</u> <u>www.openhwgroup.org</u>



© OpenHW Group

31st March 2021

OPENHW





- <u>DpenHW Group</u> is a not-for-profit, global organization driven by its members and individual contributors where HW and SW designers collaborate in the development of open-source cores, related IP, tools and SW such as the CORE-V Family of open-source RISC-V cores
  - 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







#### Research Ecosystem 64+ Members & Partners







© OpenHW Group



Partner Ecosystem 64+ Members & Partners





# Accounting, Legal, Banking Deloitte. Norton Rose FULBRIGHT



# OpenHW Group Board of Directors

- Xiaoning Qi, Alibaba Group
- John Davis, Barcelona Supercomputing Center
- Charlie Hauck, Bluespec (Treasurer)
- Fabien Clermidy, CEA
- Liang Peng, Futurewei Technologies
- Tim Whitfield, Imagination Technologies
- Rob Oshana, NXP (Chairman)
- Alessandro Piovaccari, Silicon Labs
- Wayne Dai, VeriSilicon
- Rick O'Connor, OpenHW Group





Alibaba Group

Technoloaies



# Working Groups & Task Groups



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



#### Technical Working Group (TWG)

- Co-Chairs
  - Sebastian Ahmed, Silicon Laboratories
  - Jerry Zeng, NXP Semiconductors



- Drive the overall technical direction, development roadmap and project execution for all technology related activities within the OpenHW Group and oversee the Task Groups
  - TWG is essentially the OpenHW Group company's "R&D / Engineering Organization"
- OpenHW Group engineering release methodology is based on the Eclipse Development Process
  - All OpenHW Group Platinum / Gold / Silver members are also Solutions members of the Eclipse Foundation





# Cores Task Group

- Chair: Arjan Bink, Silicon Laboratories
- Vice-Chair: Jérôme Quévremont, Thales Research & Technology **THALES**
- 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

| Core             | Bits/Stages             | 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 hardware PTW and branch-prediction (branch target buffer, branch history table and a return address stack). |
| <u> </u>         | GROUP                   |                                                                                                                                                                                                                                                                                                                                                           |





# Verification Task Group



#### • Co-Chairs:

- Robert Chu, Futurewei Technologies, Inc.
- Steve Richmond, Silicon Laboratories



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



#### CORE-V Verification UVM Test Bench





make SIMULATOR=<sim> +UVM\_TEST=riscv-dv-test



© OpenHW Group

#### CV32E4 'RTL Freeze' Coverage Data



- CV32E4 Coverage Data published in our <u>core-v-</u> <u>verif github repo</u>
- Coverage told us we had...
  - Bugs in the functional coverage model
  - Low coverage in Instructions Exceptions testing
  - Low coverage of Int & Dbg corner-cases
  - Low coverage of Instruction and Data bus interface protocol

| cādence 🏹              | Metrics Report - Gener     |                         |                   |                         |                       |                               |
|------------------------|----------------------------|-------------------------|-------------------|-------------------------|-----------------------|-------------------------------|
| iter                   | × +                        | -                       |                   |                         |                       | Block Expression              |
| Name                   | Block                      | Expression              | FSM<br>Covered    | CoverGroup              | Assertion             |                               |
| ⊿ cov_model            | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 4758 / 4884<br>(97.42%) | 0 / 0 (n/a)           | Filter by name: Filter        |
| debug_covg             | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 119 / 140<br>(85%)      | 0 / 0 (n/a)           | Name                          |
| interrupt_covg         | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 306 / 336<br>(91.07%)   | 0 / 0 (n/a)           | Name                          |
| isa_covg               | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 4333 / 4408<br>(98.3%)  | 0 / 0 (n/a)           | cg_debug_mode_ext             |
| ⊿ core_i               | 1242 /<br>1255<br>(98.96%) | 1878 / 1930<br>(97.31%) | 63 / 63<br>(100%) | 0 / 0 (n/a)             | 264 / 265<br>(99.62%) | cg_ebreak_execute_v           |
| ⊳ sleep_unit_i         | 5 / 5<br>(100%)            | 22 / 24<br>(91.67%)     | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 11 / 11<br>(100%)     | og obrook oxegute with        |
| ⊿ if_stage_i           | 159 / 159<br>(100%)        | 181 / 182<br>(99.45%)   | 14 / 14<br>(100%) | 0 / 0 (n/a)             | 18 / 18<br>(100%)     | cg_ebleak_execute_with        |
| ⊳<br>prefetch_buffer_i | 37 / 37<br>(100%)          | 82 / 83<br>(98.8%)      | 4 / 4<br>(100%)   | 0 / 0 (n/a)             | 15 / 15<br>(100%)     | ca cobroak avacuta wit        |
| aligner_i              | 20 / 20<br>(100%)          | 38 / 38<br>(100%)       | 10 / 10<br>(100%) | 0 / 0 (n/a)             | 1 / 1<br>(100%)       |                               |
| compressed_decoder_i   | 74 / 74<br>(100%)          | 39 / 39<br>(100%)       | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 0 / 0 (n/a)           |                               |
| genblk1                | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 1 / 1<br>(100%)       | Overall<br>Average<br>Covered |
| genblk2                | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 1 / 1<br>(100%)       | Grade 6 / 16 stat             |
| b id_stage_i           | 680 / 692<br>(98.27%)      | 651 / 664<br>(98.04%)   | 33 / 33<br>(100%) | 0 / 0 (n/a)             | 17 / 18<br>(94.44%)   | 37.5% (37.5%) cnb             |
| ⊳ ex_stage_i           | 96 / 96<br>(100%)          | 679 / 682<br>(99.56%)   | 16 / 16<br>(100%) | 0 / 0 (n/a)             | 4 / 4<br>(100%)       |                               |
| load_store_unit_i      | 101 / 101<br>(100%)        | 102 / 103<br>(99.03%)   | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 5 / 5<br>(100%)       |                               |
| cs_registers_i         | 142 / 143<br>(99.3%)       | 160 / 191<br>(83.77%)   | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 1 / 1<br>(100%)       |                               |
| genblk1                | 38 / 38<br>(100%)          | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 0 / 0 (n/a)           |                               |
| genblk2                | 41 / 42<br>(97.62%)        | 6 / 9<br>(66.67%)       | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 0 / 0 (n/a)           |                               |
| genblk3                | 0 / 0 (n/a)                | 0 / 0 (n/a)             | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 0 / 0 (n/a)           |                               |
| gen_trigger_regs       | 6 / 6<br>(100%)            | 19 / 19<br>(100%)       | 0 / 0 (n/a)       | 0 / 0 (n/a)             | 0 / 0 (n/a)           |                               |

| trics Re  | port - G   | enerated on 2020    | 0/10/23 (                   | 07:16          | 5:13                                          |                                                           |                             |                    |         |             | Show D                                    |  |
|-----------|------------|---------------------|-----------------------------|----------------|-----------------------------------------------|-----------------------------------------------------------|-----------------------------|--------------------|---------|-------------|-------------------------------------------|--|
| ilock     | Expression | n FSM Co            | ver Group                   | s              | Ass                                           | ertions                                                   |                             |                    |         |             |                                           |  |
| Filter by | name: Filt | er                  | ×                           |                |                                               |                                                           |                             |                    |         |             |                                           |  |
| Name      |            |                     | Overall<br>Average<br>Grade | Over<br>Cove   | rall<br>ered                                  | Enclosing Entity                                          |                             |                    |         | Source      | Code                                      |  |
| cg_de     | bug_mode   | _ext                | 37.5%                       | 6 / 16         |                                               | uvm_pkg.uvm_test_top.e                                    | env.cov_mo                  | odel.debug         | _covg o | covergro    | oup cg_debug_mode_e                       |  |
| cg_eb     | reak_exec  | ute_with_ebreakm    | 60%                         | 3/5<br>(60%    | )                                             | uvm_pkg.uvm_test_top.e                                    | env.cov_mo                  | odel.debug         | _covg   | overgro     | up<br>ak execute with ebr                 |  |
| cg_ce     | break_exe  | cute_with_ebreakm   | 100%                        | 5/5            | %)                                            | uvm_pkg.uvm_test_top.e                                    | env.cov_mo                  | odel.debug         | _covg   | covergro    | up<br>vak execute with et                 |  |
| cg_ebrea  | ak_execute | _without_ebreakm    | 100%                        | 3 / 3<br>(100% | %)                                            | uvm_pkg.uvm_test_top.env.cov_model.debug_covg<br>cg_ebrea |                             |                    |         |             | roup<br>eak_execute_without_et            |  |
| ca cobro  | ak oxocut  | o without obrookm   | 100%                        | 3/3            | uvm_pkg.uvm_test_top.env.cov_model.debug_covg |                                                           |                             |                    |         |             |                                           |  |
| Overall   | Overall    | Source Code         |                             |                | nam<br>Nai                                    | ne: Filter                                                | Vverall<br>Average<br>Grade | Overall<br>Covered | Score   | At<br>Least | Source Code                               |  |
| Grade     | Covered    |                     |                             |                |                                               | auto[RESET]                                               | 0%                          | 0 / 1 (0%)         | 0       | 1           | state: coverpoint                         |  |
| 37.5%     | (37.5%)    | cntxt.debug_cntxt.v | if_cov.mor                  | n_cb.c         |                                               | auto[BOOT_SET]                                            | 0%                          | 0 / 1 (0%)         | 0       | 1           | state: coverpoint                         |  |
|           |            |                     |                             |                |                                               | auto[SLEEP]                                               | 100%                        | 1 / 1<br>(100%)    | 6249    | 1           | state: coverpoint                         |  |
|           |            |                     |                             |                |                                               | auto[WAIT_SLEEP]                                          | 100%                        | 1 / 1<br>(100%)    | 15      | 1           | state: coverpoint<br>cntxt.debug cntxt.vi |  |
|           |            |                     |                             |                |                                               | auto[FIRST_FETCH]                                         | 0%                          | 0 / 1 (0%)         | 0       | 1           | state: coverpoint<br>cntxt.debug_cntxt.vi |  |
|           |            |                     |                             |                |                                               | auto[DECODE]                                              | 100%                        | 1 / 1<br>(100%)    | 4521    | 1           | state: coverpoint<br>cntxt.debug_cntxt.vi |  |
|           |            |                     |                             |                | a                                             | uto[IRQ_FLUSH_ELW]                                        | 0%                          | 0 / 1 (0%)         | 0       | 1           | state: coverpoint<br>cntxt.debug_cntxt.vi |  |
|           |            |                     |                             |                |                                               | auto[ELW_EXE]                                             | 0%                          | 0 / 1 (0%)         | 0       | 1           | state: coverpoint<br>cntxt.debug_cntxt.vi |  |
|           |            |                     |                             |                |                                               | auto[FLUSH_EX]                                            | 100%                        | 1 / 1<br>(100%)    | 48      | 1           | state: coverpoint<br>cntxt.debug_cntxt.vi |  |
|           |            |                     |                             |                |                                               |                                                           | 1000                        | 1/1                | ~~      |             | state: coverpoint                         |  |



### 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.





# 



- 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

| 3 - 🗉 🕼 🖻 🗖                                        | r 🔌   🕩 III 🔳 M 🌫 🤉             | ) 🔊 📑 🤜 🔊 🕹 🟠               | 📴 🐌 🗓 🖫 🖫 🖪 🥔 🥐 📕 🎘 🍅 🔅 🕶 🔗 •                                              | - 월 - 월 - ♡ ← - ○ -   🖬     |                       |                                          |                       | Q                    | 🖻   🖣  |
|----------------------------------------------------|---------------------------------|-----------------------------|----------------------------------------------------------------------------|-----------------------------|-----------------------|------------------------------------------|-----------------------|----------------------|--------|
| 🛊 Debug 😒 🍋 Proje                                  | ect Explorer 🛛 📄 🧏 🐌            | (i) ⇒ i → 8 □ □             |                                                                            |                             | Dis                   | assembly 🛛 🗖 🗖                           | 🔠 Registers 😒 🐇       |                      | - 0    |
| v 💽 sum_arm [Ashling                               | g Opella-XD ARM Debugging]      |                             | Te sum.c 🛛                                                                 | S startup.S 🛛               | E                     | nter location here 🗸 🔊 🧄 🕵 🔯             | Name                  | Value                |        |
| ✓ 🔐 sum.elf                                        |                                 |                             | 1 #include <stdio.h></stdio.h>                                             | 21 #.global _start          | ^ <u> </u>            |                                          | v M General Registerr |                      |        |
| ✓                                                  | main> (Suspended : Signal : SIG | TRAP:Trace/breakpoint trap) | 3                                                                          | 22 #.type _start, @function | C2 t                  | 2                                        | 1919 x0               | 0x0                  |        |
| calculate                                          | e_sum() at sum.c:8 0x14800120   |                             | 4                                                                          | 24 start:                   | 8                     |                                          | 1819 ×1               | 0x4844e              |        |
| main() at                                          | t sum.c:22 0x14800178           |                             | 5 volatile unsigned long long *value = 0x148000                            | 25 #clear minstret          |                       | calculate sum:                           | 1010 x2               | 0x148b4f98           |        |
| ash-arm-gdb-s                                      | server.exe                      |                             |                                                                            | 26 #csrw minstret, zero     | Ø000000014800120:     | 0000014800120: sub sp, sp, #             | 1010 x3               | 0x148b4f88           |        |
| iaarch64-elf-gd 🗸                                  | ib.exe                          |                             | 8 4                                                                        | 27 #csrw minstreth, zero    | 0000                  | 0000014800124: str w0, [sp, i            | 1010 x4               | 0x0                  |        |
| sum_riscv (Ashling)                                | g Opella-XD RISC-V Debugging]   |                             | 9 int s=0;                                                                 | 29 #clear registers         | 0000                  | 3000014800128: str w1, [sp, :            | 1010 x5<br>1011 x6    | 0x0                  |        |
| ✓ if swerv_sum.elf                                 |                                 |                             | 10 s = val1+val2;                                                          | 30 li x1, 0                 | 0000                  | 000001480012c: str wzr. [sp.             |                       | 0x0                  |        |
| ✓                                                  | TAP 1 (Qualcomm-Kryo585 Hart    | 0)] 1 (Suspended : Step)    | 211 return s;                                                              | 31 li x2, 0                 | 10                    | <pre>s = val1+val2;</pre>                | 1010 x7               | 0x0                  |        |
| <pre></pre>                                        | it startup.S:39 0x212           |                             | 130 int main()                                                             | 32 li x3, 0                 | 0000                  | 0000014800130: ldr w1, [sp,              | 1010 x8               | 0x17c21000           |        |
| ash-riscv-gdb-                                     | -server.exe                     |                             | 14 {                                                                       | 34 li x5. 0                 | 0000                  | 0000014800134: ldr w0, [sp, ;            | 1010 x9               | Oxaecf143            |        |
| riscv64-unknov                                     | wn-elf-gdb.exe                  |                             | 15                                                                         | 35 li x6, 0                 | 0000                  | 000001480013c: str w0, [sp.;             | 1010 x10              | 0x780                |        |
|                                                    |                                 |                             | 16 unsigned long count=0;                                                  | 36 li x7, 0                 | <b>P</b> 11           | return s;                                | 1010<br>0101 x11      | 0xaecf66b            |        |
|                                                    |                                 |                             | 18                                                                         | 3/ li x8,0                  | - 0000                | 0000014800140: ldrsw x0, [sp, ;          | 1010 x12              | 0x51c                |        |
|                                                    |                                 |                             | 19 for(int i=1;;i++)                                                       | 39 li x10.0                 | 12                    | }                                        | 1010 x13              | 0x7270e000           |        |
|                                                    |                                 |                             | 20 {                                                                       | 40 li x11,0                 | 0000                  | 3000014800144: add sp, sp, #             | 1010 x14              | 0xf4240              |        |
|                                                    |                                 |                             | 21                                                                         | 41 li x12,0                 | 14                    | {                                        | 1010 x15              | 0x4                  |        |
|                                                    |                                 | >                           | <pre>22   sum = calculate_sum(*(int*)value,1);<br/>23   if(sum == 0)</pre> | 42 li x13,0                 |                       | main:                                    | 1010 x16              | 0x4                  |        |
|                                                    |                                 |                             | 24 {                                                                       | 45 11 X14,0                 | 0000                  | 000001480014c: stp x29, x30,             | otot x17              | 0x0                  |        |
| Variables 🔀                                        | 🏝 🎫 🖃 🥤 🕯                       | K 🐜 📑 📑 🕺 🗧 🗖 .             | 25 count++;                                                                | 45 li x16,0                 | 16                    | unsigned long c                          | 0101 x18              | 0x0                  |        |
| me                                                 | Time                            | Value                       | 26 }                                                                       | 46 li x17,0                 | 0000                  | 0000014800154: str xzr, [x29             | 5161 ×19              | 0x64                 |        |
| fede could                                         | int .                           | 0-0                         | 27 }<br>28 return 0:                                                       | 47 li x18,0                 | 19                    | for(int i=1;;i+                          | 0101 ×20              | 0x0                  |        |
| (4)* Val1                                          |                                 | 0:4944.4                    | 29                                                                         | 48 11 X19,0                 | 0000                  | 0000014800158: mov w0, #0x1              | 0101 ×21              | 0x807ad200           | ,      |
| (v) vaiz                                           | int                             | 0x40440                     | 30 }                                                                       | 50 li x21,0                 | 0000                  | 000001480015c: str w0, [x29,             | 0101 ×22              | 0xa60c704            |        |
| (4)* 3                                             | nic .                           | 000000                      | 31                                                                         | 51 li x22,0                 | 0000                  | 0000014800160: adrp x0, 0x148            | 0101 X23              | 0x00740e46           |        |
|                                                    |                                 |                             | 32                                                                         | 52 li x23,0                 | 0000                  | 0000014800164: add x0, x0, #             | 1010 x24              | 0x00740020           | )<br>1 |
|                                                    |                                 |                             |                                                                            | 53 11 X24,0                 | 0000                  | 0000014800168: ldr x0, [x0]              | 1010 + 26             | 0x00707000           | ,      |
|                                                    |                                 |                             |                                                                            | 55 li x26.0                 | 0000                  | 000001480016c: Idr w0, [x0]              | 1919 - 27             | 0x2                  |        |
|                                                    |                                 |                             |                                                                            | 56 li x27,0                 | 0000                  | 0000014800174: bl 0x14800120             | 1919 - 29             | 0x8073fc90           |        |
|                                                    |                                 | >                           |                                                                            | 57 li x28,0                 | 0000                  | 0000014800178: str w0, [x29,             | 1919 x29              | 0x14801190           |        |
|                                                    |                                 |                             |                                                                            | 58 11 x29,0                 | 23                    | if(sum == 0                              | 1919 ×30              | 0x14800178           |        |
|                                                    |                                 |                             |                                                                            | 60 li x31.0                 | 0000                  | 000001480017c: 1dr w0, [x29,             | 1010 SD               | 0x14801190           |        |
|                                                    |                                 |                             | < >>                                                                       |                             | >                     | <pre>sooool4800100: Cmp we, #0x0 *</pre> | 6 C                   | 0.14001150           | >      |
|                                                    |                                 | ×                           | Console X                                                                  |                             | Memory Browser        | 22                                       | 1                     | 1010 1010 179 108 8  | -      |
| Launch Configuration                               | ns 52                           | 8                           | Besteniste 12                                                              |                             | 0x14800120            |                                          |                       | V Go Ne              | w Tab  |
| e filter text                                      |                                 | 0 _                         | ✓ <i>s</i> sum.c [line: 11]                                                |                             | 0x14800120 < Traditio | nal> 🕅                                   |                       |                      |        |
| A Describer                                        |                                 |                             |                                                                            |                             | 0x14800120 D100       | 83FF B9000FE0 B9000BE1 B9001FFF B9400FE  | 1 B9400BE0 ÿÑà¹á      | ¹ÿ¹ <b>á.@¹</b> à.@¹ |        |
| Tavontes                                           |                                 |                             |                                                                            |                             | 0x14800138 0B00       | 0020 B9001FE0 B9801FE0 910083FF D65F03C  | 0 A9BE7BFDà¹à         | ¹ÿÀÖý{‰              |        |
| Achling Opella-XD RISC-V Debugging                 |                                 |                             |                                                                            |                             | 0x14800150 9100       | 03FD F9000FBF 52800020 B90017A0 9000000  | 09106A000 ýċù         | R <sup>1</sup>       |        |
| C Ashing Opena-AD KISC-V Debugging     Ashing Coup |                                 |                             |                                                                            |                             | 0x14800168 F940       | 0000 B9400000 B94017A1 97FFFFEB B90013A  | 0 894013A0 🛛@ù@¹;     | .@¹ëÿÿ¹ .@¹          |        |
|                                                    |                                 |                             |                                                                            |                             | 0x14800180 7100       | 001F 54000081 F9400FA0 91000400 F9000FA  | 0 B94017A0qT          | .@ùù .@1             |        |
|                                                    |                                 |                             |                                                                            |                             | 0x14800198 1100       | 0400 B90017A0 17FFFF0 00000000 1480000   | ₿ 00000000¹ð          | ÿÿ                   |        |
|                                                    |                                 |                             |                                                                            |                             | 0x148001B0 0000       | 000000 0000000 0000000 000000 000000     | a 00000000            |                      |        |
|                                                    |                                 |                             | No details to display for the current selection.                           |                             | 0x148001C8 0000       | 000000 0000000 0000000 000000 000000     | <b>9</b> 00000000     |                      |        |
|                                                    |                                 |                             |                                                                            |                             | 0x148001E0 0000       | 00000 000000 0000000 000000 000000       | <b>9</b> 999999999    |                      |        |
|                                                    |                                 |                             |                                                                            |                             |                       |                                          |                       |                      |        |



**ASHLING** 



EMBECOSM



### 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.







 Initial project using Digilent Genesys2 FPGA boards for softcore bring up for both CV32E4 and CV64A6







JTAG Probe



IDE





QuickLogic

#### © OpenHW Group

- Real Time Operating System (e.g. FreeRTOS) capable ~600+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





Mem

Bank Bank

Mem

Mem

Bank Bank

Mem

Mem

Mem

Bank Bank



Mem

Mem

Bank Bank

# OpenHW Accelerate



- Multi Year research initiative totaling up to \$22.5M USD of co-funded research
  - Up to \$4.5M USD research funding per year
  - Funding available globally across Canadian and International Universities (75% Canadian / 25% International)
  - Available to Silver and above OpenHW Group member organizations
- OpenHW Accelerate managed within OpenHW Marketing Working Group, University Outreach Task Group Co-Chaired by Mitacs and CMC
  - Establishes project approval process
  - Peer Review Committee drawing on Academic and Industry subject matter experts for project approvals



# OpenHW Accelerate 1<sup>st</sup> Project

- 1<sup>st</sup> OpenHW Accelerate Co-Funded Project *CORE-V CV-VEC: RISC-V Vector Processor for High-throughput Multidimensional Sensor Data Processing & Machine Learning Acceleration at the Edge* 
  - Gord Harling, CEO, CMC (Industry Sponsor)
  - Frank Gürkaynak, Director, Microelectronics Design Center, ETH Zürich
  - Matheus Cavalcante, PhD Candidate, ETH Zürich
  - Yvon Savaria, Professor, Electrical Engineering, Polytechnique Montréal
  - Hossein Askari Hemmat, PhD Candidate, Polytechnique Montréal











# What's Next? Some Predictions...



- 1. OpenHW Group ecosystem continues to grow
  - Over 80 Members & Partners expected by end of 2021
- 2. New open-source RISC-V cores added to the CORE-V Family
  - CV32E4 and CV64A6 now CV32E2, CV32A6, CV32E4 variants and more to come
- 3. On chip SoC interconnect (fabric & busses)
- 4. Heterogeneous clusters with accelerators and leveraging eFPGA







- OpenHW Group & CORE-V Family of open-source RISC-V cores
  - Visit <u>www.openhwgroup.org</u> for details
  - Learn more at <u>OpenHW TV</u>

• Follow us on Twitter <u>@openhwgroup</u> & <u>LinkedIn OpenHW Group</u>







| Time  | Speaker, Chair                                                                                                                                       | Title                                               |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| 08h30 | Rick O'Connor                                                                                                                                        | Keynote – Open Source History, Trends &<br>Adoption |
| 09h30 | Davide Schiavone, Jérôme Quévremont                                                                                                                  | CORE-V Cores Roadmap                                |
| 10h30 | Robert Balas, Jeremy Bennett, Simon Davidmann, Alexander Fedorov, Alfredo<br>Herrera, Ivan Kravets, Philipp Krones, Jessica Mills, Shteryana Shopova | OpenHW SW Task Group Projects                       |
| 12h00 |                                                                                                                                                      | Lunch                                               |
| 12h30 | Rick O'Connor. Luca Benini, Fabien Clermidy, Simon Davidmann, John D. Davis,<br>Mike Milinkovich, Matthias Völker, Tim Whitfield.                    | Panel – OpenHW Europe                               |
| 13h30 | Florian Zaruba                                                                                                                                       | CORE-V MCU & APU                                    |
| 14h30 |                                                                                                                                                      | Break                                               |
| 14h45 | Aimee Sutton, Lee Moore, Mike Thompson, Steve Richmond, Greg Tumbush                                                                                 | CORE-V Verif: Hands On                              |
| 16h15 | Rick O'Connor. Sebastian Ahmed, John Martin, Robert Oshana, Tim Saxe,<br>Jérôme Quévremont                                                           | Panel – OpenHW IP Adopters                          |
| 17h15 | Duncan Bees                                                                                                                                          | <b>OpenHW Project Execution</b>                     |
| 17h45 | Rick O'Connor                                                                                                                                        | OpenHW Day Wrap Up                                  |
| 18h00 |                                                                                                                                                      | End of OpenHW Day                                   |

