## Software Inspired IC Hardware Workflows Using Bazel

Ethan Mahintorabi

Google Core Google Seattle, United States of America ethanmoon@google.com

## Abstract—

Over the past 20 years a significant amount of development has gone into developer tooling to build software safely, and repeatedly. *Bazel* [1] is an open source build system designed from the ground up to accommodate highly variable language tool chains and massive software builds. This project aims to leverage that very same technology to offer software inspired workflows to build integrated circuits.

In this abstract session, I discuss the open source project hdl/bazel\_rules\_hdl [2] which aims to use *Bazel*, *OpenROAD* [3], *Yosys* [4] and other open source tools to build a software like workflow that integrates synthesis, place and route, and verification into well defined build rule functions that can be easily run, distributed, and cached on multiple machines using the existing capabilities of Bazel.

Today hdl/bazel\_rules\_hdl offers Bazel rules that will synthesize, place and route and run regression tests against the final placed and routed design. The regression tests allow you to set power and area thresholds on subblocks that cannot be exceeded without updating the thresholds, or modifying the problematic RTL.

These build rules give you the ability to setup software like presubmits that prevent RTL modifications that reduce the final PPA of the design, break the place and route or negatively impact synthesis. These types of workflows are common in the software model, but are novel in the hardware workflow space.

The long term goal of this project is that it enables users to run bazel test //mychip/... and bazel build //mychip:gds and in 10 minutes you have verified and emitted a fabricatable IC even for the most complex designs. *Index Terms*—hardware tool chain, WOSET 2021, hardware workflows, bazel, software workflows, OpenROAD

## References

- [1] K. Wang, D. Rall, G. Tener, V. Gullapalli, X. Huang, and A. Gad, "Smart build targets batching service at google," in 2021 IEEE/ACM 43rd International Conference on Software Engineering: Software Engineering in Practice (ICSE-SEIP), 2021, pp. 160–169.
- [2] P. G. Ethan Mahintorabi. (2020) Bazel rules hdl. [Online]. Available: https://github.com/hdl/bazel\_rules\_hdl
- [3] T. Ajayi, V. A. Chhabria, M. Fogaça, S. Hashemi, A. Hosny, A. B. Kahng, M. Kim, J. Lee, U. Mallappa, M. Neseem, G. Pradipta, S. Reda, M. Saligane, S. S. Sapatnekar, C. Sechen, M. Shalan, W. Swartz, L. Wang, Z. Wang, M. Woo, and B. Xu, "Invited: Toward an open-source digital flow: First learnings from the openroad project," in 2019 56th ACM/IEEE Design Automation Conference (DAC), 2019, pp. 1–4.

[4] C. Wolf, J. Glaser, and J. Kepler, "Yosys-a free verilog synthesis suite," 2013.