

# Teaching Chip Design with Open-Source Tools

Syed Anas Alam<sup>1</sup>, Jakob Furbo Enevoldsen<sup>1</sup>, Andreas Alkjær Eriksen<sup>1</sup>, Niels William Hartmann<sup>1</sup>, Ulrik Helk<sup>1</sup>, Jørgen Kragh Jakobsen<sup>2</sup>, Christa Skytte Jensen<sup>1</sup>, Nicolai Dyre Bülow Jespersen<sup>1</sup>, Karl Herman Krause<sup>1</sup>, Mads Rumle Nordstrøm<sup>1</sup>, Tjark Petersen<sup>1</sup>, Luca Pezzarossa<sup>1</sup>, Simon Winther Rasmussen<sup>1</sup>, <u>Martin Schoeberl<sup>1</sup></u>, Jonas Ingerslev Sørensen<sup>1</sup>

<sup>1</sup>Department of Applied Mathematics and Computer Science Technical University of Denmark Kgs. Lyngby, Denmark <sup>2</sup>IC Works - Open Source Chip Design



#### **Overview**

Focus: Using open-source chip design tools in academic education

**Content:** Report on a special course at the Technical University of Denmark

- Toolchain
- Hardware architecture
- Challenges and learning values



#### The team



- Introduction
- The open-source toolchain
- The hardware design
- Challenges and learning values



- Introduction
- The open-source toolchain
- The hardware design
- Challenges and learning values



- Current global chip shortage crisis started in 2020
  - COVID-19 pandemic
  - Weather incidents
  - Complex geopolitical situation
- Many industries strongly depend on semiconductor chips
- The European Chip Act is Europe's response to the crisis
  - Strengthen Europe's resilience and competitiveness
  - Encourage chip design and production within the countries of the union
- Universities should produce candidates acquainted the chip design processes

## The Open-Source Chip Design special course



- 13 weeks course 5 ECTS
- Learning objectives
  - Define precise specifications of a computing system
  - Develop (in Chisel) and test the hardware architecture
  - Use EDA tools and solve related challenges
- 12 students signed up for the course

DTU

 $\Xi$ 



#### **Enabling technologies**

**Open source 130nm Skywater PDK** 



- Full open source toolchain
- From RTL down to the GDS

Open source shuttle program

+ efabless: Google

- Free chip fabrication
- Design has to be open source



- Introduction
- The open-source toolchain
- The hardware design
- Challenges and learning values

### The Chisel hardware construction language



- Chisel is a domain specific language, embedded in Scala
- Allows RTL description
- Two steps in the compilation
- Generates Verilog
- Enables co-simulation of Scala testers, Chisel designs, and Java or C-based golden models

DTU





- Start form our Verilog design
- The SkyWater PDK is used
- Chain of different open-source tools
  - Yosys for synthesis
  - OpenRoad (end-to-end silicon compiler)
  - Others
- Produces GDS layout files
- Allows for Intermediate simulations

# Caravel project

- Pre-made harness including I/Os
- Small RISC-V CPU for managements
- Scripts for using the OpenLane toolchain
- 10mm<sup>2</sup> of user space
- Starting sample project



## The full process from RTL to chip













- Introduction
- The open-source toolchain
- The hardware design
- Challenges and learning values

- A research-oriented time-predictable RISC-style processor written in Chisel
- Part of the open-source T-CREST multicore project
- The LLVM compiler is available for compiling C







- Includes the Patmos CPU
- Multiple booting modes
  - Boot memory
  - Boot from other memories
  - Make sure we can boot in case of problems

#### • Peripherals

- SPI controller for off-chip DRAM
- On-chip SRAM
- UART and GPIOs



## Internal (on-chip) memories

- Memories need to be generated
- We use OpenRAM
  - Precompiled macros
  - Custom memories







## **External memories**

- 10mm<sup>2</sup> cannot fit large memories
- Off chip DRAM (or Flash)
- We developed a memory controller
- We tested on the real chips







DTU

Ħ



- Testing
- Simulation with test-benches
- Simulation running programs

| Waves                                   | 10  | sec |     |     |     | 28  | sec       |     |     |           | 30  | sec       | 40               | 5A7 | 50 sec |
|-----------------------------------------|-----|-----|-----|-----|-----|-----|-----------|-----|-----|-----------|-----|-----------|------------------|-----|--------|
| <b>ETTTTTT</b>                          | 10  | sec |     |     |     | 20  | see       |     |     |           | 1   | sec       |                  | 366 | 30 300 |
|                                         | Л   |     | Л   | Л.  |     | Л   | $\square$ | Л   | Л   | $\square$ | Л   | $\square$ |                  |     | ЛΠ     |
| xx+ 00000000000+                        | 66+ | CF+ | B0+ | FB+ | 16+ | A5+ | 87+       | FB+ | 47+ | 68+       | D1+ | 88+       | 7359B2163E4EDC58 |     |        |
| 000000000000000000000000000000000000000 |     |     |     |     |     |     |           |     |     |           |     |           | FFFFFFFFFFFFFFF  |     |        |
| 000000000000000000000000000000000000000 |     |     |     |     |     |     |           |     |     |           |     |           | FFFFFFFFFFFFFFFF |     |        |
| xx+ 0000000000+                         | 66+ | CE+ | B0+ | FB+ | 16+ | A5+ | 87+       | FB+ | 47+ | 68+       | D1+ | 88+       | 7359B2163E4EDC58 |     |        |
|                                         |     |     |     | Π   |     |     |           |     |     |           |     |           |                  |     |        |
|                                         |     |     |     |     |     |     |           |     |     |           |     |           |                  |     |        |

• Test on FPGA + logic analyzer

| IOSI |   |          | h03 | h00    | h00     | h00    | h00    | h00   | h00     | h00     | h00   | h00 | h00    | h00     | h00    | h00     | h00    | h00    | h00    | h00       | 1 |
|------|---|----------|-----|--------|---------|--------|--------|-------|---------|---------|-------|-----|--------|---------|--------|---------|--------|--------|--------|-----------|---|
|      | C |          |     |        |         |        |        |       |         |         |       |     |        |         |        |         |        |        |        |           |   |
|      | D | IN 23 🗙  |     | nnmnnm | nimnnmn | nmnnmi | תחתהחת | nnnnn | עתתעתתו | INNMINI | nnnnn |     | וחתחחת | הנהחחות | תהתחתה | maninaa | manman | הההההה | ותהחתת | ותותחתותו |   |
|      | D | 0IN 22 🗙 | ]   | 7      |         |        |        |       |         |         |       |     |        |         |        |         |        |        |        |           |   |
|      |   |          | h00 | h00    | h00     | h00    | h00    | h00   | h00     | hFF     | h00   | h00 | h00    | hFF     | h00    | h00     | h00    | hFF    | h00    | h00       | T |
|      |   |          |     |        |         |        |        |       |         |         | -     | •   |        |         | -      |         | •      |        | -      |           | - |

## Final user space layout





- Introduction
- The open-source toolchain
- The hardware design
- Challenges and learning values



- The open-source project moves quite fast and the documentation falls behind
  - Use of the Slack community was needed

High memory usage during synthesis and long synthesis times (8 to 10 hours)
 Use of multiple servers to have multiple runs in parallel

Multiple teams working on different parts of the project led to challenging integration

 Weekly coordination, fast integration and testing

## Learning values

- The possibility to have a chip manufactured free of charge is a strong motivating factor
  - Attend the course meetings
  - Actively participate in the project work
  - Overcome the challenges and frustrations
- Open-source tools mitigates the entry barrier of tools
  - No monetary or other licensing is required
  - Support of the community
- Team-work is needed
  - Complex tasks cannot be performed in isolation
  - Promotes strongly interact between students and teams



- The first open-source chip developed at DTU
- The chip is now taped-out on the MPW7 shuttle program
  - 40 chips + 5 evaluation boards including the chips
  - But there was a after deadline change in Caravel
- Additional work (BSc projects, special courses) for the verification of the produced chip
- The open-source toolchain is challenging, but also had very good learning values

- The project is hosted on GitHub (see link on the web site)
- The project also got press coverage (see link in the paper)