# ChiBench: a Benchmark Suite for Testing Electronic Design Automation Tools

Rafael Sumitani
UFMG
Brazil
rafaelsumitani@dcc.ufmg.br

João Victor Amorim
UFMG
Brazil
joao.amorim@dcc.ufmg.br

Augusto Mafra
Cadence
Brazil
augusto@cadence.com

# Mirlaine Crepalde

Cadence Brazil mirlaine@cadence.com

#### Fernando M Quintão Pereira

UFMG
Brazil
fernando@dcc.ufmg.br

## **Abstract**

Electronic Design Automation (EDA) tools are software applications used by engineers in the design, development, simulation, and verification of electronic systems and integrated circuits. These tools typically process specifications written in a Hardware Description Language (HDL), such as Verilog, SystemVerilog or VHDL. Thus, effective testing of these tools requires benchmark suites written in these languages. However, while there exist some open benchmark suites for these languages, they tend to consist of only a handful of specifications. This paper, in contrast, presents ChiBench, a comprehensive suite comprising 50 thousand Verilog programs. These programs were sourced from GitHub repositories and curated using Verible's syntactic analyzer and Jasper<sup>TM</sup>'s HDL semantic analyzer. Since its inception, ChiBench has already revealed bugs in public tools like Verible's obfuscator and parser. In addition to explaining some of these case studies, this paper demonstrates how ChiBench can be used to evaluate the asymptotic complexity and code coverage of typical electronic design automation tools.

*CCS Concepts:* • Software and its engineering  $\rightarrow$  Compilers.

Keywords: Benchmark, Verilog, Testing

#### 1 Introduction

EDA (Electronic Design Automation) tools are software applications used by engineers in the design, development, simulation, and verification of electronic systems and integrated circuits (ICs). These tools cover various stages of the electronic design process, from conceptualization and design entry to implementation, verification, and testing. Examples of EDA tools include Cadence Jasper for formal verification<sup>1</sup> and Verible's tool<sup>2</sup>. These tools operate on similar types of input data: programs in some Hardware Description Language (HDL), such as Verilog, SystemVerilog, VHDL or SystemC.

Thus, the effective development and testing of such tools require benchmarks in these languages.

Verilog Benchmarks (or their lack thereof). A Benchmark Suite is a collection of programs used to test computing systems that process such programs. There exist open source benchmark collections tailored for EDA tools, such as the IS-CAS Benchmark Circuits [3] (31 circuits), the MCNC Benchmark Circuits [4] (19 circuits in the YAL format), the EPFL Combinational Benchmark Suite [1] (23 circuits), the RAW Benchmark Suite [2] (twelve programs), the KOIOS collection (19 circuits implementing different neural networks) and the Titan23 suite of 23 circuits [5]. These collections contain a small number of programs: typically less than 50. This fact is unfortunate because, in the works of Wang and O'Boyle [11]: "Although there are numerous benchmark sites publicly available, the number of programs available is relatively sparse compared to the number that a typical compiler will encounter in its lifetime." This paper mitigates this problem, releasing a much larger collection of Verilog circuits.

The Contribution of this Work. This paper describes ChiBench, an open collection of 50K Verilog programs, mined from open-source GitHub repositories. These programs were curated in a three-step process, which Section 2 explains: first, Verilog codes were automatically scraped from public code repositories. In a second phase, each program was parsed using Verible's syntactic analyzer, to ensure compliance with the IEEE Standard 1364 [9]. Finally, these programs were sieved via Jasper's HDL semantic analyzer, to ensure that each circuit contains all the required dependencies.

This paper illustrates three different usage scenarios where ChiBench has been employed, using two tools from the Verible project as test subjects. First, Section 3.1 demonstrates how ChiBench programs can be used to investigate the asymptotic complexity of EDA tools. Second, Section 3.2 explains how these programs can test EDA tools by gauging the coverage of ChiBench as a test dataset. Finally, Section 3.3 briefly describes two bugs discovered in open-source tools through ChiBench-based tests.

 $<sup>^1</sup> A vailable \ at \ https://www.cadence.com/en_US/home/tools/system-design-and-verification/formal-and-static-verification.html$ 

<sup>&</sup>lt;sup>2</sup>Available at https://github.com/chipsalliance/verible

# 2 The Construction of a Benchmark Suite

In order to build our Benchmark Suite, we have mined programs from open-source GitHub repositories, using GitHub's REST API <sup>3</sup>. We use GitHub's API to build a list of candidate Verilog repositories. Said list is sorted by popularity (measured as the number of stargazers). We remove from the candidate list repositories that are not available for public usage, due to the lack of a license. Thus, for each repository *R* in the sorted list, we have implemented a Python script that proceeds as follows:

- 1. Clone *R* and locally copy all its . v files;
- 2. Assigns a unique name to each .v file, based on its repository and its local path;
- 3. Remove any special characters from the file's name to avoid encoding issues.

We repeat the above sequence of steps for all the repositories in the base list, until reaching a predefined number of files. This threshold is set upon calling the mining script. Currently, ChiBench provides only Verilog programs; however, the mining script can be easily adapted to fetch files in any other language that is tagged in GitHub, such as VHDL.

#### 2.1 Curating the Data

After we have copied the necessary number of Verilog files from GitHub, we proceed to select valid programs. To this effect, we only keep files that are syntactically and semantically valid. Thus, this process involves passing the files through two sieves. The first sieve, the syntax analysis, happens via the Verible syntactic analyzer. At this stage, if Verible's parser cannot build an abstract syntax tree for a file, we discard it. Example 2.1 illustrates one such situation.

**Example 2.1.** The program in Figure 1, which specifies an 8-bit counter, will be filtered out by the syntactic filter. It contains a missing semicolon at Line 7. Such syntactically invalid files are uncommon in the mining process. Nevertheless, they occur, as the repositories contain, for instance, files that are still under development.

```
01 module counter (input clk, input rst,
02
     output reg [7:0] data);
     always @(posedge clk) begin
03
04
      if (rst || data == 8'hff)
05
       data <= 8'h00:
                                     This program is
06
                                     syntatically invalid
      else
07
       data <= data + 8'h01
                                     because it misses a
80
                                     semicolon at the end of
09 endmodule
                                     line 7
```

**Figure 1.** Verilog specification filtered out by our syntactic verification.

Once we remove any syntactically invalid programs, we use Jasper's HDL semantic analyzer to filter out any semantically invalid programs<sup>4</sup>. Notice that Jasper's HDL analyzer also rejects invalid syntax. However, Jasper's HDL analyzer is more computationally expensive than Verible's because it also considers semantic analysis, being more restricted to Verilog language standards. Consequently, in order to reduce the number of programs sent for semantic analysis, we chose to filter out syntactically invalid programs before using Jasper. Example 2.2 better explains what is the role of the semantic analysis.

**Example 2.2.** Figure 2 shows an example of a program that fails the semantic sieve due to a type inconsistency. In this case, the IEEE standard forbids the declaration of data ports with the wire type. Our data generation process considers each file independently, thus, this error might occur. Nevertheless, our experience is that most Verilog programs can be successfully validated as a single compilation unit.



**Figure 2.** Verilog specification that fails the semantic test.

#### 2.2 Licensing

ChiBench only contains files that provide permissive licenses. In other words, we remove from the public distribution of this collection any Verilog specification that comes from either a repository without a license or that comes from a repository whose license prevents distribution. Figure 3 shows the number of licenses in each repository used to build ChiBench. Each ChiBench file contains, as a comment, the URL of the repository from where it comes, plus its license.

## 3 Evaluation

The goal of this section is to demonstrate that ChiBench is a useful collection of benchmarks. To this end, we shall investigate the following three research questions:

**RQ1:** Can ChiBench Programs be used to infer, empirically, the asymptotic complexity of EDA tools?

<sup>&</sup>lt;sup>3</sup>Available at https://docs.github.com/en/rest

<sup>&</sup>lt;sup>4</sup>Jasper's HDL semantic analyzer is triggered with the analyze built-in command



Figure 3. Licenses of repositories used to build ChiBench.

**RQ2:** How much coverage should we expect to obtain by using ChiBench as a dataset to test EDA tools?

**RQ3:** Are ChiBench-based tests able to uncover zeroday bugs in well-known EDA tools?

**RQ4:** How are ChiBench's programs characterized in terms of size?

*Experimental Setup.* The evaluation described in this Section uses two tools available in the Verible Project (Release v0.0-3622-g07b310a3, Mar 13th, 2024) as test subjects: the parser and the obfuscator. Experiments run on an AMD Ryzen 9 5900X 12-Core 3.7GHz processor featuring Ubuntu Linux 22.04.4 LTS (kernel 6.5.0-27-generic). Coverage is measured via Clang's source-based code coverage feature (available in Clang 14.0.0).

# 3.1 RQ1 - Asymptotic Analysis

The asymptotic complexity of a tool is an expression that relates the running time of that tool as a function of its input size. Determining an analytical formula for the asymptotic complexity of a tool is a challenging problem, as this formula is influenced by many details of that tool's implementation. Thus, as an alternative, to understand the asymptotic behavior of implementations of algorithms, researchers resort to the so-called *empirical complexity analysis*. In the words of Sumitani et al. [7]: "Empirical Complexity Analysis is a branch of computer science that tries to infer the asymptotic complexity of algorithms through the observation of multiple executions of that algorithm with different inputs". In this paper, we show how ChiBench can be effectively used as a means to carry out empirical complexity analysis.

**Discussion.** Figure 4 relates the number of tokens in ChiBench programs with the time that Verible's syntactic



**Figure 4.** The impact of the number of tokens on Verible's parsing time. This figure contains about 50K points—one point per program in the ChiBench collection.

analyzer takes to parse these programs. To perform this experiment, we used the programs in the ChiBench collection as input to Verible's parser. As Figure 4 shows, the running time behavior of Verible is linear. In this regard, Pearson's coefficient relating running time and number of tokens is 0.99, with a p-value of less than  $2^{-16}$ . Therefore, Verible's parser is expected to run in linear time on the number of tokens that form the program with very strong probability.

# 3.2 RQ2 - Coverage Analysis

Coverage is a metric that quantifies the effectiveness of a test suite. In this paper, we report coverage in two ways. Either as the number of lines in the source code of a program that the test suite exercises. Or else as the number of branches exercised by the test case in the binary representation of that same program. Thus, we define the coverage ratio as either the number of lines covered divided by the total lines of code or as the number of branches covered divided by the total number of branches. The higher the coverage ratio, the better the test suite. This section analyzes the coverage ratio of ChiBench.

**Discussion.** Figure 5 presents the code coverage for Verible's obfuscator and parser assessed with the 128 largest programs from ChiBench. The coverage pattern for both tools is similar; however, the parser demonstrates a notably higher coverage. For lines covered it ranges from 10% to 19% against 4.5% to 7% for the obfuscator. In terms of branches covered, the parser starts at 31% and reaches 36% whereas the obfuscator begins at 11% and ends at nearly 12%. The red lines represent the code coverage when using all programs from ChiBench. For the parser, we achieved 42% coverage for lines and 48% for branches. In comparison, the obfuscator reached 14% for lines and nearly 16% for branches.



Figure 5. Code coverage of different tools of the Verible Framework, using the 128 largest programs from ChiBench.

We hypothesize that this disparity arises because the parser is a larger feature and, consequently, calls a larger variety of functions from Verible's modules. In contrast, the obfuscator is a more self-contained tool. Although these numbers seem low in principle, we remind the reader that Verible is a large framework, which includes several tools, such as a linter, a code formatter, and a language server. The code that forms these parts, although part of the Verible binary library, remained largely unseen during this experiment.

#### 3.3 RQ3 - Actual Bug Reports

ChiBench was initially conceived to stress-test EDA tools. Thus, to demonstrate the effectiveness of this collection as a bug-finding mechanism, we apply it onto open-source tools available in the Verible Framework.

**Discussion.** We have used ChiBench to evaluate the correctness of Verible's parser, code obfuscator and code formatter. In this case, we define as a *buggy evaluation* the analysis of a program from ChiBench that results in a "crash"; that is, an execution of the subject tool that leads to either an assertion or to an operating system exception (such as a segmentation fault). Under these definitions, we have observed one buggy evaluation on each tool. Both have been reported to the Verible's community:

- https://github.com/chipsalliance/verible/issues/2159: Verible's obfuscator crashes when reading a program that only contains the pragma directive.
- https://github.com/chipsalliance/verible/issues/2181:
   Verible's parser crashes instead of reporting syntax errors related to instantiation type.
- https://github.com/chipsalliance/verible/issues/2189: Verible's formatter crashes with a specific three-line input that is syntactically valid.

Interestingly, the second issue—which has been acknowledged as a true bug—was not activated by a program in ChiBench itself, but by a program derived from the suite: to maximize the diversity of ChiBench programs, we have used this collection to generate new programs. Generation works as follows: we use the 50K programs in ChiBench to calculate the probability that each production rule in Verible's parser is exercised when parsing a program. Then, we use this probabilistic grammar to generate new programs. In this case, every type is set as logic.

#### 3.4 RQ4 - Size Characterization

ChiBench programs are mined from open-source repositories; hence, we speculate that they approximate the average Verilog program that represents typical circuits. This section provides some characterization of such programs. To this end, we analyze their size distribution.

**Discussion.** Figure 6 shows a density curve representing the size distribution of ChiBench programs. We measure size as the number of tokens that the Verible lexer produces for each Verilog file. Notice that this metric does not depend on user-defined names. Figure 6 makes it clear that most Verilog specifications are small. In total, ChiBench contains 50,611 Verilog programs. Out of this lot, 66.87% contain less than 1,000 tokens, and 79.24% contain less than 2,000. The largest program in ChiBench contains 25,690,281 tokens, and the smallest contains only 4. The average number of tokens is 33,350.9, and the median number is 489.

# 4 Related Work

As we have already mentioned in Section 1, there exist already collections of benchmarks formed by hardware specification languages [1-5]. However, these collections are small: never containing more than 50 circuits. Nevertheless, with



**Figure 6.** Distribution of ChiBench programs per size, measured in number of tokens.

the rising popularity of large language models, this scenario has seen changes in the last year.

As an example of this new trend, at the end of 2023, Thakur et al. [8] released VeriGen, a version of the CodeGen [6] fine-tuned for the synthesis of Verilog specifications. In the process of tuning CodeGen, Thakur et al. have collected 50K Verilog circuits. However, in contrast to ChiBench, the dataset used by Thakur et al. has not undergone any form of filtering; hence, we do not know if these programs are semantically valid. This dataset is publicly available<sup>5</sup>; however, each program is a single line string. Parsing these programs automatically to reconstruct the original Verilog specification is not possible, due to the presence of line comments in the codes. This shortcoming is not a problem in the context of Thakur et al.'s work, given that they are interested in building a large language model that is based on k-grams of Verilog codes. Yet, the dataset used to train the model could not be used, for instance, to stress-test EDA tools. We believe that ChiBench might be useful to support the implementation of models like VeriGen. To this effect, independent evaluations of VeriGen have found that "A primary contributing factor to this shortfall [the inability to uncover bugs in EDA tool] is the insufficiency of HDL code resources for training" [6]. This perceived lack of benchmarks seems to be a common issue among researchers working on large language models for hardware specifications [10, 12].

#### 5 Conclusion

This paper has described ChiBench, a collection of 50K Verilog programs mined from open-source GitHub repositories. In addition to explaining the methodology to build this suite, this paper showed how ChiBench can be effectively used to

test and analyze the behavior of electronic design automation tools. The infrastructure used in the construction of ChiBench can be adjusted to other languages, such as VHDL. Thus, future work might involve maximizing the diversity of ChiBench programs to broaden coverage of EDA tools.

**Software.** ChiBench is available at https://github.com/lacdcc/chimera. Each benchmark available in ChiBench provides, as a header comment, its original license, in addition to the repository from where that specification was obtained.

# Acknowledgement

This project is sponsored by Cadence Design Systems. Additionally, the authors acknowledge the support of CNPq (grant 406377/2018-9), FAPEMIG (grant PPM-00333-18), and CAPES (grant "Edital CAPES PrInt").

#### References

- Luca Amaru, Pierre-Emmanuel Gaillardon, Eleonora Testa, and Giovanni De Micheli. 2019. The EPFL Combinational Benchmark Suite. https://doi.org/10.5281/zenodo.2572934
- [2] J. Babb, M. Frank, V. Lee, E. Waingold, R. Barua, M. Taylor, J. Kim, S. Devabhaktuni, and A. Agarwal. 1997. The RAW benchmark suite: computation structures for general purpose computing. In FCCM. IEEE Computer Society, USA, 134.
- [3] Franc Brglez, David Bryan, and Krzysztof Kozminski. 1989. Combinational profiles of sequential benchmark circuits. In ISCAS. IEEE, New York, USA, 1929–1934.
- [4] Krzysztof Koźmiński. 1991. Benchmarks for layout synthesis—evolution and current status. In DAC. Association for Computing Machinery, New York, NY, USA, 265–270. https://doi.org/10.1145/127601.127678
- [5] Kevin E. Murray, Scott Whitty, Suya Liu, Jason Luu, and Vaughn Betz. 2015. Timing-Driven Titan: Enabling Large Benchmarks and Exploring the Gap between Academic and Commercial CAD. ACM Trans. Reconfigurable Technol. Syst. 8, 2, Article 10 (mar 2015), 18 pages. https://doi.org/10.1145/2629579
- [6] Erik Nijkamp, Bo Pang, Hiroaki Hayashi, Lifu Tu, Huan Wang, Yingbo Zhou, Silvio Savarese, and Caiming Xiong. 2023. CodeGen: An Open Large Language Model for Code with Multi-Turn Program Synthesis. arXiv:2203.13474 [cs.LG]
- [7] Rafael Sumitani, Lucas Silva, Frederico Campos, and Fernando Pereira. 2023. A Class of Programs that Admit Exact Complexity Analysis via Newton's Polynomial Interpolation. In SBLP. ACM, New York, NY, USA, 50–55. https://doi.org/10.1145/3624309.3624311
- [8] Shailja Thakur, Baleegh Ahmad, Hammond Pearce, Benjamin Tan, Brendan Dolan-Gavitt, Ramesh Karri, and Siddharth Garg. 2024. Veri-Gen: A Large Language Model for Verilog Code Generation. ACM Trans. Des. Autom. Electron. Syst. 29, 3, Article 46 (apr 2024), 31 pages. https://doi.org/10.1145/3643681
- [9] Donald E. Thomas and Philip R. Moorby. 1996. The VERILOG Hardware Description Language (3rd ed.). Kluwer Academic Publishers, USA.
- [10] Yun-Da Tsai, Mingjie Liu, and Haoxing Ren. 2024. RTLFixer: Automatically Fixing RTL Syntax Errors with Large Language Models. arXiv:2311.16543 [cs.AR]
- [11] Zheng Wang and Michael O'Boyle. 2018. Machine Learning in Compiler Optimisation. arXiv:1805.03441 [cs.PL]
- [12] Xufeng Yao, Haoyang Li, Tsz Ho Chan, Wenyi Xiao, Mingxuan Yuan, Yu Huang, Lei Chen, and Bei Yu. 2024. HDLdebugger: Streamlining HDL debugging with Large Language Models. arXiv:2403.11671 [cs.AR]

 $<sup>^5</sup>At\ https://huggingface.co/datasets/shailja/Verilog\_GitHub$