

21 October 2024 (v5, 20 December 2024)

# Functional Verification for Endcap Concentrator ASICs in the High-Granularity Calorimeter Upgrade of CMS

M. Lupi, G. Bergamin, D. Ceresa, D. Coko, G. Cummings, V. Gingu, M. Hammer, J. Hirschauer, J. Hoff, N. Kharwadkar, S. Kulis, C. Mantilla-Suarez, D. Noonan, P. Rubinov, S. Scarf´ı, A. Shenai, C. Syal, X. Wang, R. Wickwire, and J. Wilson on behalf of CMS collaboration

#### Abstract

The High-Granularity Calorimeter (HGCAL) will replace the current CMS Endcap Calorimeter during Long-Shutdown 3. The Endcap Concentrator (ECON) ASICs represent key elements in the readout chain, processing trigger (ECON-T) and data (ECON-D) streams from the HGCROC to the lpGBT. The ECONs will operate in a radiation environment with a High-Energy Hadron ( $E > 20MeV$ ) flux up to  $2 \cdot 10^7 cm^{-2} s^{-1}$ .

This contribution describes the Universal Verification Methodology (UVM)-based functional verification of the ECON ASICs focusing on the re-use of existing components to manage the complexity of the verification environment.

Presented at *TWEPP2024 Topical Workshop on Electronics for Particle Physics*

# **Functional Verification for Endcap Concentrator ASICs in the High-Granularity Calorimeter Upgrade of CMS**

**M. Lupi,**,<sup>1</sup> **G. Bergamin, D. Ceresa, D. Coko, G. Cummings, V. Gingu, M. Hammer,** d. Hirschauer,  $c$  J. Hoff,  $c$  N. Kharwadkar,  $c$  S. Kulis,  $a$ **C. Mantilla-Suarez, <sup>***c***</sup> D. Noonan, <sup>***c***</sup> P. Rubinov,** *c***<sup>c</sup> S. Scarfí, <sup>***a***</sup> A. Shenai,** *c***<sup>c</sup> C. Syal,** *c* **X.** Wang,  $\epsilon$  R. Wickwire,  $\epsilon$  and J. Wilson $\epsilon$  on behalf of CMS collaboration

*CERN, 1, Esplanade des Particules, Meyrin, Switzerland*

*University of Split, R. Boškovića 32 Split, Croatia*

*FNAL, Batavia IL 60510, USA*

*Argonne National Laboratory, Lemont IL 60439, USA*

*Baylor University, Waco TX 76706, USA*

*E-mail:* [matteo.lupi@cern.ch](mailto:matteo.lupi@cern.ch)

Abstract: The High-Granularity Calorimeter (HGCAL) will replace the current CMS Endcap Calorimeter during Long-Shutdown 3. The Endcap Concentrator (ECON) ASICs represent key elements in the readout chain, processing trigger (ECON-T) and data (ECON-D) streams from the HGCROC to the lpGBT. The ECONs will operate in a radiation environment with a High-Energy Hadron ( $E \ge 20 MeV$ ) flux up to  $2 \cdot 10^7 cm^{-2} s^{-1}$ .

This contribution describes the Universal Verification Methodology (UVM)-based functional verification of the ECON ASICs focusing on the re-use of existing components to manage the complexity of the verification environment.

KEYWORDS: Digital electronic circuits; Front-end electronics for detector readout; Radiation-hard electronics; Simulation methods and programs

ArXiv ePrint: [2411.03476](https://arxiv.org/abs/2411.03476)

<sup>&</sup>lt;sup>1</sup>Corresponding author.

## **1 Introduction**

The High Granularity Calorimeter (HGCAL) is a 47-layer sampling calorimeter that will operate in the CMS detector, upgraded for the High-Luminosity (HL) LHC [1]. The detector is divided into two parts, one using silicon sensors and one using scintillating tiles as active material. The silicon section will consist of section will consist of over  $600m^2$  of hexagonal-shaped sensors, with over six million channels. The scintillating tile section will cover  $370m^2$ , with around 280 thousand channels. Both sections will be read out using two flavours of the HGCROC Front-End (FE) ASIC [2]. Subsequently, the digitized data undergo processing and zero-suppression along two independent paths, managed by two Endcap Concentrators (ECONs): the trigger path, by the ECON-T ASIC, and the data path, by the ECON-D ASIC  $[3]$ . The former produces Level-1 Trigger  $(L1)$  primitives for each bunch crossing, whereas the latter forwards data packets to the acquisition system at an average L1 rate of 750 kHz. These ASICs operate in tandem, sharing a foundational infrastructure, synchronized clocking mechanisms, and input/output protocols, while drawing upon established silicon-proven Intellectual Property (IP). Both ECONs will operate in a radiation environment with a High-Energy Hadrons ( $E \ge 20 MeV$ ) flux up to  $2 \cdot 10^7 cm^{-2} s^{-1}$ . Distributed Triple Modular Redundancy (TMR) and Error Correction Codes (ECCs) are implemented to allow the ECONs to operate in the presence of Single-Event Effects (SEEs).

The whole detector will employ more than one hundred thousand HGCROCs and more than twenty thousand of each ECON-D and ECON-T. The detector modules, an example shown in figure 1, will differ, among other parameters, for the number of HGCROCs associated with each ECON and for the number of lpGBTs [4] used for the data and trigger uplinks. High-density modules, with  $0.5cm^2$  cells, will have up to six HGCROCs per ECON, whereas Low-density modules, with  $1.2cm^2$  cells, will have up to three HGCROCs per ECON. Each HGCROC has two high-speed data (to ECON-D) links and four high-speed trigger (to ECON-T) links. The number of high-speed links used in each ECON is configurable in the range of one to six, for ECON-D, and one to thirteen for ECON-T. In most of the detector areas, the HGCROCs and ECONs will share the I2C bus, used to configure the ASICs, and will receive the clock and fast control signals at the same time.



**Figure 1**. Example of generic detector module with multiple lpGBTs, HGCROCs and two ECONs.

## **2 Verification strategy**

During the initial phases of the ECONs design, the verification team was tasked with developing a verification plan. The verification plan is composed of two main parts, a set of verification goals, i.e. features or scenarios that need to be verified, and a verification strategy, i.e. how the verification plan will be implemented to achieve the aforementioned goals. The first translates into a set of test scenarios and coverage coding, i.e. a set of *Systemverilog covergroups* and *coverpoints* [5], which is ASIC specific and is difficult to re-use across different projects. The latter can easily be replicated in different designs. The verification strategy for ECON-D and ECON-T was designed to target the constraints coming from topologies of the heterogeneous detector modules and from the radiation environment. At the same time, the verification strategy should account for similarities between the two ECONs during the design of the verification components.

Both ECON-D and ECON-T were verified using multiple, complementary approaches: a strict Continuous Integration (CI) embedded into the version control system, a functional verification framework based on Universal Verification Methodology (UVM) [6], and a set of formal verification techniques.

The ECONs were developed using *git* as a version control system and *GitLab* as a development platform. A CI was setup with a gate-keeping function: at each change request, the code is linted and checked, making sure all the verification and implementation collaterals can be regenerated. For example to ensure that the RTL can correctly be triplicated with TMRG [7] and that it can be elaborated by the simulator. Special care was taken to ensure that the simulation results were repeatable and that failing test cases were reproducible. The usage of *git* tags allows uniquely identifying the RTL and verification code which is used to generate a failing test case.

UVM is, de facto, the industry standard for functional verification. It implements coveragedriven constrained-random verification. Moreover, UVM encourages the re-use of verification components (UVCs). Given the similarities between the input and output stages of both ECONs, re-usability was exploited in the development of verification components. The UVM testbenches were used as the main component to verify the compliance of the two ECONs to the detector requirements and the designer's specifications.

Formal verification, in particular model checking, is based on techniques which can prove certain conditions or provide a counter-example, if it exists. In comparison, functional verification proves a design through repeated simulation of test cases whereas formal verification proves a design mathematically. In the verification of the two ECONs, formal verifications techniques were mainly used to prove the correct implementation of TMR using techniques and they are described in [8]. The aforementioned techniques cannot demonstrate SEU tolerance by itself. However, informal analysis of the functional verification of SEU tolerance across multiple HEP ASIC designs revealed that the majority of time spent by verification teams is actually spent in uncovering bugs that ultimately originate in how the RTL is written (using a non-voted signal in place of a voted one, a missing TMRG pragma [7], etc.). These techniques allow providing the verification teams RTL in which properly structured TMR has been assured, thereby greatly improving the efficiency of the functional verification of SEU tolerance.

#### **3 Testbench architecture and vertical re-use**

The testbench architecture was designed to achieve the verification goals. Three types of testbenches were developed: block-, ASIC-, and system-level testbenches.

Block-level testbench was used whenever the block was considered difficult to cover in the ASIC-level testbench. Specifically, in the verification of the ECON-D formatter, the Design Under Test (DUT) is a block with a relatively big fan-in, that receives data and formats them in real-time. The block needs to process both in- and out-of-order packets with interrupts, i.e. a request to drop the current packet, arriving at any time. Moreover, the block receives input data, stored in non-triplicated SRAMs, where only part of the data is protected with ECC. During the ECON-D operation, SEUs will corrupt data stored in the SRAMs and the DUT will have to partially correct them. A dedicated testbench for this DUT allowed emulating input data affected by SEUs and verifying that the DUT correctly treats these data.

ASIC-level testbenches, one for each ECON, allow reaching most of the verification goals. The clocks and fast commands are provided through a dedicated UVC which accounts for jitter, the launching edge of the signals, and skew between clocks and data, among other things. The ASIC is stimulated using two different data sources in input: data from physics simulations, stored in Comma-Separated Value (CSV) files, or randomized data generated by a HGCROC emulator. The first allows running simulated data through the ECONs; the latter allows testing for corner cases and a wide range of scenarios covering the potential use cases of the ASICs in different locations in the detector. The HGCROC emulator also allows the generation of HGCROC data with SEUs, mimicking a real operational scenario. This allows for the testbench to see if the ECONs can cope with inconsistent or partially corrupted data while being able to flag these to the back-end. One of the tasks of both ECONs is to be able to temporally align the incoming HGCROC data for parallel processing. A dedicated UVC was written to randomize the delay with which each ECON channel receives the HGCROC data. This allows the testbench to account for different PCB traces from the HGCROCs to the ECONs in different locations of the detector.

System level testbenches, one for each ECON, allow verification that the ASICs are operating correctly and in sync with the HGCROCs. An example of the ECON-D testbench is shown in figure 2. In particular, both ECONs and the HGCROC receive clocks and fast commands at the same time and they need to execute certain operations in sync, e.g. temporal alignment or data pipeline flushing. Even if these testbenches require a non-negligible investment in development and execution time, they allow co-simulating the RTL of the HGCROC and the ECONs verifying that the specifications of both ASICs are compatible.

When comparing the three different levels of testbenches it is important to keep in mind a few key factors. A block-level testbench is much faster to bring up, run tests on, and debug compared to a system-level testbench. At the same time, it is important to focus on ASIC- or system-level scenarios as they are more likely to emulate realistic scenarios under which the detector will operate.

Vertical re-use of UVCs played a key role in developing the testbenches: each of the verification components was designed with re-use in mind and considering how it should work in different testbenches. E.g. the HGCROC emulator UVC works as an active (i.e. producing stimuli) component in the ASIC-level testbenches, but it only works as a passive (i.e. monitoring the data received from the HGCROC RTL) component in system-level testbenches. Designing components

for re-use clearly increases their development time but at the same time, it allows implementing them only once, without having to rewrite the same code multiple times with the associated downsides: technical risk due to human errors, subtle mistakes in the implementation, and development and debug time.

Given the similarities between the two ECONs inputs and output stages, both the corresponding UVCs and reference models were written once and re-used across the ASIC-, and system-level testbenches. This approach greatly reduced the development times of the verification environment.



**Figure 2**. Example of system-level testbench for ECOND. The testbench re-uses multiple re-usable UVCs, in yellow, and some UVCs developed specifically for the ECONs verification. These are re-usable in both ECONs testbenches. In orange there are the UVCs developed specifically for the HGCROC.

# **4 Verification of SEE tolerance**

SEE tolerance was considered an additional requirement when setting the verification goals. As already mentioned, formal verification techniques were used to prove the correct implementation of TMR. These techniques have the advantage of being very fast to find bugs (or to prove their absence). On the other hand, these techniques cannot be universally used: e.g. they have convergence problems with big designs for which only certain parts can be proven to be bug-free. They cannot be run on designs with multiple clocks, for which a proven solution still does not exist, and they cannot prove SET tolerance. Simulation-based techniques [9] were used to complement the formal techniques, including:

- Running SEU injections in fully triplicated nodes and comparing selected ASIC signals against the output of a reference simulation without any fault injection.
- Running SET injections in triplicated clock and reset trees in post-layout, Gate Level Netlist (GLN) with annotated delays.

# **5 Runtime of sign-off runs**

To sign-off each of the ECONs the following runs were executed on different DUTs: RTL, triplicated RTL, GLN (with annotated delays, in the three corners) and the fault injection (SEEs) runs.

The verification environment of both ECONs was developed in parallel with the RTL. Both went through development cycles where bugs were found and subsequently fixed. The verification framework is run in regression runs: periodically to validate change requests. The run time, as one would expect increases as more features are added. Sign-off runs, i.e. those regressions runs that target the achievement of full coverage of the verification goals, represent a good example of runtime and they are reported in the table 1.

**Table 1**. Typical run times and number of tests for sing-off runs for each DUT level. Runtime is calculated on 32 parallel runs. The regressions were run on machines with two AMD EPYCTM7302 processors (for a total of 32 cores running at 3 GHz). ECON-D RTL run includes also the block-level testbench.

| <b>DUT</b>          | Number of tests |               | Runtime [hours] |        |
|---------------------|-----------------|---------------|-----------------|--------|
|                     | ECON-D          | <b>ECON-T</b> | ECON-D          | ECON-T |
| RTL                 | 6000            | 2500          | 33              | 15     |
| <b>TMR</b> with SEU | 1500            | 1500          | 35              | 25     |
| GL (SDF)            | 1200            | 1200          | 40              | 42     |
| GL (SDF) with SEE   | 1000            | 1000          | 32              | 35     |

# **6 Conclusions**

The verification strategy developed for both ECON-D and ECON-T was presented. The final regressions achieved complete functional coverage for the defined operational scenarios. During the functional verification of ECON-D 216 functional, 67 triplication, and 74 implementation bugs were found. In ECON-T, 44 functional, 9 triplication, and 14 implementation bugs were found. The authors attribute the ECON-T lower bug rate to a more mature set of specifications, i.e. a prototype of ECON-T was already existing and partially verified, and the project timeline, i.e. ECON-T was submitted after ECON-D, meaning that the bugs in the common infrastructure were already addressed. The bugs found vary widely from gaps in the specifications, missing voters, and corner cases in the communication with HGCROC.

Production versions of the two ASICs were submitted for fabrication in December of 2023. Comprehensive chip testing and radiation characterization have revealed no major issues. The ASICs are also being integrated in the first detector modules operating together with multiple HGCROCs and lpGBT.

#### **References**

- [1] The CMS collaboration, *The Phase-2 Upgrade of the CMS Endcap Calorimeter*, *CERN-LHCC-2017-023*, *CMS-TDR-019* (2017), DOI : 10.17181/CERN.IV8M.1JY2
- [2] Bouyjou F. et al., *HGCROC3: the front-end readout ASIC for the CMS High Granularity Calorimeter*, *JINST* (2022), DOI: 10.1088/1748-0221/17/03/C03015
- [3] Braga D. et al., *First test results of the HGCAL concentrator ASICs: ECON-T and ECON-D*, *JINST* (2024), DOI: 10.1088/1748-0221/19/03/C03050
- [4] Moreira P. et al., *Radiation-hard ASICs for data transmission and clock distribution in High Energy Physics*, *NIMA* (2023), DOI 10.1016/j.nima.2023.168364
- [5] *IEEE Standard for SystemVerilog–Unified Hardware Design, Specification, and Verification Language*, *IEEE Std 1800-2023* (2023), DOI: 10.1109/IEEESTD.2024.10458102
- [6] *IEEE Standard for Universal Verification Methodology Language Reference Manual*, *IEEE Std 1800.2-2020* (2020), DOI: 10.1109/IEEESTD.2020.9195920
- [7] Kulis S., *Single Event Effects mitigation with TMRG tool*, *JINST* (2024), DOI: 10.1088/1748-0221/12/01/C01082
- [8] Lupi M. et al., *SEU injection framework for radiation-tolerant ASICs, a formal verification approach*, *JINST* (2023), DOI: 10.1088/1748-0221/18/02/C02023
- [9] Pulli A. et al., *A simulation methodology for verification of transient fault tolerance of ASICs designed for high-energy physics experiments*, *JINST* (2023), DOI: 10.1088/1748-0221/18/01/C01038