## POLITECNICO DI TORINO Repository ISTITUZIONALE

### A Zero-Timing Overhead SET Mitigation Approach for Flash-based FPGAs

Original

A Zero-Timing Overhead SET Mitigation Approach for Flash-based FPGAs / Azimi, Sarah; Du, Boyang; Sterpone, Luca. - ELETTRONICO. - (2018). (Intervento presentato al convegno IEEE Radiation and its Effects on Component and Systems - RADECS 2018 tenutosi a Gothenburg- Sweden nel 16-21 September 2018) [10.1109/RADECS45761.2018.9328665].

Availability: This version is available at: 11583/2710093 since: 2022-04-13T15:47:16Z

Publisher: IEEE

Published DOI:10.1109/RADECS45761.2018.9328665

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

©2018 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)

# A Zero-Timing Overhead SET Mitigation Approach for Flash-based FPGAs

Sarah Azimi, Boyang Du, Luca Sterpone

Dipartimento di Automatica e Informatica Politecnico di Torino Torino, Italy

*Abstract*—Mitigation techniques for SET effects introduce severe timing penalties to the hardened circuit. In this paper, we develop a new SET mitigation approach not introducing timing degradation. Experimental results on Flash-based FPGAs demonstrate its effectiveness.

*Key words*—Flash-based FPGAs, Transient effects, Multiple Event effects.

#### I. INTRODUCTION

A DVANCED digital circuits play an important role in a growing number of applications. When used in mission critical application, digital circuits require a special attention to the dependability aspect. In fact, one of the most critical environment aspects that could lead to the failure of modern integrated technologies and systems is radiation. When a charged particle hits the target device, it may cause a voltage glitch, i.e. Single Event Transient (SET), in the circuit when can then propagate as a normal signal. During the propagation of SET, if it reaches a memory element, e.g. Flip Flop or Memory, depending on the arrive time and duration of the SET pulse, it may be sampled and corrupting the data stored inside.

Considering the reprogrammable devices such as Flashbased FPGAs, device technology scaling makes them more prone to be affected by a charged particle [1]. The increasing of clock frequency demanded by complex designs also increases the probability of SET be sampled, making situation even worse. Therefore, study, analysis and mitigation of SET phenomena have attracted a lot of attentions in recent years.

Several studies have been dedicated to the analysis of SET propagation. Most of those studies focus on electrical modeling where physical simulation allows to characterize and validate the propagation of SET pulse shape [2]. However, electrical modeling did not take into account the broadening/filtering effect of the SET pulse traversing logics and routing known as Pulse Induced Propagation Broadening (PIPB) [13]. In addition, these approaches are time consuming, which cannot be directly applied in an industrial design flow.

On the other hand, several mitigation solutions have been proposed in the past. Mitigation solutions based on filtering structure insertion have been proposed [3], which are effective against SET, but also introduce heavy performance and hardware resource overhead. There are mitigation solutions based on modification of physical layout or re-timing of the routing without modification of the placement of combinational gates or FFs. However, these solutions require the reconfiguration of the resources which means the modification of logic and routing segment, affecting the overall circuit performances.

This work presents a new design flow based on charge sharing gate insertion into the circuit netlist able to decrease the sensitivity of nodes w.r.t. the SET pulse propagation. The main contribution consists on the first approach able to implement SET on Flash-based FPGAs without any timing penalty. The effectiveness of the proposed algorithm has been evaluated on several benchmark circuits by means of SET fault injection using a Flash-based FPGA development board and an improvement of resiliency of 4 times with respect to state of the art solution can be observed. Furthermore, the experiments show that circuit mitigated with our approach do not have any timing degradation.

The paper is organized as follows: Section II provides an overview of the related works; Section III presents the proposed methodology for mitigation without timing penalty. Section IV presents the experimental results. Finally, conclusions and future works are discussed in Section V.

#### II. RELATED WORKS

Many works have been investigating SET effects in digital circuits. For the studies carried out with Flash-based FPGA as target device, since the Flash-based configuration cells are immune to bit-flips when struck by charged particles, SET in user logic and routing resources is the main focus. Characterizations of radiation induced SETs in different circuits in order to identify the type of SET generated within the silicon structure of Flash-based FPGA regarding various radiation sources have been carried out [6][7]. Further studies focusing on the SET influence on the logic and routing structure demonstrated the efficiency of the mitigation of SET based on electrical filtering [8]. There are also studies reporting radiation test experiments and electrical fault injections of SET propagation on custom circuits designed specifically to observe SETs [9]. In [14], authors proposed internal electrical injection approach to analyze the SET phenomena regarding propagation characteristics when traversing through logics and routing.

Meanwhile, several SET mitigation solutions have been proposed. One traditional method is redundancy based such as Triple Modular Redundancy (TMR) [10], along with some other techniques using time or spatial redundancy [11]. However, since methods based on replication fundamentally introduces significant resource and performance overhead, methods perform sensitivity analysis of the circuits and applied mitigation to the identified sensitive nodes and selectively mitigate them [12] have been proposed. However, timing overhead is still a critical issue for this kind of solutions.

#### **III. PROPOSED DESIGN FLOW**

To mitigate the SET induced by radiation particles striking silicon structure of Flash-based FPGA devices, the proposed design flow is illustrated in Fig. 1.



Figure 1. Overview of the developed flow including SET analysis and charge sharing mitigation.

The flow from the output files from starts commercial/standard FPGA design flow, which includes the Post-Layout Netlist, SDF and the Physical Design Constraints (PDC). First, the Post-Layout Netlist is converted to a format designed in-house named Physical Design Description (PDD) file which stores the circuit in a graph representation; then with the timing information extracted from the SDF and the placement information within the PDC, the SET Analyzer tool SETA [17] is executed, generating a SET report which contains the information regarding SET sensitivity for each Flip-Flop in the design, the worst case SET pulse width taking into account the PIPB effects and so on; finally, the zero-timing SET mitigation algorithm, illustrated in Fig. 2, is executed to generate the final SET mitigated design. Please note that the SET mitigation step can be carried out with extra user constraints declaring specifically to include or exclude certain part of the design for charge sharing structure insertion.

For nanometer Flash-based FPGAs, the decreasing size of device nodes results in higher probability of charge collection in multiple logic switches when a single particle strike the device. This phenomena results in different transient pulse shapes related to the LET absorbed by the switch junction. The key idea of the mitigation algorithm relies on insertion of extra charge sharing structures into the design so to reduce the possible SET pulse amplitude and width when it traverse the logic paths.

Since the insertion of charge sharing structures increases the fan-out of the selected nodes, the algorithm also controls the threshold for insertion to avoid introduce extra delay in the path, i.e. performance degradation. This has been done by exploiting the lower buffering threshold level provided in FPGA routing node: if the fan-out is below that threshold, the delay of the traversing signal is not affected. Instead, the added charge sharing structure will reduce the PIPB effect thus nullifying the SET effect before reaching a memory element (e.g., Latch, Flip-Flop or IO block).

```
//Initialization Phase
Netlist<sub>orig</sub> = Verilog_load();
Netlist<sub>sol</sub> = {0};
∀ Node n ∈ Netlist<sub>orig</sub> -> PIPB [node] = SET_Report[n];
\forall Path p \in \{FF_I, FF_o\} \rightarrow RC_{node}(p) = \{0\};
//1. RC load computation
\forall n \in P do
   for i \in output_nets(n)
     if i is not buffered
        N<sub>NB</sub>(i) = Time_Unbuffered(n, Netlist<sub>orig</sub>);
     else
        NBU(i) = Time_Buffered(n, Netlistorig);
   RC_{node}(n) = (\sum N_{NB}(i) + N_{BU}(i))/Fan_out(n);
//2. Charge Sharing Computation
\forall \text{ Node } n \in \text{ Netlist}_{\text{orig }} \rightarrow \text{ CS [node] = } \{0\};
V_{path}[n] = \{0\};
for p \in P : CS[node] = V_{\text{path}}
  \forall n \in P \rightarrow G(n) = interpolate(PIPB[n], RC_{node}[n]);
  PIPBmin = Max(PIPB(p));
  H_{min} = Max(RC_{node}(p));
   for i \in n generate binary permutation S
     H = card(G(n));
     PB = global_PIPB(p,S);
     If PB < original_PIPB(p) && H <= original_card(p)</pre>
         H_{min} = H; V_{path} = S;
//3. Modify Netlist
∀ Node n ∈ Netlist<sub>orig</sub>
    Netlist<sub>sol</sub> = add_CS_structure(V<sub>path</sub>);
//4. Export Verilog netlist
Export_Verilog(Netlist<sub>sol</sub>);
```

Figure 2. The Charge sharing mitigation algorithm for Flash-based FPGAs.

The mitigation algorithm starts with loading the Post-Layout Netlist and the SET report generated by the SETA tool. The mitigation is performed in three phases:

- 1. It computes the Resistive Capacitive (RC) load for each circuit node within the original netlist. The computation is done adding the timing of buffered or un-buffered nets connected to the output pins of a considered node. The coefficient of the RC load is obtained dividing the timing by the fan-out of each node.
- 2. It selects the suitable nodes for the logic charge sharing insertion. The selection is done by interpolating the PIPB values considering the original RC load and obtaining the expected size of charge sharing structure for each node in terms of number of gates. The selection of the node where to apply charge sharing gates is determined by combinational permutation identifying the solution that minimize the PIPB effect while limiting overall number of added gates per circuit logical path. In Fig. 3, it reports an example of interpolation data, where it is possible to notice that when charge sharing structure contains less than 40 gates it is possible to achieve a reduction of the PIPB coefficient, i.e. filtering of SET, without affecting the timing characteristics of the node.
- 3. It modifies the netlist adding charge-sharing structure of proper size to the selected logic nodes. Finally, the

algorithm exports the modified netlist and placement constraints file. The two files then can be imported in the commercial FPGA design flow to generate the final design implementation.



Figure 3. Charge sharing number of gates per logic nodes with respect to the routing delay and PIPB coefficient.

An example of the application of charge sharing mitigation algorithm is illustrated in Fig. 4. In details, considering the original netlist A where three SETs pulses having width of 0.3, 0.6 and 0.8 ns can broaden up to 0.38, 0.81 and 1.08 ns since PIPB coefficients of all gates are positive. Considering the application of the charge sharing structure at the netlist B, an electrical masking or reduction of all the SET pulses is noticeable.

#### IV. EXPERIMENTAL RESULTS

The proposed design flow has been experimentally evaluated by means of SET static analysis and electrical injection platform [15] using an A3P250 Flash-based FPGA manufactured by Microsemi having 6,144 logic VersaTiles. We used the Libero SoC commercial design flow to generate the PDC, SDF and Post-Layout netlist in Verilog for evaluating the mitigation algorithm. Several circuits with different complexities have been selected: 4 circuits from the ITC'99 benchmark collection [4], a Cordic core and a RISC microprocessor [5]. The characteristics of the original circuits without any mitigation approach are reported in Table I indicating the number of VersaTiles configured as Logic function or Flip-Flop and the maximal working frequency.

We analyzed the circuits SET sensitivity using the SETA tool, for the purpose of our experiments, considering three types of SETs (0.3, 0.6 and 0.8 ns). Please note that SET width lower than 1 ns corresponds to the most probable events generated by heavy ion strike on the Flash-based FPGA 130 nm technology [11]. The analysis results are reported in Table II indicating the number of FF in following categories:

- 1. *logical masked*: no SET in the input cone could reach the FF due to logic mask;
- 2. *filtered*: no SET in the input cone are totally filtered;
- 3. *partially filtered*: SET in input cone could reach the FF but with a reduced width;

4. *broadened*: SET in the input cone could reach the FF with a broadened width.



Figure 4. The key concept of the Charge Sharing mitigation algorithm.

TABLE I CHARACTERISTICS OF THE ORIGINAL BENCHMARK CIRCUITS Versatile FFs Frequency Circuits [#] [#] [MHz] B05 415 47 66 B09 493 67 46 B12 565 123 48 B13 162 50 52

TABLE II COMPREHENSIVE FF SET SENSITIVITY USING THE STATIC ANALYSIS TOOL

240

1,156

45

42

956

1.401

CORDIC

RISC

|         | SET width lower than 1 ns |          |           |           |  |
|---------|---------------------------|----------|-----------|-----------|--|
| Circuit | Logical                   |          | Partially |           |  |
| Circuit | Masked                    | Filtered | Filtered  | Broadened |  |
|         | [#]                       | [#]      | [#]       | [#]       |  |
| B05     | 46                        | 9        | 3         | 8         |  |
| B09     | 47                        | 3        | 6         | 11        |  |
| B12     | 102                       | 1        | 7         | 13        |  |
| B13     | 21                        | 14       | 8         | 7         |  |
| CORDIC  | 161                       | 12       | 28        | 39        |  |
| RISC    | 572                       | 204      | 184       | 196       |  |

Furthermore, two versions of circuits with SET mitigation solutions have been generated: 1) place and route and guardgate techniques proposed in [16] using a maximal guard-gate filtering of 1ns, noted as P&R-GG; 2) proposed method, without excluding FFs in the design during SET mitigation. Please note that for both versions, Synopsys Synplify TMR has been applied exclusively on the FFs as in real design, mitigation solutions for SEU would be usually adopted even SET is the main target in this work.

We used the electrical pulse injection platform to inject in random sensitive nodes of the circuits. We injected 5,000 SETs lower than 1 ns for each circuit and report the results in Table III where we show the percentage of *wrong answers*, when the circuit produces at least one output data different from the expected one. It is possible to observe that by applying our method, the percentage of wrong answers decrease drastically, with an noticeable improvement comparing the results achieved with the solution [16].

|                                              |         | IABI              |      |          |  |  |  |  |
|----------------------------------------------|---------|-------------------|------|----------|--|--|--|--|
| SET FAULT INJECTION WRONG ANSWERS COMPARISON |         |                   |      |          |  |  |  |  |
|                                              |         | Wrong Answers [%] |      |          |  |  |  |  |
|                                              | Circuit | Plain             | P&R- | Proposed |  |  |  |  |
|                                              |         |                   | GG   | Method   |  |  |  |  |
|                                              | B05     | 68.5              | 12.2 | 4.3      |  |  |  |  |
|                                              | B09     | 72.6              | 8.4  | 2.6      |  |  |  |  |
|                                              | B12     | 83.2              | 9.4  | 3.1      |  |  |  |  |
|                                              | B13     | 54.8              | 16.5 | 4.1      |  |  |  |  |
|                                              | CORDIC  | 89.4              | 19.6 | 4.3      |  |  |  |  |
|                                              | RISC    | 94.6              | 21.6 | 4.8      |  |  |  |  |

In Table IV, it reports the timing and area overhead, in terms of max frequency degradation percentage and number of VersaTiles respectively, of the two SET mitigation solutions against original version. As can be observed, there is no timing overhead while the area overhead is slightly less than the P&R-GG method.

TABLE IV

| TIMING AND AREA OVERHEAD FOR EACH METHOD |                    |     |     |     |     |        |      |
|------------------------------------------|--------------------|-----|-----|-----|-----|--------|------|
| Circuit                                  |                    | B05 | B09 | B12 | B13 | CORDIC | RISC |
| ming<br>[%]                              | P&R-GG             | 12  | 13  | 15  | 16  | 19     | 18   |
| Timing<br>[%]                            | Proposed<br>Method | 0   | 0   | 0   | 0   | 0      | 0    |
| sa<br>]                                  | P&R-GG             | 27  | 28  | 28  | 27  | 32     | 31   |
| Area<br>[#]                              | Proposed<br>Method | 25  | 27  | 25  | 24  | 28     | 27   |

#### V. CONCLUSIONS AND FUTURE WORKS

In this paper, we present a mitigation approach for SET affecting Flash-based FPGAs, which is capable to drastically reduce the sensitivity against SET without affecting the timing of the implemented circuit and lower area overhead comparing to previously proposed method. The developed solution has been validated with electrical fault injection of SET pulses typical for device under heavy ion strikes.

As future research, we plan to evaluate the power consumption overhead and more resources are introduced into the circuit increasing dynamic power consumption; secondly, we plan to perform radiation test analysis and to address the recent fourth generation of Flash-based FPGAs.

#### VI. ACKNOWLEDGMENTS

The authors would like to thank Luca Cattaneo, Ken O'Neill and J.J. Wang from Microsemi for their valuable technical discussions and support of boards and Microsemi Flash-based FPGA devices. A special thanks to David Merodio Codinachs

#### REFERENCES

- A. Dixit, A. Wood, "The impact of new technology on soft error rates", IEEE International Reliability Physics Symposium, 2011, pp. 5B.4.1-5B.4.7.
- [2] M. Arevalo-Garbayo, M. Portela-Garcia, M. Garcia, M. Garcia- Valderas, C.Lopes-Ongil, L.Entrena, "C-Element model for SET fault emulation", 14<sup>th</sup> Radiation and Its effects on Components and Systems (RADECS), 2013, pp. 1-4.
- [3] Y. Lien, L. He, "Device and architecture concurrent optimization for FPGA transient soft error rate", IEEE/ACM International Conference on Computer-Aided Design, 2007, pp. 194-198.
- [4] F. Corno, M.S. Reorda, G. Squillero, RT-level ITC'99 benchmarks and first ATPG results. IEEE Des. Test COmput. 17 (3) (Jul/Sep 2000) 44-53.
- [5] www.opencores.org
- [6] J.J. Wang, S. Samiee, h.-s. Chen, C.-k. Huang, M. Cheung, J. Borillo, S.N. Sun, B. Cromquist, J. McCollum, "Total Ionizing Does effects on Flashbased Field Programmable Gate Array", IEEE Transaction on Nuclear Science. Vol. 51, no. 2, pp. 3759-3766, Dec. 2004.
- [7] L. Sterpone, S. Azimi, "Radiation-induced SET on Flash-based FPGAs: Analysis and Filtering methods", 30<sup>th</sup> International Conference on Architecture of Computing Systems (ARCS), pp. 1-6, June 2017.
- [8] S. Rezgui, J. J. Wang, E. Chan Ting, B. Cronquist, J. McCollum, "New Methodolgoies for SET characterization and mitigation in Flash-based FPGAs", IEEE Transaction on Nuclear Science, Vol.54, no. 6, pp. 2512-2524, 2007.
- [9] N. Battezzati, S. Gerardin, A. Manuzzato, A. Paccagnella, S. Rezgui, L. Sterpone, M. Violante, "On the evaluation of radiation-induced transient faults in Flah-based FPGAs", in Proc. 14<sup>th</sup> IEEE Int. On-Line Testing Symp (IOLTS), pp. 135-140, July 2008.
- [10] M. P. Baze, S. P. Buchner, D. McMorrow, "A digital CMOS design techniques for SEU hardening", IEEE Transactions on Nulclear Science, No. 6, pp.2603-2608, 2000.
- [11] Microsemi aa.vv, "Using Synplify to design in Microsemi radiationhardened FPGAs2", Application Note AC139, 2012, pp. 9.
- [12]L. Sterpone, S. Azimi, B. Du, D.Merodio-Codinachs, R. Grimoldi, "Effective mitigation of radiation-induced Single Event Transient on Flash-based FPGAs", 28<sup>th</sup> edition of the ACM Great Lakes Symposimum on VLSI (GLSVLSI), pp. 203-208, May 2017.
- [13]L. Sterpone, N. Battezzati, F. L. Kastensmidt and R. Chipana, "An Analytical Model of the Propagation Induced Pulse Broadening (PIPB) Effects on Single Event Transient in Flash-Based FPGAs," in IEEE Transactions on Nuclear Science, vol. 58, no. 5, pp. 2333-2340, Oct. 2011.
- [14]A. Evans, D. Alexandrescu, V. Ferlet-Cavrois, M. Nicolaidis, "New Techniques for SET Sensitivity and Propagation Measuremenr in Flashbased FPGAs", IEEE Transaction on Nuclear science, vol. 61, no. 6, pp. 3171-3177, Nov. 2014.
- [15]M. J. Gadlage, P. J. Eaton, J.M. Benedetto, M. Carts, V. Zhu, T. L. Turflinger, "Digital device error rate trends in advanced CMOS technologies," *IEEE Transaction on Nuclear Science.*, vol. 53, no. 6, pp. 3466-3471, Dec. 2006.
- [16] L. Sterpone, B. Du, "Analysis and mitigation of Single Event Effects on Flash-based FPGAs", 19<sup>th</sup> IEEE European Test Symposium (ETS), pp. 1-6, May 2014.
- [17] L. Sterpone, V. F. Cavrois, D. E. Codinachs, C. Poivey, "SETA: A new analytical tool for single event transient analysis on Flash-based FPGAs". In Conference on Radiation and Its Effects on Components and Systems (RADECS 2012).