

Palmer Dabbelt

#### **RISC-V Software State of the Union**

June 12th, 2019: RISC-V Workshop, Zurich





# **RISC-V Origins at Berkeley**





- Krste's group needed an ISA
- Originally for education
  - Teaching undergraduate courses
  - Research into custom processors
- ISA designed over four years
  - Feedback from building chips and software
- Long design cycle lead to a solid base ISA





# **Spinning Off from Berkeley**

- Eventually we ended up with users
  - Surprised people were asking us to explain why the ISA was changing
- Led to forming two entities
  - RISC-V foundation, to shepard the ISA specification
  - SiFive, to build RISC-V chips
- HiFive1 release late 2016
  - Announced at a RISC-V workshop
- Driver for embedded software
  - OpenOCD, GCC, Zephyr









# **Building the RISC-V Software Ecosystem**

- People only pay attention when you have an ASIC
- HiFive Unleashed to bootstrap the RISC-V Linux software ecosystem









# 11 Software Talks at this Workshop



## Software Implementations of RISC-V

- QEMU support RISC-V hosts and targets
  - o Emulate RISC-V on an x86 host
  - Emulate x86 on a RISC-V host





## Software Implementations of RISC-V

- QEMU support RISC-V hosts and targets
  - Emulate RISC-V on an x86 host
  - Emulate x86 on a RISC-V host





#### **C** Compilers









# bluespec



#### **GNU-based toolchain is stable**

- Embedded since August, 2017
- Linux since February, 2018

#### **LLVM** is still experimental

Code generation for RV32 and RV64



#### **C** Compilers







id RV64



# bluespec

GNU-based toolchain is stable

Embedded since August, 2017

"Open Source Compiler Tool Chains and Operating Systems for RISC-V"
Wednesday at 9:50 am
Jeremy Bennett, Embecosm



#### **Debug and Trace**





#### **Debug and Trace**





#### **Debug and Trace**

SEGGER J-Link Probe



HiFive1 revB

(J-Link OB)



# **Commercial RISC-V Software Ecosystem**

October 24, 2017

# Lauterbach and SiFive Bring TRACE32 Support for High-Performance RISC-V Cores



# **Commercial RISC-V Software Ecosystem**

October 24, 2017

# Lauterbach and Bring TRACE32: High-Performan Cores



#### IAR EMBEDDED WORKBENCH FOR RISC-V NOW RELEASED

IAR Embedded Workbench offers excellent code optimizations for size and speed. As a well established frontrunner in the embedded industry you can rely on our tools to compile, analyze and debug your code beautifully.



# **Commercial RISC-V Software Ecosystem**

October 24, 2017

# Lauterbach and Bring TRACE32

#### RISC-V Support

The SEGGER Software Platform, including development tools, debug probes and middleware, provides a comprehensive one-stop solution for complete product development with microcontrollers based on the open RISC-V architecture. It simply works!

- Development Tools
- Debug Probes
- RTOS & Middleware



# MBEDDED WORKBENCH ISC-V NOW RELEASED

Workbench offers excellent code optimizations for size and Il established frontrunner in the embedded industry you can s to compile, analyze and debug your code beautifully.





# **Generating High Quality Code**

"The SiFive 7 series cores have macro fusion support to convert a branch over a single instruction into a conditionally executed instruction.

This gives us about a 10% increase in CoreMark scores for this core."

- **Dhrystone and CoreMark still dominate** 
  - Dhrystone hasn't changed since the 80's
  - Both are synthetic benchmarks
- RISC-V has opened up innovation in embedded systems
- We need a new benchmark for the modern IOT



# **Generating High Quality Code**

"The SiFive 7 series cores have macro fusion support to convert a branch over a single instruction into a conditionally executed instruction.

This gives us about a 10% increase in CoreMark scores for this core."

- Dhrystone and CoreMark still dominate
  - Dhrystone hasn't changed since the 80's



- RISC
- We

#### "Embench"

Wednesday at 9:25 am

**Dave Patterson** 



### Languages Newer than C

- Go port can run Docker
  - Examples run on the HiFive Unleashed
- J extension working group
- Rust on RISC-V





#### carlosedp/echo\_on\_riscv

By carlosedp • Updated 4 days ago

Container



#### Languages Newer than C

- Go port can run Docker
  - Examples run on the HiFive
     Unleashed
- J extension working group
- Rust on RISC-V





#### carlosedp/echo\_on\_riscv

By carlosedp • Updated 4 days ago

Container

"Building Secure Systems using RISC-V and Rust"

Wednesday at 2:05 pm

Arun Thomas, Draper Labs













**Interrupt Controller** 



**Processor Core** 

Cache Management

**DDR** Initialization

**Early Boot Flow** 

EDCA

Power, Clock, and Reset







DDR Initialization

**Early Boot Flow** 

EDCA

Power, Clock, and Reset

Platform Specification



# **Operating Systems**

- Freedom Metal, SiFive's bare-metal embedded environment
  - Bare-metal BSPs generated along with the hardware
  - Support for core RISC-V functionality, as well as SiFive blocks
- **Zephyr, a Linux Foundation RTOS**
- OpenEmbedded, Debian, and Fedora





# **Operating Systems**

- Freedom Metal, SiFive's bare-metal embedded environment
  - Bare-metal BSPs generated along with the hardware
  - Support for core RISC-V functionality, as well as SiFive blocks
- **Zephyr, a Linux Foundation RTOS**
- OpenEmbedded, Debian, and Fedora





#### **FreeRTOS**





#### **FreeRTOS**





#### **Trusted Execution Environment**

- Modern systems all require security
  - Secure boot
  - Trusted firmware
- RISC-V defines PMPs
- TEE working group





#### **Trusted Execution Environment**

- Modern systems all require security
  - Secure boot
  - Trusted firmware
- RISC-V defines PMPs
- TEE working group

Partition 1 Partition 2

PMP PMP

Bus

"An open-source API proposal for a multi-domain RISC-V Trusted Execution Environment"

Wednesday at 3:20 pm

Cesare Garlati, Hex Five Security



# **Bootloaders for UNIX-Class Systems**

- Berkeley Boot Loader (BBL)
  - Designed to boot university test chips
- OpenSBI
  - Clean implementation of SBI and early boot
- u-boot
  - Standard bootloader for embedded Linux systems
- Coreboot
  - First bootloader to add RISC-V support





## **Bootloaders for UNIX-Class Systems**

- Berkeley Boot Loader (BBL)
  - Designed to boot university test chips
- OpenSBI
  - Clean implementation of SBI and early boot
- u-boot
  - Standard bootloader for embedded Linux systems
- Coreboot
  - First bootloader to add RISC-V support

"OpenSBI Deep Dive"
Tuesday at 1:30 pm
Anup Patel, Western Digital



#### **Linux Kernel**

- Core RISC-V architecture support merged in early 2018
  - Runs on QEMU and HiFive Unleashed
- Most HiFive Unleashed drivers are posted for the next MW
- Upstream device tree bindings also posted for the next MW
  - Ready to begin integrating SOCs and boards
- BPF JIT was recently merged
- NOMMU port posted to the mailing list yesterday

77 unique contributors to arch/riscv/



#### **Linux Kernel**

- Core RISC-V architecture support merged in early 2018
  - Runs on QEMU and HiFive Unleashed
- Most HiFive Unleashed drivers are posted for the next MW
- Upstream device tree bindings also posted for the next MW
  - Ready to begin integrating SOCs and boards
- BPF JIT was recently merged
- NOMMU port posted to the mailing list yesterday

77

"Open Source Compiler Tool Chains and Operating Systems for RISC-V"
Wednesday at 9:50 am
Mark Corbin, Embecosm

cv/



## **Linux Userspace**



Open Source SDK For Proprietary Accelerators

- 64-bit glibc upstream since early 2018
- OpenEmbedded, Debian, and Fedora

RISC-V Community



#### **Linux Userspace**



- 64-bit glibc upstream since early 2018
- OpenEmbedded, Debian, and Fedora



"Enable RISC-V capability in cloud computing"
Wednesday at 11:50 am
Zhipeng Huang, Huawei



# **Getting Started**

- http://sifive.com/blog
  - "Last Week in RISC-V"
- sw-dev@groups.riscv.org
- #riscy on freenode
- Per-project mailing lists
  - Most are upstream
  - linux-riscv@lists.infradead.org
  - linux-qemu@nongnu.org
  - binutils, GCC, glibc, GDB at FSF



