# Yosys-slang: Fast open-source SystemVerilog frontend for Yosys

DAC 2025: Open-Source EDA Birds-of-a-Feather Session 06/24/25

### Yosys: Logic synthesis tool

#### Very popular and fully open-source

- Synthesis tool for Verilog-2005
  - Little native support for SystemVerilog
- Has a powerful intermediate representation: RTLIL
  - Allows custom passes to manipulate RTLIL
    - For optimizations, analysis, etc.
- Developed by Claire Wolf (clairexen) circa 2013, now maintained by YosysHQ
- Available under ISC license; compatible with FPGA/ASIC flows



## Slang: C++ frontend for SystemVerilog

#### Fully-compliant and blazing fast

- Hand-written parser and resolver for SystemVerilog
  - No lexer/parser generators involved!
- Developed by Mike Popoloski (MikePopoloski)
- Fully compliant with latest IEEE 1800-2023
- Only open-source tool that can fully parse 3033/3033 sv-tests
- Written in C++, also has a Python frontend (pyslang)
- Available under MIT license since 2015



### Yosys-slang: SystemVerilog plugin for Yosys

#### The marriage between Yosys and Slang

- Key idea: Slang elaborates hierarchy, resolves constants, types, and name references; yosys-slang performs symbolic execution, emits word-level RTLIL
- Developed by Martin Povišer (povik), formerly YosysHQ, now at Precision Inno
  - Inspired by <u>svase</u> by <u>Paul Scheffler (paulsc96)</u> of <u>PULP group</u>
  - Conceived at Yosys User's Group in 2024; available under ISC license
- Supporters/contributors:









Contributors 10





















### Current status

#### Ready for use in ~99% of real-world designs!

- Passing most of synthesizable sv-tests
  - Few known exceptions for uncommon language features
- Able to correctly elaborate large designs
  - Black Parrot
  - BSC Core Tile
  - OpenHW Group's CV32E40P

- Ibex RISC-V Core
- OpenTitan
- RSD RISC-V Processor

#### sv-tests:



### Benchmarking (preliminary)

#### Yosys-slang is on par with (slightly faster than) Tabby CAD Suite

CPU: Apple M1 Pro

OS: macOS

Reduced runtimes

- Reduced memory usage
- With instance caching enabled
  - Without instance caching, a bit worse
- Synlig: not able to compile these

|                       | Yosys-<br>slang<br>Runtime | Tabby<br>CAD<br>Runtime | Yosys-<br>slang Peak<br>RAM | Tabby<br>CAD Peak<br>RAM |
|-----------------------|----------------------------|-------------------------|-----------------------------|--------------------------|
| OpenTitan<br>Earlgrey | 12.4 s                     | 16.3 s                  | 1.7 GB                      | 2.6 GB                   |
| CVA6                  | 3.1 s                      | 7.2 s                   | 0.5 GB                      | 1.5 GB                   |
| Black<br>Parrot       | 4.5 s                      | 4.5 s                   | 0.4 GB                      | 0.8 GB                   |

### Comparison with alternatives

#### Verific, Synlig, sv2v, bsg\_sv2v

- Use Verific frontend for Yosys (not open-source)
  - Fast and fully compliant with IEEE 1800-2023 SystemVerilog standard



- Available for no cost via <u>Tabby CAD Suite</u> for academic use, but not for professional use
- Use Synlig frontend for Yosys (open-source: Apache-2.0)
  - Uses Surelog to elaborate, UHDM as IR, dumps to Yosys AST



- Use sv2v to convert SystemVerilog to Verilog, then use Yosys as usual (open-source: BSD-3)
  - Almost fully compliant, but missing thorough validation
- Use <u>bsg\_sv2v</u> (open-source: <u>BSD-3</u>, but also requires Synopsys DesignCompiler...)

### Real-world adoption

#### Where is yosys-slang being used?

- PULP Tapeouts: MLEM, KOOPA
- YosysHQ's <u>OSS CAD Suite</u>
- Zero ASIC's SiliconCompiler
- JKU's <u>IIC-OSIC-TOOLS</u>
- OpenROAD Flow Scripts



SiliconCompiler screenshot (courtesy: Andreas Olofsson)







### Future Plans

#### What's next for yosys-slang?

- Add support for last few synthesizable language features
- Formal equivalence checks against other tools
- Simulated equivalence checks with <u>Interra Beacon</u>
- Testing on more and larger (>1M gate) designs
- Generalize to act as frontend for other tools



### Thank you!

Silimate is hiring: <a href="https://www.silimate.com">https://www.silimate.com</a>

- Building the co-pilot for chip designers
- We love, use, and support open-source EDA (OpenSTA, Yosys, etc.)
- Well-funded and backed by Y Combinator
- Used by companies like SiFive, Tenstorrent
  - And more companies we can't disclose yet...
- Come chat with me!
  - Also, my email is <u>akash@silimate.com</u>



### BACKUP: Current feature/issue status

#### Beta features, todo features, known bugs

- BETA: Non-uniquified hierarchy
- FEATURE: Support `celldefine
- FEATURE: Break down structs
- FEATURE: Support SR latches/FFs
- FEATURE: Support foreach loops
- FEATURE: Support .prev, .next
- FEATURE: Better loop unrolling

- FEATURE: Support inout without keep hierarchy
- FEATURE: Graceful handling of non-synthesizable constructs
- FEATURE: Support initial
- BUG: Write addressing with latches
- BUG: Unpacked unions
- BUG: Large case statement timeout