# Propelling SystemVerilog into the Future: A Leap Towards CIRCT Ecosystem Integration

Hailong Sun, Fabian Schuiki, Martin Erhart, Buyun Xu, Zuoye Shi and Anqi Yu

## Overview

CIRCT stands as an formidable MLIR initiative, centered on the domain of hardware design. It supports diverse input formats such as FIRRTL, SystemVerilog, and other MLIR variants, catering to the demand for a standardized intermediate representation within the ever-advancing sphere of hardware design. The newly introduced Moore dialect endeavors to accurately encapsulate the complete SystemVerilog types and semantics produced by the Slang front-end compiler. Moreover, it serves as a medium for transformation passes, facilitating the resolution of linguistic peculiarities, enabling high-level design analysis, and ultimately translating the design into the core dialects.



The numerical indicators on the graph represent the transition from the higher-level language compilation phase to the subsequent lower-level instructions. Certain details have been excluded from the present framework for brevity.

# Compilation Flow

## I. Generate AST from SystemVerilog Code by Slang

The slang compiler provides an incredible ability to do parsing and lexing, which generates stable syntax trees for subsequent lowerings.



# II. ImportVerilog pass in CIRCT

The primary objective of this pass is to maximize the processing of diverse tokens within the AST by adopting a greedy approach. This method makes it feasible to generate a Moore Intermediate Representation (IR).





#### III. Transformation and Optimization of the Moore Layer

The transformation and optimization passes implemented within the Moore layer play a critical role in disassembling high-level language features into their corresponding lower-level components.

Take an example for optimizing local variable and inline contents in the always\_comb procedure:



As depicted below, we have implemented interfaces that differentiate operations based on whether they entail side effects, in order to invoke the mem2reg pass for the elimination of superfluous local variables. Subsequent to this optimization, inlining can be effectively executed.



# IV & V. Convert to Core IR and utilize Arcilator to generate LLVM code.

The core IR within the CIRCT framework has been subdivided into discrete components. The HW dialect encapsulates the structural aspects of hardware design, while the Seq and Comb dialects specifically denote the sequential and combinational elements, respectively, as indicated by their respective nomenclature.



Leverage the new cycle-accurate hardware simulator, Arcilator, for the generation of LLVM Intermediate Representation (IR). Our team has successfully transitioned the hardware code into a software model. The subsequent figure delineates the performance metrics of various projects emulated utilizing Arcilator, encompassing data derived from Verilator tests.



# **Eco-Applications**

## VI & VII. Do Event-driven simulation or verification

Generate LLHD IR and perform event-driven simulation with Ilhd-sim or produce btor2 code for design verification using btor2sim.



## VIII & IX. Generate SystemC code or ......

The exportSystemC pass generates systemC code for implementation, and the compilation route even supports converting Verilog to Verilog.



## Future Plan

The aforementioned features are currently available in the circt upstream branch or are pending integration. Ongoing advancements and optimizations within the compiler are scheduled for subsequent updates, including:

- Builtin function and task support
- Further enhancements to the Moore IR
- Improved support for the circt-verilog utility
- Enhanced testing for the SystemVerilog compilation process
- Upgrade slang version that CIRCT depends on

Our team is adapting other SystemVerilog projects to evaluate and monitor the progress of our developments. We extend an invitation to all parties with an interest in these endeavors to participate actively!

