Disclaimers
Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS and with all faults, and all risk associated with such information is entirely with Buyer. Buyer shall not rely on any data and performance specifications or parameters provided herein. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. No Lattice products should be used in conjunction with mission- or safety-critical or any other application in which the failure of Lattice's product could create a situation where personal injury, death, severe property or environmental damage may occur. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.
Contents
1. Introduction .............................................................................................................................................. 4
2. SED Overview ......................................................................................................................................... 4
3. SED Limitations ..................................................................................................................................... 4
4. SED Operating Modes ......................................................................................................................... 5
   4.1. Standard SED .................................................................................................................................. 6
   4.2. One-Shot SED .................................................................................................................................. 6
5. Signal Descriptions ............................................................................................................................... 7
6. SED Clock Driver ................................................................................................................................... 7
7. SED Attributes ....................................................................................................................................... 8
8. Port Descriptions ................................................................................................................................... 8
   8.1. SEDENABLE ...................................................................................................................................... 8
   8.2. SEDSTART ......................................................................................................................................... 8
   8.3. SEDFRCERR ..................................................................................................................................... 8
   8.4. SEDSTDBY ........................................................................................................................................ 8
   8.5. SEDCLKOUT ...................................................................................................................................... 9
   8.6. SEDDONE ......................................................................................................................................... 9
   8.7. SEDINPROG ..................................................................................................................................... 9
   8.8. SEDERR .......................................................................................................................................... 9
9. SED Flow ............................................................................................................................................... 9
10. Timing Diagram for SED Operation ..................................................................................................... 11
11. SED Run Time ....................................................................................................................................... 11
12. Sample Code ........................................................................................................................................ 12
   12.1. SED VHDL Examples .................................................................................................................. 12
   12.2. SED Verilog Examples ................................................................................................................ 13
Technical Support Assistance ...................................................................................................................... 14
Revision History ......................................................................................................................................... 15

Figures
Figure 2.1. System Block Diagram .......................................................................................................... 4
Figure 4.1. SEDFA Primitive Symbol ....................................................................................................... 6
Figure 4.2. SEDFB Primitive Symbol ....................................................................................................... 6
Figure 9.1. Example Schematic ................................................................................................................. 10
Figure 10.1. Timing Diagram for SED Operation ..................................................................................... 11

Tables
Table 5.1. SEDFA Primitive Port Definitions ......................................................................................... 7
Table 6.1. SED Internal Oscillator Supported Frequency Settings ........................................................ 7
Table 7.1. SED Attributes ........................................................................................................................ 8
Table 11.1. SED Run Time ........................................................................................................................ 11
1. Introduction

Memory errors can 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 memory errors in SRAM has become significant for some systems. Designers are using a variety of approaches to minimize the effects of memory errors on system behavior.

SRAM-based PLDs store logic configuration data in SRAM cells. As the number and density of SRAM cells in an PLD increase, the probability that a memory 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 MachXO2™ devices have a hardware implemented SED circuit which can be used to detect SRAM errors and allow them to be corrected.

This document describes the hardware-based SRAM CRC Error Detect (SED) approach taken by Lattice Semiconductor for MachXO2 PLDs.

2. SED Overview

The SED hardware in the MachXO2 devices is part of the Embedded Functional Block (EFB) consists of an access point to the PLD’s Configuration Logic, a Controller Circuit, and a 32-bit register to store the CRC for a given bitstream (see Figure 2.1). The SED hardware reads serial data from the PLD’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.

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 Lattice Diamond® or 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 MachXO2 SED implementation and flow.
3. SED Limitations

SED should only be run when once Vcc reaches the data sheet Vcc minimum recommend level. In addition, clock frequencies of greater than 33.33 MHz for the SED are not supported.

The clock (SMCLK) of the SED circuit is shared with the Configuration Logic. As a result, the SED module interacts with several EFB functions with the following results:

- If the EFB or Configuration Logic is accessed while the SED circuit is running:
  - The current SED cycle will be terminated:
    - When the SED circuit is terminated there will be a delay of two SMCLK cycles before EFB or Configuration Logic can be accessed. This is a result of the SMCLK transferring clock from the SED Clock to the Configuration Clock domain. The two SMCLK cycles are defined by the slower SED clock.
    - When the SED circuit is terminated the SEDDONE will remain low, SEDERR will remain low, and SEDINPROG resets from high to low.
  - The EFB or Configuration Logic access which interacts with the SED circuit is defined as:
    - The following commands issued through the JTAG port or WISHBONE interface:
      - LSC_REFRESH
      - ISC_ENABLE
      - ISC_ENABLE_X
      - All IEEE 1532 instructions
      - ISC_DISABLE
    - Primary I^2C Configuration Logic slave address match
    - SPI Configuration Logic chip select being asserted
    - The PROGRAMN pin detection logic requires the minimal low period be longer than six SMCLK cycles. If the SED circuit is running the six SMCLK cycles are defined by the SED clock.

4. SED Operating Modes

For MachXO2 devices there are two operating modes available for SED:

- Standard mode allows the design to control when the SED is run and to test the error detection operation.
- One-shot operation is used to run the SED once when the device is first configured to ensure that the configuration matches the desired configuration.

Both operations perform a single cycle which checks the CRC of all the bits in the SRAM except the EBR and RAM memory. Standard mode is activated using the SEDFA primitive while the One-Shot operation is activated using the SEDFB primitive. These primitives are described in the next section.

If an error is detected during an SED operation, the user can choose one of two corrective actions to take. One is to “Do Nothing” and the other is to initiate an on-demand user reconfiguration by pulling the PROGRAMN pin low. This can be done from another device or from an output of the MachXO2 device as shown in Figure 4.1.

The PROGRAMn pin detection logic requires the minimal low period be longer than 6 SMCLK cycles. When error detection is actively enabled, the PROGRAMn pin minimal low period will be 6 SEDCLK cycles, since the active SMCLK switched to SEDCLK as mentioned previously. This will behave differently then normal operation where the SMCLK is operating at full speed. After booting, the SED function block will behave according to the new configuration programming.
4.1. Standard SED

The Standard SED operation can be used by instantiating the SEDFA primitive which is shown in Figure 4.1. The primitive port definitions are listed in Table 5.1. See the Port Descriptions section of this document for more detailed information about each of the ports.

If the Standard SED is done with the “R1” version of the MachXO2 devices, the first time the check is run a false error will be reported. If a second check is done the correct result will be reported. The “R1” versions of the MachXO2 devices have an “R1” suffix at the end of the part number, similar to LCMXO2-1200ZE-1TG144CR1. For more details on the R1 to Standard migration refer to Designing for Migration from MachXO2-1200-R1 to Standard (Non-R1) Devices (FPGA-AN-02012).

![Figure 4.1. SEDFA Primitive Symbol](image)

4.2. One-Shot SED

The One-Shot SED operation can be used by instantiating the SEDFB primitive which is shown in Figure 4.2. The definitions of the ports for the SEDFB primitive are shown in Table 5.1. See the Port Descriptions section of this document for more detailed information about each of the ports.

The One-Shot SED is NOT supported on the “R1” version of the MachXO2 devices because a false error will always be reported. The “R1” versions of the MachXO2 devices have an “R1” suffix at the end of the part number, similar to LCMXO2-1200ZE-1TG144CR1.

![Figure 4.2. SEDFB Primitive Symbol](image)
5. Signal Descriptions

Table 5.1. SEDFA Primitive Port Definitions

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Direction</th>
<th>Active</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEDENABLE</td>
<td>Input</td>
<td>High</td>
<td>SRAM CRC enable</td>
</tr>
<tr>
<td>SEDSTART</td>
<td>Input</td>
<td>Rising Edge</td>
<td>Start SRAM CRC cycle</td>
</tr>
<tr>
<td>SEDFRERR</td>
<td>Input</td>
<td>Rising Edge</td>
<td>Force an SRAM CRC error flag</td>
</tr>
<tr>
<td>SEDSTDYB</td>
<td>Input</td>
<td>High</td>
<td>SRAM CRC disable while in standby mode</td>
</tr>
<tr>
<td>SEDCLKOUT</td>
<td>Output</td>
<td>N/A</td>
<td>Output clock</td>
</tr>
<tr>
<td>SEDDONE</td>
<td>Output</td>
<td>High</td>
<td>SRAM CRC cycle is complete</td>
</tr>
<tr>
<td>SEDINPROG</td>
<td>Output</td>
<td>High</td>
<td>SRAM CRC cycle is in progress</td>
</tr>
<tr>
<td>SEDERR</td>
<td>Output</td>
<td>High</td>
<td>SRAM CRC error flag</td>
</tr>
</tbody>
</table>

6. SED Clock Driver

The SED circuitry is driven by the MachXO2 internal oscillator when using either the SEDFA or SEDFB primitive. The maximum frequency supported is 33.25 MHz.

The MachXO2 internal oscillator can be used for several functions in the device including Configuration, SED and as an internal user clock. The frequency of the oscillator output can be set differently for each of these different uses. The settings available for the SED clock are shown in the table below. When using of the SED, the internal oscillator frequency is specified using the SED_CLK_FREQ parameter.

Table 6.1. SED Internal Oscillator Supported Frequency Settings

<table>
<thead>
<tr>
<th>Frequency Settings</th>
<th>2.08</th>
<th>2.15</th>
<th>2.22</th>
<th>2.29</th>
<th>2.38</th>
<th>2.46</th>
<th>2.56</th>
<th>2.66</th>
<th>2.77</th>
<th>2.89</th>
<th>3.02</th>
<th>3.17</th>
<th>3.33</th>
<th>3.50</th>
<th>3.69</th>
<th>3.91</th>
</tr>
</thead>
<tbody>
<tr>
<td>4.16</td>
<td>4.29</td>
<td>4.43</td>
<td>4.59</td>
<td>4.75</td>
<td>4.93</td>
<td>5.12</td>
<td>5.32</td>
<td>5.54</td>
<td>5.78</td>
<td>6.05</td>
<td>6.33</td>
<td>6.65</td>
<td>7.00</td>
<td>7.39</td>
<td>7.82</td>
<td></td>
</tr>
</tbody>
</table>
7. SED Attributes

There are three attributes that can be used with the SED primitives and these are shown in Table 7.1. Usage examples for these attributes can be found in the Sample Code section of this document. Currently the SEDFB primitive does not support the three attributes listed.

Table 7.1. SED Attributes

<table>
<thead>
<tr>
<th>Attribute Name</th>
<th>Attribute Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SED_CLK_FREQ</td>
<td>String</td>
<td>Specifies the clock frequency when used with SEDFA primitive.</td>
</tr>
<tr>
<td>DEV_DENSITY</td>
<td>String</td>
<td>Specifies the device density for use by the simulation model.</td>
</tr>
<tr>
<td>CHECKALWAYS</td>
<td>String</td>
<td>Reserved for future use.</td>
</tr>
</tbody>
</table>

The SED_CLK_FREQ attribute is used to specify the clock frequency. The SEDFA primitive uses the MachXO2 internal oscillator as the clock source. The available settings are those shown in Table 6.1. If a value other than those shown in the table is used the software will issue an error message and exit from the MAP process.

The DEV_DENSITY attribute is used to specify the device density for the MachXO2 simulation model. If the DEV_DENSITY attribute is not specified the default value of 1200L will be used. The allowable values for the DEV_DENSITY attribute are:


The CHECKALWAYS attribute is not supported at this time.

8. Port Descriptions

8.1. SEDENABLE

SEDENABLE is a level-sensitive signal which enables SED checking when high. When this signal is low, the SED hardware is disabled. This can be tied high in a design if desired.

8.2. SEDSTART

SEDSTART is the signal which starts the SED process. The rising edge of the SEDSTART signal will cause the SED cycle to start if SEDENABLE is high. The SEDSTART signal must remain high until the SED process has completed. If SEDSTART goes low during the SED cycle the process will be terminated without asserting SEDDONE or SEDERR.

8.3. SEDFRCERR

SEDFRCERR is used to force the SED process to return an error indication on the SEDERR signal. This is typically done to test the logic associated with the SEDERR output. The rising edge of the SEDFRCERR signal is detected by the SED hardware and latched in by the rising edge of the SED Clock Driver signal. The SEDFRCERR should be latched high while the SED is active for an error indication to be returned. The recommended use is for the user logic to drive the SEDFRCERR signal from low to high once the rising edge of the SEDINPROG signal is detected and while following the setup/hold time requirements defined in Figure 10.1.

8.4. SEDSTDBY

The SEDSTDBY port is provided on the SEDFA primitive only and must be connected to the SEDSTDBY output port on OSCH component. This signal is provided for simulation support of the STDBY function which can be used to turn off the internal oscillator. When the STDBY function turns off the internal oscillator the SEDFA block will no longer operate because its clock source has been turned off. If the user does not connect this signal on the SEDFA primitive the SED will still function the same way in the hardware but may not match the simulation results when STDBY is used.
8.5.  SEDCLKOUT

SEDCLKOUT is a gated version of the SED Clock Driver signal to the SED block. SEDCLKOUT is gated by SEDENABLE. This signal can be used to synchronize the inputs to the SED block or the outputs from the SED block.

8.6.  SEDDONE

SEDDONE is an output which indicates that SED checking has completed a cycle. This signal is an active high output from the SED hardware, clocked out on the rising edge of SEDCLKOUT. SEDDONE will be reset by a low SEDSTART signal.

8.7.  SEDINPROG

SEDINPROG is an output which indicates that SED checking is in progress. This signal is an active high output from the SED hardware, clocked out on the rising edge of SEDCLKOUT. SEDINPROG will go high following SEDSTART going high after the delay shown in Figure 10.1.

8.8.  SEDERR

SEDERR is an output which indicates that SED checking has completed a cycle with an error. This signal is an active high output from the SED hardware, clocked out on the rising edge of SEDCLKOUT. SEDERR will be reset by a low SEDSTART signal and delay as defined in Figure 10.1.

9.  SED Flow

The general SED flow once VCC reaches the data sheet Vcc minimum recommend level is as follows.

1.  User logic sets SEDENABLE high. This signal may be tied high if desired.

2.  User logic sets SEDSTART high and holds it high for the duration of the SED cycle. SEDINPROG goes high. If SEDDONE or SEDERR are already high they will be driven low.

3.  SED starts reading back data from the configuration SRAM.

4.  SED finishes checking. SEDERR is updated, SEDINPROG goes low, SEDDONE goes high and another SED cycle is started by asserting SEDSTART. When SEDSTART is asserted the SEDERR signal will be reset.

5.  If SEDERR is driven high it can be reset by reconfiguring the PLD.

6.  SEDENABLE goes low when/if the user specifies, and SED is no longer in use.

The preferred action to take when an error is detected is to reconfigure the PLD. Reconfiguration can be accomplished by driving the PROGRAMN pin low. This can be done by externally connecting a GPIO pin to PROGRAMN.
Note: The 1 Ohm resistor shown allows a user to recover from a bad program which always pulls the GPIO pin low in the MachXO2 device. If this type of pattern is loaded into the MachXO2, the device will always be held in the re-configuration state and is not able to communicate or be erased to clear the error condition. To recover from this condition, remove the resistor and reprogram the device, then replace resistor.

Figure 9.1. Example Schematic
10. Timing Diagram for SED Operation

![Timing Diagram for SED Operation](image)

Figure 10.1. Timing Diagram for SED Operation

Where:

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>tEN_MIN</td>
<td>0</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tIPDEL</td>
<td>2</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tFEHOLD_MIN</td>
<td>92</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tFESETUP_MIN</td>
<td>5</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tFE_MIN</td>
<td>2</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tERROUT</td>
<td>1</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tST_HMIN</td>
<td>0</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tST_LMIN</td>
<td>1</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tOUT_CLR</td>
<td>2</td>
<td>SEDCLK</td>
</tr>
<tr>
<td>tDONE_SET</td>
<td>0</td>
<td>SEDCLK</td>
</tr>
</tbody>
</table>

11. SED Run Time

The amount of time needed to perform an SED check depends on the density of the device and the frequency of the SED Clock Driver signal. 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:

\[
\text{Time (ms)} = \frac{\text{Maxbits} / 8}{\text{SED Clock Driver Frequency (MHz)}}
\]

Maxbits is in kbits and depends on the density of the PLD (see Table 11.1.). The SED Clock Driver signal frequency is shown in MHz. Time is in milliseconds. The SED checking in the MachXO2 device reads 8 bits (1 byte) on each SED clock cycle.

For example, for a design using a MachXO2 with 4,000 look-up tables and an SED Clock Driver frequency of 7 MHz:

\[
\text{Time} = \frac{972\text{ kbits} / 8}{7\text{ MHz}} = 17.4\text{ ms}
\]

In this example, SED checking will take approximately 17.4 ms.

Note that the internal oscillator is used to generate the SED Clock Driver signal and its frequency can vary by ±5.5%.

<table>
<thead>
<tr>
<th>Density</th>
<th>XO2-256</th>
<th>XO2-640</th>
<th>XO2-640U</th>
<th>XO2-1200</th>
<th>XO2-1200U</th>
<th>XO2-2000</th>
<th>XO2-2000U</th>
<th>XO2-4000</th>
<th>XO2-7000</th>
</tr>
</thead>
<tbody>
<tr>
<td>33.25 MHz</td>
<td>0.35</td>
<td>0.72</td>
<td>1.35</td>
<td>1.35</td>
<td>2.01</td>
<td>2.01</td>
<td>3.65</td>
<td>3.65</td>
<td>5.77</td>
</tr>
<tr>
<td>2.08 MHz</td>
<td>5.64</td>
<td>11.48</td>
<td>21.63</td>
<td>21.63</td>
<td>32.15</td>
<td>32.15</td>
<td>58.41</td>
<td>58.41</td>
<td>92.19</td>
</tr>
</tbody>
</table>

Note: Density refers to the number of configuration bits in the device.
12. Sample Code

The following simple example code shows how to instantiate the SED primitive. In the example the SED is always enabled and will be run when the “sed_start” signal is driven high. The outputs of the SED hardware are available to route to the PLD output pins or for use in another module. Note that the SADFA primitive is part of ispLEVER 8.1 SP1 or later and Diamond 1.1 or later.

12.1. SED VHDL Examples

VHDL SEDFA

COMPONENT SEDFA
  GENERIC(
    SED_CLK_FREQ : string := "3.5";
    CHECKALWAYS : string := "DISABLED";
    DEV_DENSITY : string := "1200L"
  )
  PORT(
    SEDENABLE : In STD_LOGIC;
    SEDSTART : In STD_LOGIC;
    SEDFRCERR : In STD_LOGIC;
    SEDSTDBY : In STD_LOGIC;
    SEDERR : Out STD_LOGIC;
    SEDDONE : Out STD_LOGIC;
    SEDINPROG : Out STD_LOGIC;
    SEDCLKOUT : Out STD_LOGIC);
END COMPONENT;

SEDinst0: SEDFA
  -- synthesis translate_off
  GENERIC MAP (SED_CLK_FREQ => "13.30";
    CHECKALWAYS => "DISABLED";
    DEV_DENSITY => "1200L"
  )
  -- synthesis translate_on
  PORT MAP (SEDENABLE => '1',
            SEDSTART => sed_start,
            SEDFRCERR => '0',
            SEDSTDBY => sed_stdby,
            SEDERR => sed_err,
            SEDDONE => sed_done,
            SEDINPROG => sed_active,
            SEDCLKOUT => sed_clkout);
12.2. SED Verilog Examples

Verilog SEDFA
module SEDFA (SEDENABLE, SEDSTART, SEDFRCERR, SEDSTDBY, SEDERR, SEDDONE, SEDINPROG, SEDCLKOUT);
input SEDENABLE, SEDSTART, SEDFRCERR, SEDSTDBY;
output SEDERR, SEDDONE, SEDINPROG, SEDCLKOUT;
parameter SED_CLK_FREQ = "3.5";
parameter CHECKALWAYS = "DISABLED";
parameter DEV_DENSITY = "1200L";
//"256L","640L","1200L","2000L","4000L","7000L","640U", "1200U", and "2000U"
endmodule

Verilog SEDFA Primitive Instantiation
// instantiate SEDFA primitive module with parameter passing to SEDFA module
SEDFA # (.SED_CLK_FREQ("4.75"), .DEV_DENSITY("1200L"))
sedfa_tst (.SEDENABLE(1'b1), .SEDSTART(sed_start), .SEDFRCERR(1'b0), .SEDSTDBY(),
.SEDERR(sed_err), .SEDDONE(sed_done), .SEDINPROG(sed_active), .SEDCLKOUT(sed_clkout));
Technical Support Assistance
Submit a technical support case through www.latticesemi.com/techsupport.
# Revision History

## Revision 2.1, November 2019

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>• Changed document number from TN1206 to FPGA-TN-02156.</td>
</tr>
<tr>
<td></td>
<td>• Updated document template.</td>
</tr>
<tr>
<td>Disclaimers</td>
<td>Added this section.</td>
</tr>
</tbody>
</table>

## Revision 2.0, January 2017

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>SED Run Time</td>
<td>Updated this section. Revised values in Table 11.1, SED Run Time.</td>
</tr>
<tr>
<td>Technical Support Assistance</td>
<td>Updated this section.</td>
</tr>
<tr>
<td>All</td>
<td>Updated document template.</td>
</tr>
</tbody>
</table>

## Revision 1.9, December 2013

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Updated the body text to match Timing Diagram for SED Operation.</td>
</tr>
</tbody>
</table>

## Revision 1.8, February 2013

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Removed requirements for holding user logic in a steady state.</td>
</tr>
</tbody>
</table>

## Revision 1.7, January 2013

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>SED Overview</td>
<td>Defined the EFB or Configuration Logic which interacts with the SRAM CRC Error Detection circuit.</td>
</tr>
<tr>
<td>Timing Diagram for SED Operation</td>
<td>Added timing diagram for SED operation.</td>
</tr>
<tr>
<td>All</td>
<td>Changed “SRAM CRC Error Detection” to “SED” throughout the document.</td>
</tr>
</tbody>
</table>

## Revision 1.6, August 2012

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Updated SRAM CRC Error Detection Limitations and SRAM CRC Error Detection Operating Modes sections.</td>
</tr>
</tbody>
</table>

## Revision 1.5, February 2012

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Updated document with new corporate logo.</td>
</tr>
</tbody>
</table>

## Revision 1.4, July 2011

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>SED Operating Modes</td>
<td>Updated Standard SRAM CRC Error Detection text section with information about migration from MachXO2-1200-R1 to Standard (N-1) devices.</td>
</tr>
</tbody>
</table>

## Revision 1.3, June 2011

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>SED Operating Modes</td>
<td>Clarified attribute usage for SEDFB primitive.</td>
</tr>
<tr>
<td>SED Run Time</td>
<td>Clarified run time calculation section.</td>
</tr>
</tbody>
</table>
# MachXO2 SED Usage Guide

## Technical Note

© 2017 - 2019 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at [www.latticesemi.com/legal](http://www.latticesemi.com/legal). All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

---

### Revision 1.2, May 2011

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Changed “SED” to “SRAM CRC Error Detection” throughout the document.</td>
</tr>
<tr>
<td>SED Limitations</td>
<td>Added Limitations section</td>
</tr>
<tr>
<td>SED Operating Modes</td>
<td>Replaced Basic SED Mode and Hardware Description sections with Operating Modes section and added description of the primitives.</td>
</tr>
<tr>
<td>SED Clock Driver</td>
<td>Updated supported frequencies in Table 6.1., SRAM CRC Error Detection Internal Oscillator Supported Frequency Settings.</td>
</tr>
<tr>
<td>Signal Descriptions</td>
<td>Updated Port descriptions and Flow sections.</td>
</tr>
<tr>
<td>SED Run Time</td>
<td>Corrected Run Time calculations and updated Table 11.1, SRAM CRC Error Detection Run Time.</td>
</tr>
<tr>
<td>Sample Code</td>
<td>Updated this section.</td>
</tr>
</tbody>
</table>

### Revision 1.1, January 2011

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Updated for ultra-high I/O (“U”) devices.</td>
</tr>
</tbody>
</table>

### Revision 1.0, November 2010

<table>
<thead>
<tr>
<th>Section</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>All</td>
<td>Initial release.</td>
</tr>
</tbody>
</table>