## POLITECNICO DI TORINO Repository ISTITUZIONALE

Taking Test Programs Connectivity to the Bit-Level

Original

Taking Test Programs Connectivity to the Bit-Level / Calabrese, Andrea. - (In corso di stampa). (Intervento presentato al convegno IEEE European Test Symposium, (ETS)).

Availability: This version is available at: 11583/2981871 since: 2023-09-10T11:42:16Z

Publisher: IEEE

Published DOI:

Terms of use:

This article is made available under terms and conditions as specified in the corresponding bibliographic description in the repository

Publisher copyright IEEE postprint/Author's Accepted Manuscript

©9999 IEEE. Personal use of this material is permitted. Permission from IEEE must be obtained for all other uses, in any current or future media, including reprinting/republishing this material for advertising or promotional purposes, creating new collecting works, for resale or lists, or reuse of any copyrighted component of this work in other works.

(Article begins on next page)

# Taking Test Programs Connectivity to the Bit-Level

Andrea Calabrese Dip. automatica ed informatica, Politecnico di Torino Turin, Italy

andrea.calabrese@polito.it

*Abstract*—As System-on-Chips become more and more complex, a high fault coverage is becoming more difficult to achieve. As fault coverage is the de facto standard metric for testing, we aim for a faster heuristic for test evaluations. In particular, last year a faster heuristic known as *connectivity* was defined in ITC 2022 [1]. We want to improve over this heuristic, trying to improve the precision of the connectivity metric. In particular, we introduce a bit-level connectivity, using the general connectivity as an optimistic value, however taking into account the toggle coverage at a register-level. Our case study is a chip developed by STMicroelectronics of the SP58 family.

*Index Terms*—Burn-in test, functional test, heuristics, EDA, Automotive.

#### I. INTRODUCTION

As System-on-Chips (SoCs) increase in scale on every generation, testing is becoming an increasingly difficult task, both in terms of test complexity and in terms of time spent; moreover, many SoCs include now multi-core capabilities and even the interactions between different cores need to be tested [2]. Thus, the probability of physical defects keeps increasing [3]. Standards such as ISO-26262 [4] provide a well-defined metric for safety applications in the automotive field, but means to achieve the desired safety metrics are becoming more and more expensive in terms of time.

In this paper, we will improve over the coverage heuristic [1] to provide more details about the data passed between instructions of a test program. In Section II we will shortly talk about the original coverage metric. In Section III we will propose the methodology to improve over the original coverage metric. In Section IV we will show our experiments on our case study. In the end, we will draw some conclusions.

#### II. BACKGROUND

Burn-In (BI) is a well-established methodology for finding latent defects in SoCs [5]. In particular, during the BI analysis, various tests and programs run on the Device under Test (DuT), interleaved with signature checks on intermediate results. Functional testing is a methodology suited for both online and manufacturing testing [6]–[8]. It mainly consists in executing programs, both hand-written or generated by an automatic tool such as microGP [9], during the testing phase.

Fault coverage is the de facto standard in the testing field to evaluate the goodness of a testing program or pattern. However, this process tends to be time-consuming; however,

Thanks to (in alphabetical order): Francesco Angione, Paolo Bernardi, Lorenzo Cardone, Stefano Quer, and the STMicroelectronics' team. in [1], a connectivity metric emerges as a proposal for a fast evaluation of a test program. Connectivity does not aim to substitute the fault coverage, but it is meant to be a helping metric for the programmer (be it a person or a tool) to improve upon such a program.

In general, given two instructions  $I_x$ ,  $I_y$  and a register  $R_n$ , we say those instructions are connected on  $R_n$  when, if  $I_x$  writes on register  $R_n$  and  $I_y$  reads from such register, no instruction  $I_z$  between  $I_x$  and  $I_y$  writes on  $R_n$ . The connectivity analysis assesses the connections between all of the instructions on the test program on each register.

This way, connectivity aims to detect the usefulness of each instruction of the test program, giving the programmer a choice between improving the program in terms of time consumption (eliminating useless instructions) or in terms of coverage (connecting those instructions to the next ones).

#### III. PROPOSED APPROACH

As the connectivity takes into account the flow of the program, it is arguable that the data for the testing is also important. In this paper, we want to propose an enhancement to the connectivity metric, taking into account the propagation of the bits of each register. In particular, we want to produce a report of what bits changed for each register, both involved or not, in the program execution.



Fig. 1. An adder acting on the same registers carrying different data.

As an example, in Figure 1 we suppose 2 4-bit registers R0 and R1. We suppose that we can control R1 without changing the desired flow of the test program; our objective is to toggle all the bits contained in R0 to improve the toggle activity. In Figure 1(a), we chose a sub-optimal value for R1, as in R0 only 2 bits toggle after the operation. However, in Figure 1(b) we chose R1 in such a way that all the values in R0 toggle in the end.

|                      | Original |              |                  | Improved |              |                  |
|----------------------|----------|--------------|------------------|----------|--------------|------------------|
| Test program         | Coverage | Connectivity | Bit-level        | Coverage | Connectivity | Bit-level        |
|                      | [%]      | [%]          | connectivity [%] | [%]      | [%]          | connectivity [%] |
| Adder                | 92.56    | 91.38        | 23.82            | 93.67    | 91.38        | 81.21            |
| Multiplier           | 92.30    | 68.96        | 45.25            | 93.38    | 68.96        | 78.43            |
| Floating Point       | 90.78    | 96.4         | 36.96            | 91.71    | 96.4         | 40.01            |
| Shifter              | 86.20    | 92.38        | 48.14            | 89.48    | 95.17        | 48.29            |
| Count-zeros          | 86.81    | 94.49        | 13.72            | 87.72    | 94.49        | 14.51            |
| Load-Store           | 91.85    | 53.28        | 19.06            | 93.76    | 53.28        | 22.06            |
| Branch Target Buffer | 71.16    | 68.45        | 30.99            | 72.14    | 68.45        | 35.99            |
| Bit-wise logical     | 95.00    | 100.00       | 30.14            | 95.95    | 100.00       | 31.84            |

 TABLE I

 Improvements on bit-level connectivity and the consequences on the fault coverage

We can extend this idea to every N-bit register and to every operation performed by the test program. Starting from the connectivity data, we perform an additional pass: since only the connected instructions produce fault coverage, we are interested in the bit-level connectivity of those instructions. We compute the cumulative bit-level connectivity percentage on the instruction-to-instruction level per register using Equation 1:

$$C_{i2i}(R_n(t_0), R_n(t_1)) = \frac{Count\_ones(R_n(t_0) \bigoplus R_n(t_1))}{Size\_of(R_n)}$$
(1)

Where  $C_{i2i}$  is the bit-level connectivity on instruction-toinstruction level, the  $\bigoplus$  operation is a xor, and  $R_n(t_x)$  is the status of the register n at the time  $t_x$ .

However, using a single instruction for a full test on an operation on a register may not be feasible, both because it may affect the program flow and might not take into account different side effects (eg.: overwriting the instruction pointer). In this case, to evaluate the whole program, we can perform a similar operation using the entire original connectivity report, losing granularity over the information while, however, assessing the test at an end-to-end level. To assess this end-to-end bit-level connectivity, we use the Equation 2:

$$C_p = C * \sum_{n=0^N} \frac{\sum_{t=1^T} \min(1, C_{i2i}(R_n(t-1), R_n(t)))}{N * Size\_of(R_n)}$$
(2)

Where  $C_p$  is our desired metric, C is the original connectivity and the rest is the sum of the bit-level single instruction connectivities applied to all registers including all the program, capped at 1. We designed this bit-level connectivity to cap at C for computing the distance between an optimal program in terms of data and the optimal program with respect to the original connectivity.

#### IV. EXPERIMENTAL RESULTS

We performed our experiments on the SPC58 automotive autocontroller provided by STMicroelectronics.

Table I shows improvements on the fault coverage obtained by increasing the bit-level connectivity on some of our test programs; the only exception is the shifter program, which received improvements both in the original connectivity and in the bit-level connectivity. By looking at the improved coverage column, we can see that even slightly changing the data may have a small improvement on the overall bit-level connectivity. Experimentally, this analysis comes at a slightly higher cost with respect to the original connectivity analysis, in the order of 0.1 seconds. However, the added bit-level analysis provides more in-depth results than the original connectivity, providing a suggestion on what instruction can be improved to reach the full potential of the connectivity metric, therefore increasing the fault coverage.

#### V. CONCLUSIONS

We propose an improvement on the connectivity metric, developed for fast feedback to the test programmer, providing bit-level precision for each instruction. This bit-level connectivity improves the feedback for the test programmer, showing how many bits were tested for each register on each instruction acting on it. This way, the programmer can focus on the data quality with knowledge of the data flow provided by the original connectivity.

#### REFERENCES

- [1] F. Angione, P. Bernardi, A. Calabrese, L. Cardone, A. Niccoletti, D. Piumatti, S. Quer, D. Appello, V. Tancorre, and R. Ugioli, "An innovative strategy to quickly grade functional test programs," in 2022 IEEE International Test Conference (ITC), 2022, pp. 355–364.
- [2] F. Angione, P. Bernardi, G. Filipponi, C. Tempesta, M. S. Reorda, D. Appello, V. Tancorre, and R. Ugioli, "Online scheduling of concurrent memory bists execution at real-time operating-system level," in 2022 IEEE International Symposium on Defect and Fault Tolerance in VLSI and Nanotechnology Systems (DFT), 2022, pp. 1–6.
- [3] A. Vassighi et al., "Cmos ic technology scaling and its impact on burn-in," *IEEE Transactions on Device and Materials Reliability*, 2004.
- [4] "Iso 26262-[1-10], road vehicles functional safety," 2011.
- [5] C. He et al., "Wafer level stress: Enabling zero defect quality for automotive microcontrollers without package burn-in," in *IEEE International Test Conference (ITC)*, 2020.
- [6] S. M. Thatte et al., "Test generation for microprocessors," IEEE Transactions on Computers, vol. C-29, no. 6, pp. 429–441, 1980.
- [7] D. Brahme et al., "Functional testing of microprocessors," IEEE Transactions on Computers, vol. C-33, no. 6, pp. 475–485, 1984.
- [8] D. Appello et al., "System-level test: State of the art and challenges," in *IEEE IOLTS*, 2021.
- [9] G. Squillero, "MicroGP—An Evolutionary Assembly Program Generator," *Genetic Programming and Evolvable Machines*), 2005.

### **COVER LETTER for PhD FORUM**

| First name                      | Andrea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Last name                       | Calabrese                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| Affiliation                     | Politecnico di Torino                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| E-mail                          | and rea. calabrese@polito.it                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Phone number                    | 3393944747                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| Proposed PhD thesis title       | New programming paradigms for optimization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| Start PhD date                  | November 2020                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Expected End PhD date           | February 2024                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Type of PhD topic <sup>1</sup>  | Applied research                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Collaborators <sup>2</sup>      | Politecnico di Torino                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| PhD motivation <sup>3</sup>     | I was always passioned about computer. First, I started playing<br>videogames, then I started being interested in the mechanisms behind<br>them.<br>Later, I became interested in parallel algorithms and GPU, on which I<br>worked during the thesis. It felt natural, then, to prosecute the work of                                                                                                                                                                                                                                                                                                     |  |  |  |
|                                 | my master thesis to the Ph.D., looking for opportunities to both provide<br>an improvement on the current algorithms and provide a concrete<br>usefulness to my research activity.                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Scientific results <sup>4</sup> | <ul> <li>D. Appello <i>et al.</i>, "Accelerated Analysis of Simulation Dumps through Parallelization on Multicore Architectures," <i>2021 24th International Symposium on Design and Diagnostics of Electronic Circuits &amp; Systems (DDECS)</i>, Vienna, Austria, 2021, pp. 69-74, doi: 10.1109/DDECS52668.2021.9417048.</li> <li>Quer, S.; Calabrese, A. Graph Reachability on Parallel Many-Core Architectures. <i>Computation</i> <b>2020</b>, <i>8</i>, 103.<br/>https://doi.org/10.3390/computation8040103</li> <li>E. Angione <i>et al.</i>, "An inpovative Strategy to Quickly Grade."</li> </ul> |  |  |  |
|                                 | Functional Test Programs," <i>2022 IEEE International Test</i><br><i>Conference (ITC)</i> , Anaheim, CA, USA, 2022, pp. 355-364, doi:<br>10.1109/ITC50671.2022.00044.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                                 | D. Appello <i>et al.</i> , "Parallel Multithread Analysis of Extremely Large Simulation Traces," in <i>IEEE Access</i> , vol. 10, pp. 56440-56457, 2022, doi: 10.1109/ACCESS.2022.3177613.                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                                 | Calabrese, Andrea, Stefano Quer, and Giovanni Squillero. "Smart Techniques for Flying-probe Testing." <i>ICSOFT</i> . 2021.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |

<sup>1</sup> e.g., Applied research/ R&D, fundamental research, etc.
<sup>2</sup> e.g., university, industry, research centre, etc.
<sup>3</sup> explain why you have decided to pursue a PhD and why in this topic.

<sup>4</sup> provide a list of scientific outputs and innovations (accepted, submitted, expected) including: Patents, Books/ book chapters, Journal papers, Conference papers, Workshop papers etc.