

# SINGLE EVENT UPSETS (SEU) TEST REPORT

# Single-Event Upsets Characterization of the 28nm Kintex-7-based Programmable Logic of Xilinx Zynq-7000 FPGA

| Radiation Testing Date | 15 April 2019                                        |
|------------------------|------------------------------------------------------|
| Participants           | University of Piraeus/Embedded System Lab, ESA/ESTEC |
| DUT                    | Xilinx Zynq-7000 AP SoC XC7Z045-2FFG900              |
| Board                  | Xilinx ZC706                                         |
| Radiation type         | High Energy Heavy ions (Fe ions)                     |
| Accelerator            | GSI Helmholtz Centre for Heavy Ion Research          |
| Radiation source       | Energy: 230 MeV/c, effective LET 2.29 MeVcm2/mg      |
| Test type              | Single Event Upsets (SEUs)                           |

Reference: ESL-TR-1902

Version: 1.0

Date: 1 July 2019

Authors: Vasileios Vlagkoulis, Mihalis Psarakis (University of Piraeus)

## **Revision History**

| Version | Date        | Authors                  | Comments                 |
|---------|-------------|--------------------------|--------------------------|
| 1.0     | 1 July 2019 | V.Vlagkoulis, M.Psarakis | First release for review |

# Table of Contents

| 1.  | Scope                            |
|-----|----------------------------------|
| 1   | 1 Scope of the document          |
| 1   | 2 References                     |
| 2.  | Introduction7                    |
| 3.  | Test objectives                  |
| 4.  | Test facility7                   |
| 5.  | Test setup                       |
| 6.  | SEU characterization             |
| 6   | 1 Design under test (DUT) 10     |
| 6   | 2 Test flow 12                   |
| 7.  | Test results 14                  |
| 7   | 1 Post-processing software       |
| 7   | 2 SEU analysis                   |
|     | 7.2.1 CRAM testing               |
|     | 7.2.2 BRAM testing               |
|     | 7.2.3 Flip-Flop testing          |
|     | 7.2.4 Initial values analysis 19 |
| 7   | .3 MBU/MCU analysis              |
| APP | ENDIX: Test DUT                  |

# List of Figures

| Figure 1: Board under test (Xilinx ZC706)                                                 | 8              |
|-------------------------------------------------------------------------------------------|----------------|
| Figure 2: Test setup                                                                      | 9              |
| Figure 3: Photo of board under test                                                       | 9              |
| Figure 4: Test flow                                                                       | 13             |
| Figure 5: Cross section vs. LET                                                           | 19             |
| Figure 6: MCU patterns (unmasked bits)                                                    | 21             |
| Figure 7: MCU patterns (masked bits)                                                      | 21             |
| Figure 8: SRLs (LUTRAMs) – Configuration Memory mapping                                   | 22             |
| Figure 9: DUT for test setup - Communication between the Host PC and the DUT              | 23             |
| Figure 10: Zynq-7000 CLB architecture (all slices are connected in a row or a column fash | <b>ion)</b> 24 |
| Figure 11: Slice configuration as FF chains                                               | 25             |
| Figure 12: Slice configuration and routing                                                | 26             |
| Figure 13: BRAM configuration and connection in cascade mode                              | 27             |
| Figure 14: DSP slices configuration and connection in cascade mode                        | 27             |
| Figure 15: FPGA resource utilization and routing                                          | 28             |

# List of Tables

| Table 1: CUT - bits type details                               | 11 |
|----------------------------------------------------------------|----|
| Table 2: CUT – initial bit values                              | 12 |
| Table 3: CDUT – Essential bits                                 | 12 |
| Table 4: Execution time of FPGA Configuration access functions | 14 |
| Table 5: Test sessions                                         |    |
| Table 6: Configuration frame address fields                    |    |
| Table 7: Test Post-Processing Database fields                  | 15 |
| Table 8: CRAM Upsets in a frame                                |    |
| Table 9: CRAM SEUs                                             |    |
| Table 10: BRAM Upsets in a frame                               | 17 |
| Table 11: BRAM SEUs                                            | 17 |
| Table 12: FF + SRL Upsets in a frame                           | 17 |
| Table 13: FF + SRL Upsets & SEUs                               |    |
| Table 14: SEU according to bit flip type                       | 20 |
| Table 15: Likelihood to upset 0->1 : 1->0                      | 20 |
| •                                                              |    |

## 1. Scope

## **1.1 Scope of the document**

This document reports the results of the radiation testing of the 28nm Xilinx Zynq-7000 FPGA device with high-energy heavy ions (Fe) in the **GSI Helmholtz Centre for Heavy Ion Research**.

## **1.2 References**

- [1] Single-Event Upsets Characterization of the 28nm Artix-7-based Programmable Logic of Xilinx Zynq-7000 FPGA, SEU TEST REPORT, ESL-TR-1901, June 2019
- [2] Vasileios Vlagkoulis et al., "Analysis of the Single Event Upsets in the Programmable Logic of 28 nm Xilinx Zynq-7000 FPGA due to Heavy Ion Irradiation", Single Event Effects (SEE) Symposium and Military and Aerospace Programmable Logic Devices (MAPLD) Workshop, May 2019.
- [3] Amrbar, Mehran, et al. "Heavy ion single event effects measurements of Xilinx Zynq-7000 FPGA." 2015 IEEE Radiation Effects Data Workshop (REDW). IEEE, 2015.
- [4] Tambara, Lucas Antunes, et al. "Heavy ions induced single event upsets testing of the 28 nm xilinx zynq-7000 all programmable soc." 2015 IEEE Radiation Effects Data Workshop (REDW). IEEE, 2015.
- [5] Stoddard, Aaron, et al. "A hybrid approach to FPGA configuration scrubbing." IEEE Transactions on Nuclear Science 64.1 (2017): 497-503.
- [6] Furano, Gianluca, et al. "FPGA SEE Test with Ultra-High Energy Heavy Ions." 2018 IEEE International Symposium on Defect and Fault Tolerance in VLSI and Nanotechnology Systems (DFT). IEEE, 2018.
- [7] Yang, Weitao, et al. "Microbeam Heavy-Ion Single-Event Effect on Xilinx 28-nm System on Chip." IEEE Transactions on Nuclear Science 65.1 (2018): 545-549.
- [8] Xilinx, Inc. " 7 Series FPGAs Configuration: User Guide v1.13 (UG470)." (2018).
- [9] A. Sari, V. Vlagkoulis and M. Psarakis, "An Open-source Framework for Xilinx FPGA Reliability Evaluation", Workshop on Open Source Design Automation (OSDA) 2019, Florence, Italy, in conjunction with DATE 2019.
- [10] Markus Happe, Andreas Traber, and Ariane Keller. "Preemptive Hardware Multitasking in ReconOS." Applied Reconfigurable Computing – 11th International Symposium (ARC), Bochum, Germany, 2015.
- [11] Wirthlin, Michael, et al. "A method and case study on identifying physically adjacent multiple-cell upsets using 28-nm, interleaved and SECDED-protected arrays." IEEE transactions on nuclear science 61.6 (2014): 3080-3087.

# 2. Introduction

This document presents the **Single-Event Upsets (SEUs)** characterization of the **28nm Kintex-7based Programmable Logic (PL) of a Xilinx Zynq-7000** device due to heavy ion irradiation. All the embedded memories of the PL part of the Xilinx Zynq-7000 device, i.e. Configuration memory (CRAM), Block RAM (BRAM) and user Flip-Flops (FFs), are investigated.

The main target of the experiment is to complete the SEU characterization results reported in [1] for the Xilinx Zynq-7000 device. In [1] an Artix-7-based Xilinx Zynq-7000 device was studied while in the current experiment a Kintex-7-based Xilinx Zynq-7000 device. The purpose of both experiments is to record the Single Bit Upsets (SBUs) and Multiple Cell Upsets (MCUs) of the embedded memories of the PL part due to heavy ion irradiation and calculate their cross section.

A preliminary analysis of the experimental results has been presented in [2].

This work was partially funded by ESA/ESTEC under the purchase order N.5201016857.

## 3. Test objectives

The main purpose of the radiation test is to analyze in-depth the SEU vulnerability of the PL part of the Xilinx Zynq-7000 FPGA device under heavy ion irradiation and study the feasibility of using Xilinx Zynq-7000 in space applications.

The objectives of the radiation test are:

- i) Calculate the cross sections for all the different memory types of the PL part: CRAM, Flip-Flops (FFs), Shift Register LUTs (SRLs) and Block RAMs (BRAMs)
- ii) Calculate the cross sections for the essential bits of the CRAM, i.e. including only upsets in the essential bits of the CRAM. Essential bits are the device configuration bits associated with the circuitry of the design
- iii) Determine and analyze the Single Bit Upsets (SBUs) and the Multiple Cell Upsets (MCUs) in CRAM

# 4. Test facility

The radiation tests were performed in the GSI Helmholtz Centre for Heavy Ion Research under heavy ions (Fe) irradiation. The energy of the lead ions was 230MeV/u. The beam arrives at the facility in form of spills of 1s length, with a periodicity of ~3s. A beam size of ~31 mm × 31 mm was set, and the beam flux was around  $10^3$  ions/cm<sup>2</sup> per spill.

## 5. Test setup

The FPGA device under test (DUT) is the Xilinx Zynq-7000 SoC device. These devices integrate a processing system (PS) based on a single or dual-core ARM Cortex-A9 CPU and Xilinx programmable logic (PL) in a single device built on a 28nm, high-k metal gate process technology. The PL includes several different types of resources including among others: configurable logic blocks (CLBs), BRAMs, DSP slices, etc. The radiation tests have been performed in an Xilinx ZC706

(see **Figure 1**) which integrates an XC7Z045-2FFG900 Zynq-7000 APSoC device. The PL part of the Xilinx XC7Z045 device is derived from the Xilinx Kintex-7 series technology and is the main target of this study.



Figure 1: Board under test (Xilinx ZC706)

The test setup is shown in Figure 2:

- The Xilinx board is powered by an N6705 power supply which is remotely controlled by the Control Room Laptop 2 (CRL 2).
- The Xilinx board is connected through the JTAG port with the Beam Room Laptop (BRL), for bitstream configuration and readback purposes.
- The BRL is remotely controlled and monitored through Windows Remote Desktop by CRL 1.
- The BRL runs the test\_app. Test\_app performs FPGA configuration, data acquisition (FPGA readback capture) and logging. More information about the test application running in BRL is given in [1].
- All system clocks were synchronized before the tests with the facility's clock. All instruments' (PSU, BRL, CRLs) logs are time-stamped for post processing.



Figure 2: Test setup

Figure 3 photo depicts the Xilinx board connected in the beam room.



Figure 3: Photo of board under test

## 6. SEU characterization

The goal of this test is to study the upsets due to heavy ion irradiation in the embedded memories of a Kintex-7-based Xilinx Zynq-7000 device in order to enhance the radiation test results reported in [1] for an Artix-7-based Xilinx Zynq-7000 device. Last years, several studies of the radiation effects in Xilinx Zynq-7000 devices have been presented in the literature. These experiments have investigated the SEUs in the various memories of the device [3],[4],[5],[6], i.e. configuration memory (CRAM) and BRAM of the programmable logic (PL) and caches and on-chip memory (OCM) of the processing system (PS) or the SEE impact in the entire PS area [7]. In [1] we attempted to provide a deeper insight in the SEU vulnerability of the memories of the PL part of device. Therefore, the main differences of the current radiation experiments compared with the one performed in CERN [1] are:

- In CERN we studied an Artix-7-based Xilinx Zynq-7000 device (XC7Z020) while in the current experiment a larger Kintex-7-based Xilinx Zynq-7000 device (XC7Z045).
- In CERN the CRAM readback and reconfiguration tasks were performed during the beam idle periods in order to reduce the possibility to be affected by an SEU or SEFI in the CRAM access logic, while in the current experiment they can be executed anytime. In other words, the CRAM is readback regardless if the beam is off or on and it is re-written to remove upsets after a number of readbacks. This is because in CERN there was a sufficiently long idle period (e.g. 30s) between spills allowing the execution of readback/reconfiguration cycles while in GSI the time distance between spills was 2s.

## 6.1 Design under test (DUT)

A synthetic, parameterized benchmark has been designed for the purposes of the radiation tests.

- The FPGA DUT communicates with the BRL through the JTAG interface (use of BSCANE2 primitive) as shown in Figure 9 (The figures of Test DUT are included in Appendix).
- The DUT is not clocked during irradiation, so we can capture Single Event Upsets (SEUs) in the user memories of the PL part, i.e. BRAM, SRL and FFs using the Xilinx Readback Capture<sup>1</sup> command. Otherwise (i.e. if the CUT is clocked), upsets in user memory elements would be overwritten by normal circuit operation. Given that the clock is paused, any difference observed in the BRAM, SRL and FFs contents compared to their initial values can be caused by either an SEU in the configuration bits or a single event transient (SET) in the global signals (e.g. Clock or reset) of the corresponding CUT chains.
- All available slices, FFs, BRAMs and DSPs have been instantiated in the CUT as shown in Figure 10. Specifically:

<sup>&</sup>lt;sup>1</sup> There are two styles of readback: Readback and Readback Capture. During Readback, the configuration memory cells are read, including the current values on all user memory elements (LUT RAM, SRL, and BRAM). Readback Capture is a superset of Readback. In addition to reading all configuration memory cells, the current state of all internal CLB and IOB registers is read, storing all CLB and IOB register values into configuration memory cells. The register values are stored in the same configuration memory cell on which the corresponding register initial values have been programmed, thus sending the GRESTORE/GSR command to the FPGA configuration logic after the Readback Capture can cause registers to return to an unintended state [8].

- All slices are connected in long register chains (see Figure 11 and Figure 12).
  - The SLICEL LUTs are configured as route-through, the SLICEM LUTs are configured as 32-bit Shift Registers LUTs (SRLs) and LUT outputs are connected with CLB FFs to form long register chains.
  - The FFs are preloaded with alternate 0 and 1, while the SRLs with continuous 0s and 1s or alternate 0-1 patterns.
  - Register chain is not clocked (clock signal input is pulled down into the IOB), the CE signal of the FFs and SRLs is connected to '1' (through Routing Static Source HARD1 of the TIEOFF<sup>2</sup>) and the FFs reset or preset is configured to be asynchronous and pulled-down into the IOB (in CERN [1] the reset was synchronous); this means that transients in the clock and the reset/preset tree can be captured.
- All available BRAMs of the device are instantiated in the CUT (see Figure 13)
  - Initialized with a predefined pattern (to test SEUs in BRAMs), i.e. data are set to all 1s or all 0s or checkerboard values and parity bits to 0s
  - Cascaded through the Data Bus either horizontal (raw) or vertical (column).
  - BRAM chain is not clocked and the WREN/RDEN signals of the BRAMs are connected to '0' (pulled-down into the IOB); this means that upsets in the BRAMs due to transients in the clock tree are unlikely to happen.
- All available DSP slices of the device are instantiated in the DUT (see Figure 14)
  - Connected in cascade mode either horizontal (raw) or vertical (column) -configurable
  - Configured to implement multiply and accumulate (MAC) operation
  - DSP chain is not clocked.

The outcome is a highly utilized and densely routed design (100% slice, BRAM and DSP utilization) (see Figure 15). The following Tables presents details about the configuration bitstream of the CUT.

| Bit Type                                           | Number of Bits | %      |
|----------------------------------------------------|----------------|--------|
| Configuration bits (unmasked)                      | 71.017.108     | 66.65  |
| CLB FF bits (masked)                               | 437.200        | 0.41   |
| CLB SRL bits (masked)                              | 4.505.600      | 4.23   |
| Unknown masked bits                                | 661.116        | 0.62   |
| BRAM bits (masked)                                 | 20.090.880     | 18.85  |
| Other unused masked bits (PS area or dummy frames) | 9.843.904      | 9.24   |
| Total bits                                         | 106.555.808    | 100.00 |

#### Table 1: CUT - bits type details

<sup>&</sup>lt;sup>2</sup> The basic primitive in Xilinx FPGAs to supply VCC and GND signals to a design is the TIEOFF. The TIEOFF accompanies every switch matrix and has several connections to all sink connections to its neighboring logic tile (CLB, BRAM, DSP, etc). It has 2 pins, HADR0 (GND) and HADR1 (VCC).

| Bit Value                           | Number of Bits | %      |
|-------------------------------------|----------------|--------|
| Configuration bits (unmasked) zeros | 60.798.772     | 85.61  |
| Configuration bits (unmasked) ones  | 10.218.336     | 14.39  |
| Total Configuration bits (unmasked) | 71.017.108     | 100.00 |
| CLB FF bits (masked) zeros          | 218.600        | 50.00  |
| CLB FF bits (masked) ones           | 218.600        | 50.00  |
| Total CLB FF bits (masked)          | 437.200        | 100.00 |
| CLB SRL bits (masked) zeros         | 2.252.800      | 50.00  |
| CLB SRL bits (masked) ones          | 2.252.800      | 50.00  |
| Total CLB SRL bits (masked)         | 4.505.600      | 100.00 |
| BRAM bits (masked) zeros            | 11.489.280     | 57.19  |
| BRAM bits (masked) ones             | 8.601.600      | 42.81  |
| Total BRAM bits (masked)            | 20.090.880     | 100.00 |
| Unknown & Unused masked bits zeros  | 10.505.020     | 100.00 |
| Unknown & Unused masked bits ones   | 0              | 0.00   |
| Total Unknown & Unused masked bits  | 10.505.020     | 100.00 |

#### Table 3: CDUT – Essential bits

| Bit Type                         | Number of Bits | %      |
|----------------------------------|----------------|--------|
| Configuration Essential bits     | 31.295.881     | 44.07  |
| Configuration Non-Essential bits | 39.721.227     | 55.93  |
| Total Configuration bits         | 71.017.108     | 100.00 |
| CLB FF Essential bits            | 437.200        | 100.00 |
| CLB FF Non-Essential bits        | 0              | 0.00   |
| Total CLB FF bits                | 437.200        | 100.00 |

\* All the other bits (SRL, BRAM, unused) are non-essential bits

For test purposes an open-source platform has been developed [9]. The platform provides access to the FPGA configuration memory and circuit logic via the JTAG protocol. It provides a non-intrusive tool to perform various configuration memory functions, such as bitstream readback and verify, configuration frames/registers write and read, etc. For more information about the platform see [1].

### 6.2 Test flow

The test flow is shown in Figure 4.

It performs the following steps:

- 1. The board ZC706 is configured through the JTAG interface.
- 2. The BRL reads back the device configuration memory through JTAG using readback-capture and records the readback data. This step is used to record the CRAM configuration data and the content of user state elements (i.e. FFs); given that the CUT is paused during the test, any changes in their content would be due to upsets or SETs in the clock and reset signals (note that reset is asynchronous).

- 3. The BRL reads all the Configuration Registers according to Table 5-23 of [8] and records the data. This step is used to record the state of the FPGA Configuration Registers such Frame Address Register, Control Register, Status Register in order to find any abnormal register values during the test.
- 4. The steps 2 and 3 are repeated for N times (10 times for the current test).
- 5. The FPGA is reconfigured and the Configuration Registers are read in order to record their state after the reconfiguration. In case of success, the test goes to step (2). Otherwise, a power cycle (power-off and power-on) is executed and the test goes to step (1).

All the configuration memory write and readback operations are performed by Vivado TCL scripts using JTAG commands. Note that in contrast with the CERN test [1], the readback/ reconfiguration tasks are performed at any time of the experiment, i.e. regardless if the beam is off or on.



#### Figure 4: Test flow

The execution times of the FPGA configuration memory access functions (e.g. FPGA memory configuration, readback capture and read configuration registers) used in the test are presented in Table below.

| Configuration access function | Execution time (sec) |  |  |
|-------------------------------|----------------------|--|--|
| FPGA Configuration            | 5.00                 |  |  |
| Readback Capture              | 13.50                |  |  |
| Read Configuraton Registers   | 0.10                 |  |  |

#### Table 4: Execution time of FPGA Configuration access functions

Given that the irradiation period is approximately 3 secs (1 secs beam on, 2 secs beam off), the beam is active more than once (4 to 5 times) during the Readback Capture. This means that a Readback Capture records accumulated upsets, which include the upsets recorded by the previous Readback Capture and the upsets occurred during the last irradiation periods.

## 7. Test results

Test was performed for 0° angle of incidence with an effective LET of 2.29 MeVcm<sup>2</sup>/mg.

#### Table 5: Test sessions

| Duration       |              | Angle of                        | Fluence                |
|----------------|--------------|---------------------------------|------------------------|
| Start<br>(CET) | End<br>(CET) | incidence (θ)/<br>Effective LET | (ions/cm²)             |
|                |              | (MeVcm <sup>2</sup> /mg)        |                        |
| 15.04.19       | 15.04.19     | 0° / 2.29                       | 3.58 x 10 <sup>5</sup> |
| 18:06          | 18:46        |                                 |                        |

### 7.1 Post-processing software

The Zynq device is divided into two halves, the top and the bottom. All configuration frames in the device have a fixed, identical length of 3,232 bits (101 32-bit words). The configuration frame address is divided into five fields (**Table 6**).

| Table 6 | : Configuration | frame | address | fields |
|---------|-----------------|-------|---------|--------|
|---------|-----------------|-------|---------|--------|

| -              |           |                                                                     |
|----------------|-----------|---------------------------------------------------------------------|
| Address fields | Bit index | Description                                                         |
|                |           | 0: Interconnect & Block Configuration (CLB, IOB, DSP, CLK) and FF & |
|                |           | LUTRAM values                                                       |
|                |           | 1: BRAM content                                                     |
|                |           | 2: CFG_CLB                                                          |
|                |           | 3: Unknown type (a normal bitstream does not include this type)     |
| Block Type     | [25:23]   | 4: Unknown type                                                     |
|                |           | 0: Тор                                                              |
| Top/Bottom     | [22]      | 1: Bottom                                                           |
|                |           | Defines a row of the device. The row addresses start at 0 and       |
| Row Address    | [21:17]   | increment from center to top and from center to bottom              |
|                |           | Defines a column of the device. Column addresses start at 0 on the  |
| Column Address | [16:7]    | left and increase to the right                                      |
| Minor Address  | [6:0]     | Defines a frame within a column                                     |

Both the configuration bit file and the readback file (generated using Xilinx Readback commands) include the configuration frames with block type 0 and 1. Xilinx does not provide documentation for the block types 2, 3 and 4. In [10], it is mentioned that the CFG\_CLB block type 2 defines which part of the FPGA needs to be reset or reconfigured. It only appears in a partial bitstream, if the RESET AFTER RECONFIG attribute has been set for this region.

For the SEU/MCU analysis, a database with all the erroneous bits was created comparing the readback-capture files with the readback-capture golden files. For each bit difference between a readback-capture with the golden file, a database entry is created with the fields shown below. If an error recorded in the current readback-capture, it had been also recorded in the previous readback-capture cycle, then it is not stored in the database because it is an accumulated error. On the other hand, if a bit not be upset in the current readback-capture, it had been recorded as error in the previous readback-capture cycle, then it is stored as error in the database.

| Database fields  | Valid values           | Description                                                      |
|------------------|------------------------|------------------------------------------------------------------|
| Timestamp        |                        | The timestamp of the readback-capture file                       |
|                  |                        | Bit value of the golden file, e.g. if this bit is 0 then the bit |
| Golden Bit value | 0 or 1                 | is flipped from 0 to 1                                           |
| Frame Address    | 32 bit hex value       | Address of the configuration frame of the erroneous bit          |
|                  |                        | The value of the frame address bits [25:23]                      |
|                  |                        | 000: Interconnect & Block Configuration                          |
|                  | Interconnect & Block   | 001: BRAM Content                                                |
|                  | Configuration or Block | These block types are only included in the                       |
| Block Type       | RAM Content            | readback/readback capture files                                  |
|                  |                        | The value of the frame address bit 22                            |
|                  |                        | 0: Тор                                                           |
| Top/Bottom       | Top or Bottom          | 1: Bottom                                                        |
| Row Address      |                        | The value of the frame address bits [21:17]                      |
| Column Address   |                        | The value of the frame address bits [16:7]                       |
| Minor Address    |                        | The value of the frame address bits [6:0]                        |
| Word of frame    | integer (0 to 100)     | The word position in the frame of the erroneous bit              |
| Bit of Word      | integer (0 to 31)      | The bit position in the word                                     |
| Bit of Frame     | integer (0 to 3231)    | The bit position in the frame                                    |
|                  |                        | 0: The bit is unmasked                                           |
| Masked Bit       | 0 or 1                 | 1: The bit is masked                                             |
|                  |                        | False: The bit is located into a non-masked frame (at least      |
|                  |                        | one bit of the frame is unmasked)                                |
|                  |                        | True: The bit is located into a masked frame (all the bits of    |
|                  |                        | the frame are masked). Such frames are a) the BRAM               |
|                  |                        | content (block type 1) frames, b) the dummy frames and           |
| Masked Frame     | False or True          | the PS area frames of all the block types                        |
|                  |                        | 0: The bit is non-essential                                      |
| Essential Bit    | 0 or 1                 | 1: The bit is essential                                          |
|                  |                        | False: The bit is located into a frame which has at least        |
|                  |                        | one essential bit                                                |
| Non Essential    |                        | True: The bit is located into a non-essential frame (all the     |
| Frame            | False or True          | bits of the frame are not essential)                             |

#### Table 7: Test Post-Processing Database fields

| Database fields | Valid values          | Description                                                     |
|-----------------|-----------------------|-----------------------------------------------------------------|
|                 | String                |                                                                 |
|                 | (SLICE_XnYm or        | In case of masked bit, this field identifies the specific logic |
| Logic Block     | RAMB36_XnYm)          | block position (SLICE, RAMB)                                    |
|                 | String                |                                                                 |
|                 | (e.g. Latch=D5FF.Q or | In case of masked bit, this field identifies the specific logic |
| Specific Logic  | RAM=A:1)              | of the above block (FF, SRL bit, BRAM bit)                      |

All the results below are extracted from the database using queries.

## 7.2 SEU analysis

To analyze the SEUs we studied the effects in four different memory categories: CRAM, BRAM, FFs and SRLs.

## 7.2.1 CRAM testing

CRAM category includes all the unmasked bits of the configuration bitstream and has been obtained by the analysis of the readback-capture files. Since all these bits are static to the device operation, any upset is supposed to be an SEU (**Table 8**). The CRAM SEUs and the cross section are shown in **Table 9**.

Table 8: CRAM Upsets in a frame

| Upsets in a frame | CRAM Bits<br>Occurrences |
|-------------------|--------------------------|
| 1                 | 5790                     |
| 2                 | 64                       |
| 3                 | 1                        |
| 16                | 2                        |

We have also calculated the cross sections considering only the upsets in the essential CRAM bits, as extracted by the Xilinx ebd file, in order to provide a more realistic probability metric of SEUs affecting the CUT behavior.

#### Table 9: CRAM SEUs

| CRAM             | SEUs                    | 5953                   |
|------------------|-------------------------|------------------------|
| CRAIM            | Cross section [cm2/bit] | 2.49x10 <sup>-10</sup> |
| CDAM Ecceptial   | SEUs                    | 2935                   |
| CRAIVI Essential | Cross section [cm2/bit] | 1.23x10 <sup>-10</sup> |

In case of the two 16-bit upsets per frame (**Table 8**), these events occurred in two consecutive readbacks. The first readback recorded 16 bits in a frame having erroneous values compared with the golden value and the second readback recorded the same 16 bits in the same frame having

the golden value without performing reconfiguration between these two readbacks (double flip). A similar event (double flip) was also observed in three cases of 1-bit upset per frame. This specific case needs further investigation.

## 7.2.2 BRAM testing

BRAM category include the masked bits of the configuration bitstream for the BRAM data and has been obtained by the analysis of the readback-capture data. Upsets in these bits are mostly due to SEUs. Given that the CUT clock is paused during the radiation experiments and the CE signal is '0', upsets due to transients in the clock tree or the data busses are unlikely to happen.

**Table 10** presents the number of upsets in a frame and the number of occurrences while Table**11** presents the cross section of the BRAM.

| Upsets in a frame | BRAM Bits<br>Occurrences |
|-------------------|--------------------------|
| 1                 | 3875                     |
| 2                 | 103                      |
| 3                 | 2                        |

| Table | <b>10</b> : | BRAM | Upsets | in | a frame |
|-------|-------------|------|--------|----|---------|
|-------|-------------|------|--------|----|---------|

#### Table 11: BRAM SEUs

| DDAM   | SEUs                    | 4087                     |
|--------|-------------------------|--------------------------|
| DKAIVI | Cross section [cm2/bit] | 6.05 x 10 <sup>-10</sup> |

## 7.2.3 Flip-Flop testing

FF and SRL categories include the masked bits of the configuration bitstream for the CLB FFs and shift register LUT data, respectively and have been obtained by the analysis of the readback-capture data. The CUT clock is also paused for the FFs and SRLs, so any upset in these bits compared to their initial values can be caused by either an SEU in the configuration bits or FFs or a single event transient (SET) in the clock net and reset signals of the corresponding CUT chains (remember that all FFs and SRLs are cascaded in long chains).

#### Table 12: FF + SRL Upsets in a frame

| Upsets in a frame | FF Bits<br>Occurrences | SRL Bits<br>Occurrences |
|-------------------|------------------------|-------------------------|
| 1                 | 16                     | 1189                    |
| 2                 | -                      | 38                      |
| 3                 | -                      | 1                       |
| 100               | 1                      | -                       |

In the case of FFs, a single event was observed that affects several (100) FFs extending in several slices that belong to a physical half-row column (**Table 12**). These FFs – which are the 4 FFs of the SLICEM AFF, BFF, CFF and DFF (**Figure 11**b) of all the 25 Slices of a half-row SLICEM column (SLICE\_X136Y75 to SLICE\_X136Y99) – were changed to 0. They were configured as FFs with asynchronous preset and they were preloaded with 1s. This means that this phenomenon is not a SET on the preset signal. Furthermore, neither the SLICEM SRLs, which were preloaded with alternate 1-0 pattern, nor the other 4 SLICEM FFs, which were configured with asynchronous preset and preloaded with 0s, were flipped. This means that this phenomenon is not a SET on the clock signal too, assuming that each Slice is connected to a single clock net. The root cause of this phenomenon is currently investigated.

Moreover, five double flips in 1-bit upset per FF frame were also observed, as in the case of CRAM. In **Table 13**, the SEUs and the cross section of the FFs and the SRLs are presented.

|      | Upsets                  | 116                      |
|------|-------------------------|--------------------------|
| FFs  | SEUs                    | 116                      |
|      | Cross section [cm2/bit] | 7.89 x 10 <sup>-10</sup> |
|      | Upsets                  | 1268                     |
| SRLs | SEUs                    | 1268                     |
|      | Cross section [cm2/bit] | 8.37 x 10 <sup>-10</sup> |

#### Table 13: FF + SRL Upsets & SEUs

The cross section of all the different memory categories of the current test (2.29 MeVcm<sup>2</sup>/mg LET) is shown in **Figure 5** along with the cross sections of the radiation test performed in CERN [1] (8.8 and 12.45 MeVcm2/mg LETs).



Figure 5: Cross section vs. LET

Notice that we did not observe errors in the FPGA Configuration Registers.

### 7.2.4 Initial values analysis

**Table 14** presents: a) the percentage of the occurrences of the bit flip 0 to 1 and 1 to 0 for all the memory categories (column 3) and b) the ratios of the number of 0-to-1 (1-to-0) upsets/number of bits preloaded with 0 (1) (column 4). For the calculation of the ratios, we took into account the percentage of the initial values for each memory category as shown in **Table 2**.

| Memory Type | Bit Flip Type | % occurrences | Upsets per<br>preloaded bits ratio |
|-------------|---------------|---------------|------------------------------------|
| CRAM        | 0 to 1        | 82.70%        | 0.08 x 10 <sup>-3</sup>            |
| CRAIVI      | 1 to 0        | 17.30%        | 0.10 x 10 <sup>-3</sup>            |
| BRAM        | 0 to 1        | 58.04%        | 0.20 x 10 <sup>-3</sup>            |
|             | 1 to 0        | 41.96%        | 0.19 x 10 <sup>-3</sup>            |
|             | 0 to 1        | 5.17%         | 0.03 x 10 <sup>-3</sup>            |
| FFS         | 1 to 0        | 94.83%        | 0.50 x 10 <sup>-3</sup>            |
| SRLs        | 0 to 1        | 50.55%        | 0.29 x 10 <sup>-3</sup>            |
|             | 1 to 0        | 49.45%        | 0.28 x 10 <sup>-3</sup>            |

#### Table 14: SEU according to bit flip type

Observing the results of the above Table we can conclude that (Table 15):

- i. for the cases of CRAM and SRLs the likelihood to occur upset in memory cells preloaded with '0' is approximately equal with those preloaded with '1', as also observed in [5] and [1].
- ii. For the cases of BRAMs, the likelihood to occur upset in memory cells preloaded with '0' is also approximately equal with those preloaded with '1'
- iii. for the cases of FFs, the '1' cells upset more frequently compared to the '0' cells, including the phenomenon described in section 7.2.3, which is under investigation

| Memory<br>Category | Likelihood to upset |  |
|--------------------|---------------------|--|
| 0                  | 011110              |  |
| CRAM               | 1 : 1.25            |  |
| BRAM               | 1:0.95              |  |
| FFs                | 1:16.7              |  |
| SRLs               | 1:0.97              |  |

#### Table 15: Likelihood to upset 0->1 : 1->0

### 7.3 MBU/MCU analysis

As shown in **Table 8** most events are single bit upsets (SBUs). However, there is a considerable number of multiple bit upsets (MBUs) (mainly 2-bit upsets per frame). We can assume that when two or more upsets are observed in a frame, they are MBUs, i.e. caused by a single particle. Moreover, we observed multiple upsets expanding in more than one (neighboring) configuration frames called Multiple Cell Upsets (MCUs). We adopted the approach proposed in [5] to identify the MCUs in different frames and described in [1].

**Figure 6** presents the patterns (shapes) of the MCUs and their frequency of occurrence. The x-axis of the shapes represents consecutive frame address, while the y-axis consecutive bits in a frame. The total number of SBUs are significantly higher than the number of MCUs. The second and third shapes of the first row prove the bit interleaving scheme adopted in the FPGA configuration memory [5]. For example, the hamming distance of the two upsets of the second shape is (1,1), i.e. the first upset is in the i-bit of the frame j and the second upset is in the i+1-bit of the frame j+1. Note that in the above analysis, only the unmasked bits of the configuration memory have been considered, i.e. that are not dynamically altered by the CUT and possible upsets in these bits can be detected and corrected by a scrubbing mechanism.

The MCU patterns for this LET are similar with the most frequent MCU patterns in [1]. Furthermore, the likelihood of occurrence of N-bits patterns with N > 2 is very low.



Figure 6: MCU patterns (unmasked bits)

**Figure 7** presents the MCUs patterns in case of masked bits. The occurrence of these patterns depends on the CUT, because the masked bit of the configuration memory corresponds to the LUTs used to shape the SRLs and the configuration bits used to preload the FFs.



Figure 7: MCU patterns (masked bits)

The above MCU patterns with masked bits confirm the corresponding patterns observed in [1]. Given that for the FFs, SRLs and BRAMs masked configuration bits, the slice/LUT position can be extracted, it is possible to correlate the hamming distances (from the frame/bit logical addresses) of **Figure 7** with the bit positions of SRLs and BRAMs. For example, the relation between the bits of four configuration frames containing the LUTs of a SLICEM and the bits of the four corresponding SRLs is shown in **Figure 8**. Specifically, it shows how the bits 0 to 63 of four consecutive configuration frames (address offsets 0x0, 0x1, 0x2 and 0x3) form four 64-bit SRLs (LUTA, LUTB, LUTC and LUTD). The observation is that the first, second and third MCU shapes of **Figure 7** may occur in two contiguous bits of an SRL (bits of **Figure 8** with red color). For example, the MCU of the first shape may affect the bits 3 and 4 of the LUTA SRL, the MCU of the third shape may affect the bits 31 and 32 of the LUTA SRL and the MCU of the second shape may affect the bits 23 and 24 of the LUTB SRL.

SEUs TEST REPORT: SEUs Characterization of the 28nm Kintex-7-based Programmable Logic of Xilinx Zynq-7000 FPGA

|        | Frame Address<br>Offset 0x0 | Frame Address<br>Offset 0x1 | Frame Address<br>Offset 0x2 | Frame Address<br>Offset 0x3 |        | Frame Address<br>Offset 0x0 | Frame Address<br>Offset 0x1 | Frame Address<br>Offset 0x2 | Frame Address<br>Offset 0x3 |        | Frame Address<br>Offset 0x0 | Frame Address<br>Offset 0x1 | Frame Address<br>Offset 0x2 | Frame Address<br>Offset 0x3 |        | Frame Address<br>Offset 0x0 | Frame Address<br>Offset 0x1 | Frame Address<br>Offset 0x2 | Frame Address<br>Offset 0x3 |
|--------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| Bit 0  | LUTA<br>BIT1                | LUTA<br>BITO                | LUTA<br>BIT9                | LUTA<br>BIT8                | Bit 16 | LUTB<br>BIT1                | LUTB<br>BITO                | LUTB<br>BIT9                | LUTB<br>BIT8                | Bit 32 | LUTC<br>BIT1                | LUTC<br>BITO                | LUTC<br>BIT9                | LUTC<br>BIT8                | Bit 48 | LUTD<br>BIT1                | LUTD<br>BITO                | LUTD<br>BIT9                | LUTD<br>BIT8                |
| Bit 1  | LUTA<br>BIT3                | LUTA<br>BIT2                | LUTA<br>BIT11               | LUTA<br>BIT10               | Bit 17 | LUTB<br>BIT3                | LUTB<br>BIT2                | LUTB<br>BIT11               | LUTB<br>BIT10               | Bit 33 | LUTC<br>BIT3                | LUTC<br>BIT2                | LUTC<br>BIT11               | LUTC<br>BIT10               | Bit 49 | LUTD<br>BIT3                | LUTD<br>BIT2                | LUTD<br>BIT11               | LUTD<br>BIT10               |
| Bit 2  | LUTA<br>BIT5                | LUTA<br>BIT4                | LUTA<br>BIT13               | LUTA<br>BIT12               | Bit 18 | LUTB<br>BIT5                | LUTB<br>BIT4                | LUTB<br>BIT13               | LUTB<br>BIT12               | Bit 34 | LUTC<br>BIT5                | LUTC<br>BIT4                | LUTC<br>BIT13               | LUTC<br>BIT12               | Bit 50 | LUTD<br>BIT5                | LUTD<br>BIT4                | LUTD<br>BIT13               | LUTD<br>BIT12               |
| Bit 3  | LUTA<br>BIT7                | LUTA<br>BIT6                | LUTA<br>BIT15               | LUTA<br>BIT14               | Bit 19 | LUTB<br>BIT7                | LUTB<br>BIT6                | LUTB<br>BIT15               | LUTB<br>BIT14               | Bit 35 | LUTC<br>BIT7                | LUTC<br>BIT6                | LUTC<br>BIT15               | LUTC<br>BIT14               | Bit 51 | LUTD<br>BIT7                | LUTD<br>BIT6                | LUTD<br>BIT15               | LUTD<br>BIT14               |
| Bit 4  | LUTA<br>BIT17               | LUTA<br>BIT16               | LUTA<br>BIT25               | LUTA<br>BIT24               | Bit 20 | LUTB<br>BIT17               | LUTB<br>BIT16               | LUTB<br>BIT25               | LUTB<br>BIT24               | Bit 36 | LUTC<br>BIT17               | LUTC<br>BIT16               | LUTC<br>BIT25               | LUTC<br>BIT24               | Bit 52 | LUTD<br>BIT17               | LUTD<br>BIT16               | LUTD<br>BIT25               | LUTD<br>BIT24               |
| Bit 5  | LUTA<br>BIT19               | LUTA<br>BIT18               | LUTA<br>BIT27               | LUTA<br>BIT26               | Bit 21 | LUTB<br>BIT19               | LUTB<br>BIT18               | LUTB<br>BIT27               | LUTB<br>BIT26               | Bit 37 | LUTC<br>BIT19               | LUTC<br>BIT18               | LUTC<br>BIT27               | LUTC<br>BIT26               | Bit 53 | LUTD<br>BIT19               | LUTD<br>BIT18               | LUTD<br>BIT27               | LUTD<br>BIT26               |
| Bit 6  | LUTA<br>BIT21               | LUTA<br>BIT20               | LUTA<br>BIT29               | LUTA<br>BIT28               | Bit 22 | LUTB<br>BIT21               | LUTB<br>BIT20               | LUTB<br>BIT29               | LUTB<br>BIT28               | Bit 38 | LUTC<br>BIT21               | LUTC<br>BIT20               | LUTC<br>BIT29               | LUTC<br>BIT28               | Bit 54 | LUTD<br>BIT21               | LUTD<br>BIT20               | LUTD<br>BIT29               | LUTD<br>BIT28               |
| Bit 7  | LUTA<br>BIT23               | LUTA<br>BIT22               | LUTA<br>BIT31               | LUTA<br>BIT30               | Bit 23 | LUTB<br>BIT23               | LUTB<br>BIT22               | LUTB<br>BIT31               | LUTB<br>BIT30               | Bit 39 | LUTC<br>BIT23               | LUTC<br>BIT22               | LUTC<br>BIT31               | LUTC<br>BIT30               | Bit 55 | LUTD<br>BIT23               | LUTD<br>BIT22               | LUTD<br>BIT31               | LUTD<br>BIT30               |
| Bit 8  | LUTA<br>BIT33               | LUTA<br>BIT32               | LUTA<br>BIT41               | LUTA<br>BIT40               | Bit 24 | LUTB<br>BIT33               | LUTB<br>BIT32               | LUTB<br>BIT41               | LUTB<br>BIT40               | Bit 40 | LUTC<br>BIT33               | LUTC<br>BIT32               | LUTC<br>BIT41               | LUTC<br>BIT40               | Bit 56 | LUTD<br>BIT33               | LUTD<br>BIT32               | LUTD<br>BIT41               | LUTD<br>BIT40               |
| Bit 9  | LUTA<br>BIT35               | LUTA<br>BIT34               | LUTA<br>BIT43               | LUTA<br>BIT42               | Bit 25 | LUTB<br>BIT35               | LUTB<br>BIT34               | LUTB<br>BIT43               | LUTB<br>BIT42               | Bit 41 | LUTC<br>BIT35               | LUTC<br>BIT34               | LUTC<br>BIT43               | LUTC<br>BIT42               | Bit 57 | LUTD<br>BIT35               | LUTD<br>BIT34               | LUTD<br>BIT43               | LUTD<br>BIT42               |
| Bit 10 | LUTA<br>BIT37               | LUTA<br>BIT36               | LUTA<br>BIT45               | LUTA<br>BIT44               | Bit 26 | LUTB<br>BIT37               | LUTB<br>BIT36               | LUTB<br>BIT45               | LUTB<br>BIT44               | Bit 42 | LUTC<br>BIT37               | LUTC<br>BIT36               | LUTC<br>BIT45               | LUTC<br>BIT44               | Bit 58 | LUTD<br>BIT37               | LUTD<br>BIT36               | LUTD<br>BIT45               | LUTD<br>BIT44               |
| Bit 11 | LUTA<br>BIT39               | LUTA<br>BIT38               | LUTA<br>BIT47               | LUTA<br>BIT46               | Bit 27 | LUTB<br>BIT39               | LUTB<br>BIT38               | LUTB<br>BIT47               | LUTB<br>BIT46               | Bit 43 | LUTC<br>BIT39               | LUTC<br>BIT38               | LUTC<br>BIT47               | LUTC<br>BIT46               | Bit 59 | LUTD<br>BIT39               | LUTD<br>BIT38               | LUTD<br>BIT47               | LUTD<br>BIT46               |
| Bit 12 | LUTA<br>BIT49               | LUTA<br>BIT48               | LUTA<br>BIT57               | LUTA<br>BIT56               | Bit 28 | LUTB<br>BIT49               | LUTB<br>BIT48               | LUTB<br>BIT57               | LUTB<br>BIT56               | Bit 44 | LUTC<br>BIT49               | LUTC<br>BIT48               | LUTC<br>BIT57               | LUTC<br>BIT56               | Bit 60 | LUTD<br>BIT49               | LUTD<br>BIT48               | LUTD<br>BIT57               | LUTD<br>BIT56               |
| Bit 13 | LUTA<br>BIT51               | LUTA<br>BIT50               | LUTA<br>BIT59               | LUTA<br>BIT58               | Bit 29 | LUTB<br>BIT51               | LUTB<br>BIT50               | LUTB<br>BIT59               | LUTB<br>BIT58               | Bit 45 | LUTC<br>BIT51               | LUTC<br>BIT50               | LUTC<br>BIT59               | LUTC<br>BIT58               | Bit 61 | LUTD<br>BIT51               | LUTD<br>BIT50               | LUTD<br>BIT59               | LUTD<br>BIT58               |
| Bit 14 | LUTA<br>BIT53               | LUTA<br>BIT52               | LUTA<br>BIT61               | LUTA<br>BIT60               | Bit 30 | LUTB<br>BIT53               | LUTB<br>BIT52               | LUTB<br>BIT61               | LUTB<br>BIT60               | Bit 46 | LUTC<br>BIT53               | LUTC<br>BIT52               | LUTC<br>BIT61               | LUTC<br>BIT60               | Bit 62 | LUTD<br>BIT53               | LUTD<br>BIT52               | LUTD<br>BIT61               | LUTD<br>BIT60               |
| Bit 15 | LUTA<br>BIT55               | LUTA<br>BIT54               | LUTA<br>BIT63               | LUTA<br>BIT62               | Bit 31 | LUTB<br>BIT55               | LUTB<br>BIT54               | LUTB<br>BIT63               | LUTB<br>BIT62               | Bit 47 | LUTC<br>BIT55               | LUTC<br>BIT54               | LUTC<br>BIT63               | LUTC<br>BIT62               | Bit 63 | LUTD<br>BIT55               | LUTD<br>BIT54               | LUTD<br>BIT63               | LUTD<br>BIT62               |

Figure 8: SRLs (LUTRAMs) – Configuration Memory mapping

Version 1.0





Figure 9: DUT for test setup - Communication between the Host PC and the DUT

SEUs TEST REPORT: SEUs Characterization of the 28nm Kintex-7-based Programmable Logic of Xilinx Zynq-7000 FPGA Version 1.0



Figure 10: Zynq-7000 CLB architecture (all slices are connected in a row or a column fashion)



- 8-bit shift register for each SLICEL
- LUTs used as route-thrus
- FFs initialization values of a SLICEL configurable

#### SLICEM: 4 SRL32s (or LUTs) & 8 FFs



- 136-bit shift register for each SLICEM
- LUTs used as 32-bit shift register
- FFs and SRLs initialization values of a SLICEM configurable

#### Figure 11: Slice configuration as FF chains

Version 1.0



SLICEL: 4 LUTs & 8 FFs

Figure 12: Slice configuration and routing







- BRAMs initialized with a predefined pattern
- BRAMs connected in cascade mode through Data Bus
- either horizontal (raw) or vertical (column) -> configurable
- Each Memory size 1024 x 32 = 32.768 bits (36 Kb)

#### *Figure 13: BRAM configuration and connection in cascade mode*



- DSPs connected in cascade mode
- DSPs implement multiplication
- DSPs connected in cascade mode either horizontal (raw) or vertical (column) -> configurable

Figure 14: DSP slices configuration and connection in cascade mode

University of Piraeus - ESLab

SEUs TEST REPORT: SEUs Characterization of the 28nm Kintex-7-based Programmable Logic of Xilinx Zynq-7000 FPGA Version 1.0



| Resource | Utilization | Available | Utilization % |
|----------|-------------|-----------|---------------|
| LUT      | 70400       | 218600    | 32.20         |
| LUTRAM   | 70400       | 70400     | 100.00        |
| FF       | 437200      | 437200    | 100.00        |
| BRAM     | 545         | 545       | 100.00        |
| DSP      | 900         | 900       | 100.00        |
| IO       | 173         | 362       | 47.79         |
| BUFG     | 3           | 32        | 9.38          |
|          |             |           |               |

SLICELs = 37050 LUTs used as Route-Thrus and not as Logic LUTs = 37050 \* 4 = LUTs per SLICEL = 148200

SLICEMs = 17600 SRLs = 17600 \* 4 SRLs per SLICEM = <u>70400</u>

Total SLICEs = 37050 + 17600 = 54650 / SLICE FF = 54650 \* 8 Regs per Slice = <u>437200</u>

Figure 15: FPGA resource utilization and routing