

# **Characterization of Single Event Transient Effects in Standard Combinational Cells**

Marko Andjelkovic

24-26.10.2022, Granada, Spain 3<sup>rd</sup> ELICSIR Training School





innovations for high performance microelectronics



## **1** Motivation

- 2 Fundamentals of SET Effects
- **3** SET Characterization Methodology
- **4** SET Characterization for 130 nm Standard Cell Library
- 5 SET Sensitivity Models and SET Database
- 6 Conclusions

3



# 1 Motivation

- 2 | Fundamentals of SET Effects
- SET Characterization Methodology
- ) SET Characterization for 130 nm Standard Cell Library

) SET Sensitivity Models and SET Database

Conclusions

# ihp

# 1. Motivation

# Space radiation

- Galactic cosmic rays, Solar Particle Events and particles trapped in Earth's magnetic field
- Radiation intensity may vary by several orders of magnitude over hours or days
- Electronics employed in space should be tolerant to radiation-induced effects
  - Cumulative Effects (CEs)
    - ✤ Total Ionizing Dose (TID)
    - Displacement Damage (DD)
  - Single Event Effects (SEEs)
    - Soft SEEs data loss and temporary failures
    - Hard SEEs permanent failures



[Illustration from https://www.nasa.gov]



# 1. Motivation

# Soft SEEs (soft errors)

- Major reliability threat for CMOS integrated circuits (ICs) operated in space
- Caused by a single energetic particle (heavy ion, proton, neutron, electron)
- Manifested as unwanted bit-flips in data storage elements (flip-flops, latches, SRAM cells)

#### Two scenarios for soft error occurrence

- Particle strike in a storage element, resulting in a bit flip (<u>Single Event Upset – SEU</u>)
- Particle strike in a combinational gate, resulting in a voltage pulse (<u>Single Event Transient – SET</u>), which then propagates to a storage element





# 1. Motivation

# Technology scaling effects

- Increase of total <u>Soft Error Rate (SER)</u> due to increase of IC complexity
- Soft errors have become relevant even for terrestrial safety-critical applications

# Contribution of SETs to the total SER of an IC increases with technology scaling

- Increase in operating frequency leads to an increase of SET latching probability
- Decrease in supply voltage leads to an increase of SET generation probability
- Decrease in logic path length leads to a decrease of logical and electrical masking probabilities



# 1. Motivation

# Soft-error-aware IC design

- Characterization and modeling of soft error effects at device, circuit and system levels
- Multi-level static and dynamic mitigation of soft error effects (radiation hardening by design)
- Online monitoring of soft errors (energetic particles) as a support for dynamic fault tolerance



elicsir



#### **Multi-level design flow**

3



# **1** Motivation

- Fundamentals of SET Effects
- SET Characterization Methodology
- ) SET Characterization for 130 nm Standard Cell Library

[SET Sensitivity Models and SET Database]

Conclusions



# **2. Fundamentals of SET Effects**

## SET generation

- Particle-induced current pulse results in a positive or a negative voltage pulse at the output of a gate
- Off-state transistors are most sensitive to particle strikes, due to existence of reverse-biased p-n junctions
- On-state transistors act as restoring elements, i.e., provide restoring current to counteract the particleinduced current
- One particle can hit multiple transistors, causing multiple SETs
- Typical SET pulse width from tens to hundreds of picoseconds



# 2. Fundamentals of SET Effects

# SET propagation

- Due to masking effects, only a fraction of gates in a circuit may cause soft errors
  - Electrical masking (SET suppression)
  - Logical masking
  - Temporal masking
- Propagation-induced pulse broadening (PIPB)
  - The SET pulse may be broadened during propagation through certain paths
- Propagation-induced SET multiplication
  - A single SET may result in multiple SETs due to branching







#### Metrics for quantifying the SET sensitivity of a gate, circuit or system

- Critical charge (threshold LET): minimum charge (LET) which causes a voltage pulse with amplitude beyond the half of supply voltage
- Generated SET pulse width: width of SET pulse generated at the output of a logic gate
- > Propagated SET pulse width: width of SET pulse after propagation through a gate or path
- Soft Error Rate (SER): number of errors in a given time interval (overall SET sensitivity)

#### SET sensitivity is affected by numerous parameters

- > Design parameters: target gate type and size, load gate type and size, circuit structure
- Operating parameters: input logic levels, supply voltage, temperature
- Radiation parameters: charge (LET), angle and position of particle strike
- > Technology parameters: doping profiles, device geometry
- Other reliability mechanisms: aging, manufacturing defects, process variations

2. Fundamentals of SET Effects

induced by SETs in a given time interval

$$SER = \sum_{i=1}^{N} SER_{NOMINAL}(i) \cdot SER_{DERATING}(i)$$

N = number of components in the system

$$SER_{NOMINAL} = k \cdot Flux \cdot Area \cdot e^{-\frac{Q_{CRIT}}{Q_S}}$$

 $SER_{DERATING} = Logical_{DER} \cdot Electrical_{DER} \cdot Timing_{DER}$ 

www.ihp-microelectronics.com I **CSIT**pr

12



3



# 1 Motivation

- [] Fundamentals of SET Effects
  - SET Characterization Methodology
  - SET Characterization for 130 nm Standard Cell Library

SET Sensitivity Models and SET Database

Conclusions

# ibp

# **3. SET Characterization Methodology**

#### Joint characterization of SET sensitivity of <u>standard cells</u> and their <u>hardened variants</u>:

- Analysis of the SET sensitivity metrics for standard cells in terms of contributing parameters
- SPICE-based simulations
  - Two current models for SET generation
  - Voltage pulse model for SET propagation
- Fitting models for SET sensitivity metrics based on the sum of contributions
  - Contribution of each parameter can be assessed
- Model parameters (instead of raw simulation data) are stored in LUTs
  - Reduction in memory size and analysis time





# **3. SET Characterization Methodology**

SET generation setup

- Successive injection of current pulse in sensitive nodes of a target gate
- Analysis of critical charge and generated SET pulse width

#### SET propagation setup

- Propagation of voltage pulse through a target gate
- Analysis of the change of pulse amplitude and width



## SET current models: Double-exponential current model

- Most widely used SET current model
- > Defined with 3 parameters: collected charge, rise time and fall time



$$I_{DEXP}(t) = \frac{Q}{\tau_{fall} - \tau_{rise}} \left( e^{\frac{-t}{\tau_{fall}}} - e^{\frac{-t}{\tau_{rise}}} \right)$$

$$Q = \text{collected charge} = 1.035 \times 10^{-2} \times l \times LET$$

$$\tau_{fall} = \text{fall time of current pulse (tens of ps)}$$

$$\tau_{rise} = \text{rise time of current pulse (hundreds of ps)}$$

$$l = \text{charge collection depth (several } \mu\text{m})}$$





#### SET current models: Limitation of double-exponential current model

- > Cannot reproduce current pulse with plateau, caused by high charge (LET) values
- Overdrive effect: results in unrealistic SET voltage pulse for high charge (LET) values, exceeding supply rails





#### SET current models: Bias-dependent current model

- Resolves the overdrive effect inherent in double-exponential current model
- Good agreement with TCAD simulations
- Composed of double-exponential current source I<sub>DEXP</sub> and two voltage-dependent current sources G<sub>SEE</sub> and G<sub>REC</sub>



```
**********Bias Dependent SET Model*****
.subckt Bias_Dep_SET n p see_tau1=0.5e-12 see_tau2=70e-12
+ see_start_time=1e-6 see_duration=1.5e-12 see_let=40 see_col_len=1.5e-6
+ see recomb=1E11
.param F=0.05 CS=1e-9
.param IMAX='(see_let*1.035E-2*see_col_len*1E6*1E-12)/((see_duration +
+ see_tau2 - see_tau1)-(see_tau2-see_tau1)*exp(-1*(see_duration/see_tau1)))'
.param DELAY='see_start_time+see_duration'
* IMAX from equation in Massengill 1993 IEEE NSREC Short Course
   see_let = LET Value in MeV-cm^2/mg
   1.035E-2 is constant to go from LET to pC/um
   see_col_len is the collection length in meters
   1E6 converts to micro-meters
   1E-12 converts to Coulombs
 The following components represent the items in the schematic representation
   presented in the above referenced IEEE TNS paper
CHOLD VC 0 'CS'
IEXPSEE 0 VC EXP (0 IMAX see_start_time see_tau1 DELAY see_tau2)
GRECOMB VC 0 CUR='V(VC)*CS*see_recomb'
GSEE VC 0 CUR='V(VC)*(CS/see_tau1)*(1.0/(1.0+\exp((V(p)-V(n)+3*F)/F))))
GSEEP n p CUR='V(VC)*(CS/see_tau1)*(1.0/(1.0+\exp((V(p)-V(n)+3*F)/F))))
.ends Bias_Dep_SET
```

J. S. Kauppila et al., PhD Thesis, Vanderbilt University, 2015.

# Outline





roiect

# Critical charge Q<sub>CRIT</sub> (for INV, input 0)

- > Q<sub>CRIT</sub> is linearly proportional to timing parameters of current pulse
- > Q<sub>CRIT</sub> increases (mostly linearly) with the size of target gate and load gate
  - Larger gates have higher driving strength and higher capacitance





Higher supply voltage

**Critical charge Q**<sub>CRIT</sub> (for INV, input 0)

Lower temperature •••

-INV x1

40

Change of critical charge (fC) Change of critical charge (fC) Load gate = INV x1 12 INV x2 V<sub>DD</sub> = 1.2 V 20 📥 INV x4 0 -20 0 Nominal supply -4 voltage (1.2 V) -40 Nominal temp. (27 °C) -8 -60 -12 -16 -80 -80 -60 -0.4 -0.2 -0.1 0.0 0.1 0.2 .40 -20 -0.5 -0.3 Change of supply voltage (V) Change of temperature (°C)

4. SET Characterization for 130 nm Standard Cell Library

Driving current of restoring transistor increases

Load = INV x1

20 40 60

80

100 120

-INV x1

--- INV\_x2

📥 INV x4 

16



# Critical charge (for multi-input gates)

- Similar qualitative trends like for INV (mostly linear dependence of Q<sub>CRIT</sub> on size factor)
- Q<sub>CRIT</sub> for one input and large size factor may be similar as for lower size factor and another input
- > Q<sub>CRIT</sub> values can be sorted into several groups (allows for reducing the number of simulations)



| Input levels | Qcrit (fC) for NAND3 |           |       |  |  |  |  |  |  |
|--------------|----------------------|-----------|-------|--|--|--|--|--|--|
|              | x0                   | <b>x1</b> | x2    |  |  |  |  |  |  |
| 000          | 61                   | 111       | 220   |  |  |  |  |  |  |
| 001          | 46.2                 | 81.2      | 153.3 |  |  |  |  |  |  |
| 010          | 46.3                 | 80.3      | 152.8 |  |  |  |  |  |  |
| 011          | 30                   | 49.3      | 87.5  |  |  |  |  |  |  |
| 100          | 46.9                 | 82.4      | 154.6 |  |  |  |  |  |  |
| 101          | 31                   | 50.3      | 90.3  |  |  |  |  |  |  |
| 110          | 31                   | 50.3      | 89.8  |  |  |  |  |  |  |
| 111          | 26.9                 | 39.3      | 63.4  |  |  |  |  |  |  |



#### **Generated SET pulse width** (for INV, input 0)

www.ihp-microelectronics.com

- SET pulse width increases with LET (amount of deposited charge)
- Increase of gate size reduces the SET pulse width
- Large load increases the SET pulse width for higher LET





#### Generated SET pulse width (for INV, input 0)

- T<sub>EMP</sub> decrease leads to a decrease of SET pulse width
- V<sub>DD</sub> increase leads to a decrease of SET pulse width





# Generated SET pulse width - comparison

- > SET pulse width may vary by at least 2 times depending on gate type
- > Standard delay cells (SDC) based on skew-sized transistors are most sensitive to SETs



Initial SET pulse width (T\_IN)

C<sub>1</sub>

SET pulse propagation

Particle strike

O

 $\geq$ 

**elics F**project

 $T_OUT = T_IN + c_1 + c_2 + c_3$ 

**Final SET pulse** 

width (T OUT)

Clk

D

CLK

C

C3

26



An SET will propagate through a gate only if its width is larger than the propagation delay

An SET will generate a soft error only if its width is larger than the sum of setup and hold

 $C_2$ 



# SET pulse propagation (through individual cells)

- > Each cell broadends a pulse with one polarity, and shrinks a pulse with opposite polarity
- Driving strength influences the pulse broadening/shrinking





## SET pulse propagation (through individual cells)

More complex gates and gates with more inputs are better SET suppressors





# SET pulse propagation (through combinational paths)

- > Significant pulse broadening may occur accross very short non-inverting paths
- > Supply voltage and temperature corners may significantly contribute to pulse broadening

| 10 gata combinational naths  | Output pulse width (ps) |            |             |                               |     |     |  |  |  |  |
|------------------------------|-------------------------|------------|-------------|-------------------------------|-----|-----|--|--|--|--|
| (oll gates are with v1 size) | Positive                | input puls | se = 200 ps | Negative input pulse = 200 ps |     |     |  |  |  |  |
| (all gates are with XI Size) | LVT                     | TVT        | HVT         | LVT                           | TVT | HVT |  |  |  |  |
| INV                          | 208                     | 206        | 204         | 195                           | 196 | 197 |  |  |  |  |
| BUF                          | 367                     | 322        | 293         | 0                             | 68  | 108 |  |  |  |  |
| NAND2                        | 201                     | 201        | 201         | 203                           | 204 | 204 |  |  |  |  |
| AND2                         | 166                     | 152        | 134         | 237                           | 250 | 268 |  |  |  |  |
| NOR2                         | 223                     | 216        | 214         | 151                           | 176 | 185 |  |  |  |  |
| OR2                          | 925                     | 748        | 645         | 0                             | 0   | 0   |  |  |  |  |
| Alternating OR2 and AND2     | 542                     | 447        | 387         | 0                             | 0   | 0   |  |  |  |  |
| Alternating AND3 and OR4     | 499                     | 416        | 359         | 0                             | 0   | 0   |  |  |  |  |
| Alternating NAND2 and NOR3   | 667                     | 563        | 506         | 0                             | 0   | 0   |  |  |  |  |
| Alternating XNOR3 and NOR2   | 0                       | 0          | 0           | 173                           | 243 | 252 |  |  |  |  |

3



## **1** Motivation

- **2** Fundamentals of SET Effects
  - SET Characterization Methodology
    - SET Characterization for 130 nm Standard Cell Library
- **5** SET Sensitivity Models and SET Database

## Conclusions

# expressed as a sum of contributing functions

SET\_metric = SET\_metric\_nominal +  $\sum_{i=1}^{N} f_i \cdot (K_i - K_{iNOM})$ 

5. SET Sensitivity Models and SET Database

By fitting the simulation results, predictive SET sensitivity models can be

 $f_i$  = fitting function  $K_i$  = contributing parameter (e.g. size factor)

#### Critical charge model (8 fitting parameters per cell)

 $Q_{CRIT} = Q_{NOM} + f(S_T) + f(S_L) + f(C_L) + f(V_{DD}) + f(T_{EMP}) + f_{ERROR}$ 

Generated SET pulse width model (12 fitting parameters per cell)

 $T_{SET} = f(LET, S_T = 1) + f(S_T = n) + f(S_L, C_L) + f(V_{DD}) + f(T_{EMP})$ 

Propagated SET pulse width model (7 fitting parameters per cell)

 $T_{OUT} = T_{IN} \pm \Delta \tau = T_{IN} \pm c_0 \pm f(S_T) \pm f(C_L) \pm f(V_{DD}) \pm f(T_{EMP})$ 

Average relative error for each model (with respect to SPICE) is less than 5 %



# 5. SET Sensitivity Models and SET Database



#### Optimization of simulations and SET sensitivity database

- Due to similar SET sensitivity for multiple inputs, the number of simulations for SET generation can be reduced by almost 48 %
- By storing the model parameters in LUTs instead of simulation results, the number of stored values is reduced by 2 orders of magnitude



**elics**irproject

#### Model-based SET sensitivity database

|   | Critical charge model LUT |                      |                      |  |                                      |  |  |  |  |  |
|---|---------------------------|----------------------|----------------------|--|--------------------------------------|--|--|--|--|--|
|   |                           | Input 1              | Input 2              |  | Input 2 <sup>P</sup> - L             |  |  |  |  |  |
|   | <b>Q</b> <sub>NOM</sub>   | Q <sub>NOM</sub> (1) | Q <sub>NOM</sub> (2) |  | Q <sub>NOM</sub> (2 <sup>P</sup> -L) |  |  |  |  |  |
|   | <b>a</b> _0               | a <sub>0</sub> (1)   | a <sub>0</sub> (2)   |  | a <sub>o</sub> (2 <sup>P</sup> -L)   |  |  |  |  |  |
| • | <b>a</b> 1                | a1(1)                | a1(2)                |  | a1(2 <sup>P</sup> -L)                |  |  |  |  |  |
|   | a2                        | a2(1)                | a2(2)                |  | a₂(2 <sup>₽</sup> -L)                |  |  |  |  |  |
|   | <b>a</b> 3                | a <sub>3</sub> (1)   | a <sub>3</sub> (2)   |  | a₃(2 <sup>P</sup> -L)                |  |  |  |  |  |
|   | <b>a</b> <sub>4</sub>     | a4(1)                | a4(2)                |  | a <sub>4</sub> (2 <sup>P</sup> -L)   |  |  |  |  |  |
|   | <b>a</b> <sub>5</sub>     | a <sub>5</sub> (1)   | a <sub>5</sub> (2)   |  | a₅(2 <sup>P</sup> -L)                |  |  |  |  |  |
|   | <b>a</b> <sub>6</sub>     | a <sub>6</sub> (1)   | a <sub>6</sub> (2)   |  | a <sub>6</sub> (2 <sup>P</sup> -L)   |  |  |  |  |  |

#### www.ihp-microelectronics.com

# **5. SET Sensitivity Models and SET Database**



## SET sensitivity of each gate type can be represented with 3 look-up tables

- Critical charge LUT
- Generated SET pulse width LUT
- Propagated SET pulse width LUT

| Critical charge model LUT |                      |                      | Generated SET pulse width model LUT      |                       |                          |                          |  | Propagated SET pulse width model LUT |                       |                    |                    |  |                    |
|---------------------------|----------------------|----------------------|------------------------------------------|-----------------------|--------------------------|--------------------------|--|--------------------------------------|-----------------------|--------------------|--------------------|--|--------------------|
|                           | Input 1              | Input 2              | <br>Input 2 <sup>p</sup> - L             |                       | Input 1                  | Input 2                  |  | Input 2 <sup>P</sup> - L             |                       | Input 1            | Input 2            |  | Input P            |
| <b>Q</b> <sub>NOM</sub>   | Q <sub>NOM</sub> (1) | Q <sub>NOM</sub> (2) | <br>Q <sub>NOM</sub> (2 <sup>P</sup> -L) | LET <sub>DRIVE</sub>  | LET <sub>DRIVE</sub> (1) | LET <sub>DRIVE</sub> (2) |  | $LET_{DRIVE}(2^{P}-L)$               | <i>c</i> <sub>0</sub> | c <sub>o</sub> (1) | c <sub>o</sub> (2) |  | с <sub>0</sub> (Р) |
| ao                        | a <sub>0</sub> (1)   | a <sub>o</sub> (2)   | <br>a <sub>o</sub> (2 <sup>P</sup> -L)   | <b>b</b> <sub>0</sub> | b <sub>0</sub> (1)       | b <sub>0</sub> (2)       |  | $b_0(2^p-L)$                         | <b>C</b> <sub>1</sub> | c1(1)              | c1(2)              |  | c₁(P)              |
| a,                        | a1(1)                | a1(2)                | <br>$a_1(2^P-L)$                         | <b>b</b> <sub>1</sub> | b <sub>1</sub> (1)       | b1(2)                    |  | $b_1(2^p-L)$                         | <b>C</b> <sub>2</sub> | c <sub>2</sub> (1) | c <sub>2</sub> (2) |  | c <sub>2</sub> (P) |
| <i>a</i> ,                | a <sub>2</sub> (1)   | a <sub>2</sub> (2)   | <br>$a_{2}(2^{p}-L)$                     | <i>b</i> <sub>2</sub> | b <sub>2</sub> (1)       | b <sub>2</sub> (2)       |  | $b_2(2^p-L)$                         | C.                    | $c_{-}(1)$         | $c_{2}(2)$         |  | c_(P)              |
| <i>a</i> <sub>2</sub>     | a <sub>2</sub> (1)   | a <sub>2</sub> (2)   | <br>$a_{2}(2^{p}-L)$                     | <b>b</b> <sub>3</sub> | b <sub>3</sub> (1)       | b <sub>3</sub> (2)       |  | b₃(2 <sup>p</sup> − L)               | c3                    | $c_{3}(1)$         | c (2)              |  | $c_{3}(r)$         |
| 3<br>a                    | 3(-)<br>a (1)        | 3(-)                 | <br>$a_{3}(-2^{p}-1)$                    | <b>b</b> <sub>4</sub> | b <sub>4</sub> (1)       | b4(2)                    |  | $b_4(2^p-L)$                         | <b>c</b> <sub>4</sub> | $c_4(1)$           | $c_{4}(2)$         |  | $c_4(P)$           |
| u <sub>4</sub>            |                      | $u_4(2)$             | <br>$u_4(2 - L)$                         | <b>b</b> <sub>5</sub> | b <sub>5</sub> (1)       | b <sub>5</sub> (2)       |  | $b_5(2^p-L)$                         | <i>c</i> <sub>5</sub> | c <sub>5</sub> (1) | c <sub>5</sub> (2) |  | с <sub>5</sub> (Р) |
| <b>a</b> <sub>5</sub>     | a <sub>5</sub> (1)   | a <sub>5</sub> (2)   | <br>a <sub>5</sub> (2 <sup>r</sup> -L)   | <b>b</b> <sub>6</sub> | b <sub>6</sub> (1)       | b <sub>6</sub> (2)       |  | $b_6(2^p-L)$                         | <b>c</b> <sub>6</sub> | с <sub>6</sub> (1) | с <sub>6</sub> (2) |  | с <sub>6</sub> (Р) |
| <b>a</b> <sub>6</sub>     | a <sub>6</sub> (1)   | a <sub>6</sub> (2)   | <br>a <sub>6</sub> (2 <sup>p</sup> -L)   | <b>b</b> <sub>7</sub> | b <sub>7</sub> (1)       | b <sub>7</sub> (2)       |  | $b_7(2^P-L)$                         |                       |                    |                    |  |                    |
|                           |                      |                      |                                          | b <sub>s</sub>        | b <sub>8</sub> (1)       | b <sub>8</sub> (2)       |  | b <sub>8</sub> (2 <sup>P</sup> − L)  |                       |                    |                    |  |                    |
|                           |                      |                      |                                          | b <sub>g</sub>        | b <sub>9</sub> (1)       | b <sub>9</sub> (2)       |  | b <sub>9</sub> (2 <sup>p</sup> − L)  |                       |                    |                    |  |                    |

# Outline





roiect



- Characterization of SET effects in standard cells is initial step in the rad-hard design
- SET sensitivity of a logic gate in a given technology is strongly influenced by a combined impact of design, operating and irradiation parameters
- SET models are essential for simplifying the SER computation for a target circuit
- Major contributions:
  - Joint characterization of standard cells and their hardened variants
  - SET sensitivity models considering explicitly the parameters relevant for the design process, with the possibility to identify the impact of each parameter
  - Reduction of number of simulations and SET database

#### Future work:

- > Further improvement of SET models by considering additional parameters and effects
- Inclusion of SET models in a reliability-aware design flow



# Thank you for your attention!

Marko Andjelkovic

IHP – Innovations for High Performance Microelectronics Im Technologiepark 25 15236 Frankfurt (Oder) Germany Phone: +49 (0) 335 5625 527 Fax: +49 (0) 335 5625 413 Email: andjelkovic@ihp-microelectronics.com

www.ihp-microelectronics.com



https://elicsir.elfak.rs/



innovations for high performance microelectronics