

# LatticeXP2 Soft Error Detection (SED) Usage Guide

October 2012 Technical Note TN1130

#### Introduction

Soft errors occur when high-energy charged particles alter the stored charge in a memory cell in an electronic circuit. The phenomenon first became an issue in DRAM, requiring error detection and correction for large memory systems in high-reliability applications. As device geometries have continued to shrink, the probability of soft errors in SRAM has become significant for some systems. Designers are using a variety of approaches to minimize the effects of soft errors on system behavior.

SRAM-based FPGAs store logic configuration data in SRAM cells. As the number and density of SRAM cells in an FPGA increase, the probability that a soft error will alter the programmed logical behavior of the system increases. A number of approaches have been taken to address this issue, but most involve Intellectual Property (IP) cores that the user instantiates into the logic of their design, using valuable resources and possibly affecting design performance. The LatticeXP2 devices have a hardware implemented soft error detector which does not affect performance or heat dissipation of the devices.

This document describes the hardware based soft error detect (SED) approach taken by Lattice Semiconductor for LatticeXP2™ FPGAs.

#### **SED Overview**

The SED hardware in the LatticeXP2 devices consists of an access point to FPGA configuration memory, a controller circuit, and a 32-bit register to store the CRC for a given bitstream (see Figure 16-1). The SED hardware reads serial data from the FPGA's configuration memory and calculates a CRC. The data that is read, and the CRC that is calculated, does not include EBR memory or PFUs used as RAM. The calculated CRC is then compared with the expected CRC that was stored in the 32-bit register. If the CRC values match it indicates that there has been no configuration memory corruption, but if the values differ an error signal is generated.

Figure 16-1. System Block Diagram





Note that the calculated CRC is based on the particular arrangement of configuration memory for a particular design. Consequently, the expected CRC results cannot be specified until after the design is placed and routed. The ispLEVER® bitstream generation software analyzes the configuration of a placed and routed design and updates the 32-bit SED CRC register contents during bitstream generation.

The following sections describe the LatticeXP2 SED implementation and flow, along with some sample code to get started with.

#### **SED Limitations**

SED should only be run when the logic of the device is held in a steady state condition to prevent false error indications. All background programming instructions are not available while the SED is in progress due to resource contention. If a normal (not background) Flash programming command or SRAM configuration command is run the SRAM CRC Error check will be terminated. Refer to PCN 02B-12 for further details.

#### **Basic SED and One-shot SED Modes**

#### **Basic SED**

Basic SED checks the CRC for all bits. For Basic SED (SEDBA), the inputs are SEDCLKIN, SEDENABLE, SED-START, and SEDFRCERRN. The output signals are SEDCLKOUT, SEDDONE, SEDINPROG, and SEDERR.

Once an error is detected the SEDERR signal will stay high. SED supports the following Soft Error Corrections (SEC): "Do Nothing" or on-demand user reconfiguration by pulling the PROGAMN pin low from another device.

#### One-Shot SED

The One-Shot SED setting is based on the One-Shot Fuse. The module (SEDBB) has no input ports. The output signals are SEDDONE, SEDINPROG, and SEDERR. At a minimum, the user must connect SEDERR to an I/O pin in order to detect an error.

## **Hardware Description**

As shown in Figure 16-2, the LatticeXP2 SED hardware has several inputs and outputs that allow the user to control, and monitor, SED behavior.

Figure 16-2. Signal Block Diagram





## **Signal Descriptions**

Table 16-1. SED Signal Descriptions

| Signal Name | Direction | Active | Description              |
|-------------|-----------|--------|--------------------------|
| SEDCLKIN    | Input     | N/A    | Clock                    |
| SEDENABLE   | Input     | High   | SED enable               |
| SEDCLKOUT   | Output    | N/A    | Output clock             |
| SEDSTART    | Input     | High   | Start SED cycle          |
| SEDINPROG   | Output    | High   | SED cycle is in progress |
| SEDDONE     | Output    | High   | SED cycle is complete    |
| SEDFRCERRN  | Input     | Low    | Force an SED error flag  |
| SEDERR      | Output    | High   | SED error flag           |

#### **SEDCLKIN**

Clock input to the SED hardware.

When external SPI configuration is used, this clock is derived from the LatticeXP2's on-chip oscillator. The on-chip oscillator's output goes through a divider to create MCCLK. MCCLK goes through another divider to create SED-CLKIN.

The software default for MCCLK is 2.5 MHz, but this can be modified using the MCCLK\_FREQ global preference in ispLEVER's pre-map Design Planner (see TN1141, <u>LatticeXP2 sysCONFIG Usage Guide</u> for supported values of MCCLK). It has a range of 2.5 MHz to 66 MHz.

The divider for SEDCLKIN can be set to 1, 2, 4, 8, 16 or 32. The default is 1, so the default SEDCLKIN frequency is 2.5 MHz. The divider value can be set using a parameter, see the example code at the end of this document.

If internal Flash configuration mode is used, SEDCLKIN can only be set to 3.1 MHz with a divider setting of 1.

Note that SEDCLKIN is an internally generated signal, so it should not be included as an input in the user design. See the examples at the end of this document. Also note that while inputs to the SED block are clocked using SED-CLKIN, no attempt has been made to synchronize between clock domains. If this is a concern for a particular design then the designer will need to provide synchronization.

#### OSC DIV

Options: 1, 2, 4, 8, 16 or 32 for external configuration. Only 1 can be selected for internal configuration. The CLK that drives the SED module will be set by MCCLK/OSC DIV.

#### SEDENABLE

Level-sensitive signal which starts SED checking.

#### Table 16-2. SEDENABLE

| State | Description                                     |
|-------|-------------------------------------------------|
|       | Enables output of SEDCLKOUT, arms SED hardware. |

#### **SEDCLKOUT**

Gated version of SEDCLKIN, SEDCLKOUT is gated by SEDENABLE.

#### **SEDSTART**

Active high input to the SED hardware, sampled on the rising edge of SEDCLKIN.



#### Table 16-3. SEDSTART

| State | Description                                                           |
|-------|-----------------------------------------------------------------------|
| 1     | Start error detection. Must be high a minimum of one SEDCLKIN period. |
| 0     | No action.                                                            |

#### **SEDFRCERRN**

Active high input to the SED hardware, sampled on the rising edge of SEDCLKIN.

#### Table 16-4. SEDFRCERRN

| State | Description                                  |
|-------|----------------------------------------------|
| 1     | No action.                                   |
| 0     | Forces SEDERR high, simulating an SED error. |

#### **SEDINPROG**

Active high output from the SED hardware, clocked out on the rising edge of SEDCLKOUT.

#### Table 16-5. SEDINPROG

| State | Description                                                                  |
|-------|------------------------------------------------------------------------------|
| 1     | SED checking is in progress, goes high on the clock following SEDSTART high. |
| 0     | SED checking is not active.                                                  |

#### **SEDDONE**

Active high output from the SED hardware, clocked out on the rising edge of SEDCLKOUT.

#### Table 16-6. SEDDONE

| State | Description                                                                  |
|-------|------------------------------------------------------------------------------|
| 1     | SED checking is complete. Reset by a high on SEDSTART or a low on SEDENABLE. |
| 0     | SED checking is not complete.                                                |

#### **SEDERR**

Active high output from the SED hardware, clocked out on the rising edge of SEDCLKOUT.

#### Table 16-7. SEDERR

| State | Description                                              |
|-------|----------------------------------------------------------|
| 1     | SED has detected an error. Reset by SEDENABLE going low. |
| 0     | SED has not detected an error.                           |



#### **SED Flow**

#### Figure 16-3. Timing Diagram



The general SED flow is as follows.

- 1. User logic sets SEDENABLE high. This signal may be tied high if desired.
- 2. User logic sets SEDSTART high. SEDINPROG goes high. If SEDDONE is already high it is driven low. SEDSTART may be tied high to enable continuous SED checking.
- 3. SED starts reading back data from the configuration SRAM.
- 4. SED finishes checking. SEDERR is updated, SEDINPROG goes low, and SEDDONE goes high.
- 5. If SEDERR is driven high there are only two ways to reset it, drive SEDENABLE low or reconfigure the FPGA.
- 6. SEDENABLE goes low when/if the user specifies, and SED is no longer in use.

The user has two choices when an error is detected, ignore the error, and possibly log it, or reconfigure the FPGA. Reconfiguration can be accomplished by driving the PROGRAMN pin low. This can be done by externally connecting a GPIO pin to PROGRAMN.

Figure 16-4. Example Schematic



#### **SED Run Time**

The amount of time needed to perform an SED check depends on the density of the device and the frequency of SEDCLKIN. There will also be some overhead time for calculation, but it is fairly short in comparison. An approximation of the time required can be found by using the following formula:



#### Maxbits / SEDCLKIN = Time

Maxbits is in mega-bits and depends on the density of the FPGA (see Table 16-8). SEDCLKIN is frequency in MHz. Time is in seconds

For example, for a design using a LatticeXP2 with 5K look-up tables and the SEDCLKIN is the software default of 3.1 MHz:

```
1.236 Mbits / 3.1 MHz = 398.71 ms
```

In this example, SED checking will take approximately 398.71 ms. Remember that this happens in the background and does not affect user logic performance.

Note that the internal oscillator used to generate SEDCLKIN can vary by ±30%.

Table 16-8. SED Run Time

| Device  | XP2-5K | XP2-8K | XP2-17K | XP2-30K | XP2-40K |
|---------|--------|--------|---------|---------|---------|
| Density | 1.236M | 1.954M | 3.636M  | 5.964M  | 8.304M  |
| 66MHz   | 18.7ms | 29.6ms | 55.1ms  | 90.4ms  | 126.2ms |
| 50MHz   | 24.7ms | 39.1ms | 72.7ms  | 119.3ms | 166.1ms |
| 3.1MHz  | 399ms  | 624ms  | 1.173s  | 1.924s  | 2.679s  |
| 2.5MHz  | 495ms  | 782ms  | 1.455s  | 2.395s  | 3.325s  |

### **Sample Code**

The following simple example code shows how to instantiate the SED. In the example the SED is always on and always running, and the outputs of the SED hardware have been routed to FPGA output pins. Note that the SEDBA primitive is part of ispLEVER 6.1 or later.

#### **Basic SED VHDL Example**

```
library ieee;
use ieee.std logic 1164.all;
use ieee.std logic unsigned.all;
entity example is
  port (
        sed done : out std logic;
        sed in prog : out std logic;
         sed clk out : out std logic;
        sed out
                  : out std logic);
end;
architecture behavioral of example is
   component SEDBA -- SED component
     generic (OSC DIV : integer := 1); -- set SEDCLKIN divider
      port (
        SEDENABLE : in std_logic;
        SEDSTART : in std logic;
        SEDFRCERRN : in std logic;
                   : out std_logic;
        SEDERR
        SEDDONE
                     : out std logic;
        SEDINPROG : out std_logic;
SEDCLKOUT : out std_logic);
   end component;
```



```
begin
      isnt1: SEDBA
      generic map (OSC DIV=> "1")
      port map (
         SEDENABLE => '1', -- tied high
SEDSTART => '1', -- tied high
         SEDFRCERRN => '1', -- tied high
         SEDERR => sed out, -- wired to an output
         SEDDONE => sed_done, -- wired to an output
SEDINPROG => sed_in_prog, -- wired to an output
SEDCLKOUT => sed_clk_out ); -- wired to an output
end behavioral ;
One Shot SED in VHDL
library ieee;
use ieee.std logic 1164.all;
use ieee.std_logic_unsigned.all;
entity example is
   port (
         sed done : out std logic;
         sed in prog : out std logic;
         sed out : out std logic);
end;
architecture behavioral of example is
   component SEDBB -- This is for One Shot SED
     generic (OSC DIV : integer := 1); -- set SEDCLKIN divider
     port (
          SEDDONE : out std logic;
          SEDINPROG : out std logic;
          SEDERR : out std logic
end component;
begin
     isnt1: SEDBB
     generic map (OSC DIV=> "1")
     port map (
          SEDERR => sed out, -- wired to an output
          SEDDONE => sed done, -- wired to an output
          SEDINPROG => sed in prog); -- wired to an output
end behavioral ;
```



#### **Basic SED Verilog Example**

```
module example (
   sed_done,
   sed_in_prog,
   sed clk out,
   sed out) ;
output sed done;
output sed_in_prog;
output sed_clk_out;
output sed out;
assign V hi = 1'b1;
assign V_lo = 1'b0;
SEDBA
     #(.OSC DIV(1))
SED IP(
       .SEDENABLE(V_hi), // always high
       .SEDSTART(V_hi), // always high .SEDFRCERRN(V_hi), // always high
       .SEDERR(sed_out), // wired to an output .SEDDONE(sed_done), // wired to an output
       .SEDINPROG(sed_in_prog), // wired to an output
       .SEDCLKOUT(sed_clk_out)); // wired to an output
```

endmodule



## **One-Shot SED in Verilog**

```
module example (
    sed done,
    sed in prog,
    sed clk out,
    sed out) ;
output sed done;
output sed_in_Prog;
output sed_clk_out;
output sed out;
assign V hi = 1'b1;
assign V_lo = 1'b0;
SEDBB
    #(.OSC DIV(1))
   SED_IP(
         .SEDDONE(sed_done),
         .SEDINPROG(sed_inprog),
         .SEDERR(sed out)
         );
endmodule
module SEDBB (SEDERR, SEDDONE, SEDINPROG);
    output SEDERR, SEDDONE, SEDINPROG;
endmodule
```

## **Technical Support Assistance**

Hotline: 1-800-LATTICE (North America)

+1-503-268-8001 (Outside North America)

e-mail: techsupport@latticesemi.com

Internet: www.latticesemi.com



## **Revision History**

| Date           | Version | Change Summary                                                                                                                         |  |
|----------------|---------|----------------------------------------------------------------------------------------------------------------------------------------|--|
| February 2007  | 01.0    | Initial release.                                                                                                                       |  |
| January 2008   | 01.1    | Updated code in the following sections: Basic SED VHDL Example, One Shot SED in VHDL, Basic SED Verilog Example, One Shot SED Verilog. |  |
| January 2008   | 01.2    | Updated OSC_DIV text section.                                                                                                          |  |
|                |         | Updated SED Flow text section.                                                                                                         |  |
| February 2008  | 01.3    | Updated Timing Diagram.                                                                                                                |  |
| March 2008     | 01.4    | Updated SEDCLKIN and OSC_DIV text sections and SEDENABLE table.                                                                        |  |
| April 2008     | 01.5    | Corrected "SEDFRCERR" to read "SEDFRCERRN".                                                                                            |  |
| July 2008      | 01.6    | Added footnote to SED Flow timing diagram.                                                                                             |  |
| August 2008    | 01.7    | Updated SEDCLKIN and OSC_DIV text sections.                                                                                            |  |
|                |         | Updated SED Run Time text section and SED Run Time table.                                                                              |  |
| January 2009   | 01.8    | Updated SED Flow text section. Added Example Schematic diagram.                                                                        |  |
| January 2009   | 01.9    | Updated Basic SED Verilog Example code.                                                                                                |  |
|                |         | Updated One-Shot SED in Verilog code.                                                                                                  |  |
| September 2009 | 02.0    | Updated Basic SED VHDL Example code.                                                                                                   |  |
|                |         | Updated One-Shot SED in VHDL code.                                                                                                     |  |
| October 2012   | 02.1    | Added SED Limitations section.                                                                                                         |  |