# LogiCORE IP Soft Error Mitigation Controller v3.4.1

**Product Guide** 

PG036 September 30, 2015





# **Table of Contents**

### **SECTION I: SUMMARY**

### **IP Facts**

### **Chapter 1: Overview**

| Nemory Types          | . 7 |
|-----------------------|-----|
| Nitigation Approaches | . 8 |
| eliability Estimation | . 9 |
| eature Summary        | 10  |
| pplications           | 10  |
| nsupported Features   | 11  |
| icensing              | 11  |

### **Chapter 2: Product Specification**

| Features             | 13 |
|----------------------|----|
| Standards Compliance | 14 |
| Resource Utilization | 14 |
| Performance          | 18 |
| Port Descriptions    | 35 |

### **Chapter 3: Designing with the Core**

| Interfaces                   | 42 |
|------------------------------|----|
| Behaviors                    | 66 |
| Systems                      | 81 |
| Customizations               | 82 |
| Data Consistency             | 88 |
| Configuration Memory Masking | 88 |
| Clocking                     | 90 |
| Resets                       | 91 |
| Additional Considerations    | 91 |

### **E** XILINX.

### SECTION II: VIVADO DESIGN SUITE

### Chapter 4: Customizing and Generating the Core

| GUI                                       | . 94 |
|-------------------------------------------|------|
| Output Generation                         | 101  |
| Generating and Using ChipScope Tool Files | 101  |
| Integration and Validation                | 103  |

### **Chapter 5: Constraining the Core**

| Required Constraints                           | 106 |
|------------------------------------------------|-----|
| Contents of the Xilinx Design Constraints File | 106 |
| Device, Package, and Speed Grade               | 112 |
| Clock Frequency                                | 112 |
| Clock Management                               | 112 |
| Clock Placement                                | 112 |
| I/O Pins                                       | 112 |

### **Chapter 6: Detailed Example Design**

| Functions                        | 114 |
|----------------------------------|-----|
| Port Descriptions                | 117 |
| Demonstration Test Bench         | 121 |
| Implementation                   | 121 |
| External Memory Programming File | 124 |
| Simulation                       | 127 |

### SECTION III: ISE DESIGN SUITE

### **Chapter 7: Customizing and Generating the Core**

| Creating a Project                        | 129 |
|-------------------------------------------|-----|
| Customizing and Generating the Core       | 130 |
| Output Generation                         | 137 |
| Generating and Using ChipScope Tool Files | 138 |
| Integration and Validation                | 140 |

### **Chapter 8: Constraining the Core**

| Required Constraints                  | 142 |
|---------------------------------------|-----|
| Contents of the User Constraints File | 142 |
| Device, Package, and Speed Grade      | 147 |
| Clock Frequency                       | 147 |

### **E** XILINX.

| Clock Management | 147 |
|------------------|-----|
| Clock Placement  | 147 |
| I/O Pins         | 147 |

### **Chapter 9: Detailed Example Design**

| Functions                          | 149 |
|------------------------------------|-----|
| Port Descriptions                  | 151 |
| Simulation                         | 153 |
| Demonstration Test Bench           | 153 |
| Implementation in ISE Design Suite | 154 |
| External Memory Programming File   | 155 |
| Directory and File Contents        | 156 |

### SECTION IV: APPENDICES

### Appendix A: Verification, Compliance, and Interoperability

| Verification        | 161 |
|---------------------|-----|
| Validation          | 162 |
| Conformance Testing | 162 |

### **Appendix B: Migrating**

| Customization and Generation Changes | 163 |
|--------------------------------------|-----|
| Port Changes                         | 163 |
| Functionality Changes                | 163 |

### Appendix C: Debugging

| Finding Help on Xilinx.com | 164 |
|----------------------------|-----|
| Debug Tools                | 166 |
| Hardware Debug             | 167 |
| Interface Debug            | 168 |
| Clocking                   | 169 |

### Appendix D: Additional Resources

| Xilinx Resources     | 170 |
|----------------------|-----|
| Solution Centers     | 170 |
| References           | 170 |
| Technical Support    | 171 |
| Revision History     | 171 |
| Notice of Disclaimer | 172 |



# SECTION I: SUMMARY

**IP Facts** 

Overview

**Product Specification** 

Designing with the Core

### **IP Facts**

# 

# Introduction

The LogiCORE<sup>™</sup> IP Soft Error Mitigation (SEM) Controller is an automatically configured, pre-verified solution to detect and correct soft errors in Configuration Memory of Xilinx FPGAs. Soft errors are unintended changes to the values stored in state elements caused by ionizing radiation.

The SEM Controller does not prevent soft errors; however, it provides a method to better manage the system-level effects of soft errors. Proper management of these events can increase reliability and availability, and reduce system maintenance and downtime costs.

# Features

- Typical detection latency of 25 ms in many devices.
- Integration of built-in silicon primitives to fully leverage and improve upon the inherent error detection capability of the FPGA.
- Optional error correction, using selectable method: repair, enhanced repair, or replace.
  - Correction by repair method is ECC algorithm based.
  - Correction by enhanced repair method is ECC and CRC algorithm based (7 series devices only).
  - Correction by replace method is data re-load based (Virtex ®-6 and 7 series devices only).
- Using Xilinx Essential Bits technology, optional error classification to determine if a soft error has affected the function of the user design.
  - Increases uptime by avoiding disruptive recovery approaches for errors that have no real effect on design operation.
  - Reduces effective failures-in-time (FIT).
- Optional error injection to support evaluation of SEM Controller applications.

| LogiCORE IP Facts Table                      |                                                                                    |  |  |  |  |  |
|----------------------------------------------|------------------------------------------------------------------------------------|--|--|--|--|--|
|                                              | Core Specifics                                                                     |  |  |  |  |  |
| Supported<br>Device<br>Family <sup>(1)</sup> | Zynq®-7000 <sup>(2)</sup> , Kintex®-7, Virtex-7,<br>Artix®-7, Virtex-6, Spartan®-6 |  |  |  |  |  |
| Supported<br>User Interfaces                 | RS-232, SPI                                                                        |  |  |  |  |  |
| Resources                                    | See Table 2-2 through Table 2-7                                                    |  |  |  |  |  |
|                                              | Provided with Core                                                                 |  |  |  |  |  |
| Design Files                                 | Vivado: Encrypted RTL<br>ISE: NGC                                                  |  |  |  |  |  |
| Example<br>Design                            | VHDL and Verilog                                                                   |  |  |  |  |  |
| Test Bench                                   | Not Applicable <sup>(3)</sup>                                                      |  |  |  |  |  |
| Constraints<br>File                          | Vivado: XDC<br>ISE: UCF                                                            |  |  |  |  |  |
| Simulation<br>Model                          | Not Applicable <sup>(3)</sup>                                                      |  |  |  |  |  |
| Supported<br>S/W Driver                      | N/A                                                                                |  |  |  |  |  |
|                                              | Tested Design Flows                                                                |  |  |  |  |  |
| Design Entry                                 | Vivado® Design Suite v2012.4 <sup>(4)</sup><br>ISE™ Design Suite v14.4             |  |  |  |  |  |
| Simulation <sup>(5)</sup>                    | Not Applicable <sup>(3)</sup>                                                      |  |  |  |  |  |
| Synthesis <sup>(5)</sup>                     | Synopsys Synplify Pro<br>Xilinx XST<br>Vivado Synthesis                            |  |  |  |  |  |
|                                              | Support                                                                            |  |  |  |  |  |

Provided by Xilinx @ www.xilinx.com/support

#### Notes:

- 1. For a complete listing of supported devices, see the <u>release</u> <u>notes</u> for this core.
- 2. Supported in ISE Design Suite implementations only.
- 3. Functional and timing simulation of designs that include the SEM Controller is supported. However, it is not possible to observe the SEM Controller behaviors in simulation. Hardware-based evaluation is required.
- 4. Supports only 7 series devices.
- 5. For the supported versions of the tools, see the <u>Xilinx Design</u> <u>Tools: Release Notes Guide</u>.



# Overview

Ionizing radiation is capable of inducing undesired effects in most silicon devices. Broadly, an undesired effect resulting from a single event is called a single event effect (SEE). In most cases, these events do not permanently damage the silicon device; SEEs that result in no permanent damage to the device are called soft errors. However, soft errors have the potential to reduce reliability.

Xilinx devices are designed to have an inherently low susceptibility to soft errors. However, Xilinx also recognizes that soft errors are unavoidable within commercial and practical constraints. As a result, Xilinx has integrated soft error detection and correction capability into many device families.

In many applications, soft errors can be ignored. In applications where higher reliability is desired, the integrated soft error detection and correction capability is usually sufficient. In demanding applications, the SEM Controller can ensure an even higher level of reliability.

# **Memory Types**

If a soft error occurs, one or more memory bits are corrupted. The memory bits affected can be in the device configuration memory (which determines the behavior of the design), or may be in design memory elements (which determine the state of the design). The following four memory categories represent a majority of the memory in a device:

- **Configuration Memory.** Storage elements used to configure the function of the design loaded into the device. This includes function block behavior and function block connectivity. This memory is physically distributed across the entire device and represents the largest number of bits. Only a fraction of the bits are essential to the proper operation of any specific design loaded into the device.
- **Block Memory**. High capacity storage elements used to store design state. As the name implies, the bits are clustered into a physical block, with several blocks distributed across the entire device. Block Memory represents the second largest number of bits.
- **Distributed Memory**. Medium capacity storage elements used to store design state. This type of memory is present in certain configurable logic blocks (CLBs) and is distributed across the entire device. Distributed Memory represents the third largest number of bits.



• **Flip-Flops**. Low capacity storage elements used to store design state. This type of memory is present in all configurable logic blocks (CLBs) and is distributed across the entire device. Flip-Flops represent the fourth largest number of bits.

An extremely small number of additional memory bits exist as internal device control registers and state elements. Soft errors occurring in these areas can result in regional or device-wide interference that is referred to as a single-event functional interrupt (SEFI). Due to the small number of these memory bits, the frequency of SEFI events is considered negligible in this discussion, and these infrequent events are not addressed by the SEM Controller.

# **Mitigation Approaches**

Soft error mitigation for design state in Block Memory, Distributed Memory, and Flip-Flops can be performed in the design itself, by applying standard techniques such as error detection and correction codes or redundancy. Soft errors in unused design state resources (those physically present in the device, but unused by the design) are ignored. Designers concerned about reliability must assess risk areas in the design and incorporate mitigation techniques for the design state as warranted.

Soft error mitigation for the design function in Configuration Memory is performed using error detection and correction codes.

Configuration Memory is organized as an array of frames, much like a wide static RAM. In many device families, each frame is protected by ECC, with the entire array of frames protected by CRC in all device families. The two techniques are complementary; CRC is incredibly robust for error detection, while ECC provides high resolution of error location.

The SEM Controller builds upon the robust capability of the integrated logic by adding optional capability to classify Configuration Memory errors as either "essential" or "non-essential." This leverages the fact that only a fraction of the Configuration Memory bits are essential to the proper operation of any specific design.

Without error classification, all Configuration Memory errors must be considered "essential." With error classification, most errors will be assessed "non-essential" which eliminates false alarms and reduces the frequency of errors that require a potentially disruptive system-level mitigation response.

Additionally, the SEM Controller extends the built-in correction capability to accelerate error detection and provides the optional capability to handle multi-bit errors.

If the features offered by the SEM Controller are not required, the integrated soft error detection and correction capability in the silicon should be sufficient for SEU mitigation. See the relevant FPGA Configuration User Guide for information on how to use the built-in error detection and correction capability.

# **Reliability Estimation**

As a starting point, a designer's specification for system reliability should highlight critical sections of the system design and provide a value for the required reliability of each sub-section. Reliability requirements are typically expressed as failures in time (FIT), which is the number of design failures that can be expected in 10<sup>9</sup> hours (approximately 114,155 years).

When more than one instance of a design is deployed, the probability of a soft error affecting any one of them increases proportionately. For example, if the design is shipped in 1,000 units of product, the nominal FIT across all deployed units is 1,000 times greater. This is an important consideration because the nominal FIT of the total deployment can grow large and can represent a service or maintenance burden.

The nominal FIT is different from the probability of an individual unit being affected. Also, the probability of a specific unit incurring a second soft error is determined by the FIT of the individual design and not the deployment. This is an important consideration when assessing suitable soft error mitigation strategies for an application.

The FIT associated with soft errors must not be confused with that of product life expectancy, which considers the replacement or physical repair of some part of a system.

Xilinx device FIT data is reported in the *Xilinx Device Reliability Report* (UG116) [Ref 1]. The data reveals the overall infrequency of soft errors.

**TIP:** It is important to note that the failure rates involved are so small that most designs need not include any form of soft error mitigation.

The contribution to FIT from flip-flops is negligible based on the flip-flop's very low FIT and small quantity. However, this does not discount the importance of protecting the design state stored in flip-flops. If any state stored in flip-flops is highly important to design operation, the design must contain logic to detect, correct, and recover from soft errors in a manner appropriate to the application.

The contribution to FIT from Distributed Memory and Block Memory can be large in designs where these resources are highly utilized. As previously noted, the FIT contribution can be substantially decreased by using soft error mitigation techniques in the design. For example, Block Memory resources include built-in error detection and correction circuits that can be used in certain Block Memory configurations. For all Block Memory and Distributed Memory configurations, soft error mitigation techniques can be applied using programmable logic resources.

The contribution to FIT from Configuration Memory is large. Without using an error classification technique, all soft errors in Configuration Memory must be considered "essential," and the resulting contribution to FIT eclipses all other sources combined. Use of

error classification reduces the contribution to FIT by no longer considering most soft errors as failures; if a soft error has no effect, it can be corrected without any disruption.

In designs requiring the highest level of reliability, classification of soft errors in Configuration Memory is essential. This capability is provided by the SEM Controller.

### **Feature Summary**

The SEM Controller implements five main functions: initialization, error injection, error detection, error correction, and error classification. All functions, except initialization and detection, are optional; desired functions are selected during the IP core configuration and generation process.

The SEM Controller initializes by bringing the integrated soft error detection capability of the FPGA into a known state after the FPGA enters user mode. After this initialization, the SEM Controller observes the integrated soft error detection status. When an ECC or CRC error is detected, the SEM Controller evaluates the situation to identify the Configuration Memory location involved.

If the location can be identified, the SEM Controller optionally corrects the soft error by repairing it or by replacing the affected bits. The repair methods use active partial reconfiguration to perform a localized correction of Configuration Memory using a read-modify-write scheme. These methods use algorithms to identify the error in need of correction. The replace method also uses active partial reconfiguration with the same goal, but this method uses a write-only scheme to replace Configuration Memory with original data. This data is provided by the implementation tools and stored outside the SEM Controller.

The SEM Controller optionally classifies the soft error as essential or non-essential using a lookup table. Information is fetched as needed during execution of error classification. This data is also provided by the implementation tools and stored outside the SEM Controller.

When the SEM Controller is idle, it optionally accepts input from the user to inject errors into Configuration Memory. This feature is useful for testing the integration of the SEM Controller into a larger system design. Using the error injection feature, system verification and validation engineers can construct test cases to ensure the complete system responds to soft error events as expected.

# **Applications**

Although the SEM Controller can operate autonomously, most applications use the solution in conjunction with an application-level supervisory function. This supervisory function

monitors the event reporting from the SEM Controller and determines if additional actions are necessary (for example, reconfigure the device or reset the application).

System designers are encouraged to carefully consider each design's reliability requirements and system-level supervisory functions to make informed decisions.

Is an error mitigation solution even required? Is the solution built into the target device sufficient for the application requirements, or is the SEM Controller required? If the SEM Controller is required, what features should be used?

When the SEM Controller is the best choice for the application, Xilinx recommends that the SEM Controller is used as provided, including the system-level design example components for interfacing with external devices. However, these interfaces can be modified if required for the application.



**RECOMMENDED:** Xilinx recommends integrating the SEM IP core as early as possible, ideally at the start of the project. For more information, see Integration and Validation, page 103.

### **Unsupported Features**

The SEM Controller does not operate on soft errors in block memory, distributed memory, or flip-flops. Soft error mitigation in these memory resources must be addressed by the user logic through preventive measures such as redundancy or error detection and correction codes.

The SEM Controller does not operate on soft errors in state elements contained within hardened processor systems, such as those found in Xilinx Zynq-7000 devices. Soft error mitigation in these memory resources must be addressed through software running on the processor system.

Unsupported features and specific limitations include functional, implementation, and use considerations. For more details, see Additional Considerations in Chapter 3.

# Licensing

This Xilinx LogiCORE IP module is provided at no additional cost with the Xilinx Vivado® Design Suite and ISE<sup>™</sup> Design Suite software under the terms of the Xilinx End User License. The core can be accessed through the Vivado Design Suite and ISE CORE Generator IP catalog.

Information about this and other Xilinx LogiCORE IP modules is available at the <u>Xilinx</u> <u>Intellectual Property</u> page. For information about pricing and availability of other Xilinx LogiCORE modules and software, please contact your <u>local Xilinx sales representative</u>.



# **XILINX**<sub>®</sub>

# **Product Specification**

This chapter contains the specification of the LogiCORE IP Soft Error Mitigation (SEM) Controller. This configurable controller for mitigation of soft errors in configuration memory also comes with a system-level example design showing use of the controller in a system.

### Features

The SEM controller includes:

- Integration of silicon features to leverage built-in error detection capability.
- Implementation of error correction capability to support correction of soft errors. The error correction method can be defined as:
  - Repair: ECC algorithm-based correction. This method supports correction of configuration memory frames with single-bit errors. This covers correction of all single-bit upset events. It also covers correction of multi-bit upset events when errors are distributed one per frame as a result of configuration memory interleaving.
  - **Enhanced Repair**: ECC and CRC algorithm-based correction. This method supports correction of configuration memory frames with single-bit errors or double-bit adjacent errors. This covers correction of all single-bit upset events and all double-bit adjacent upset events. This also covers correction of multi-bit upset events when errors are distributed one or two adjacent per frame as a result of configuration memory interleaving (7 series devices only).
  - **Replace**: Data reload based correction. This method supports correction of configuration memory frames with arbitrary errors. This covers correction of any upset event that can be resolved to specific configuration memory frames, even if the exact bit locations in the frames cannot be determined (Virtex-6 and 7 series devices only).
- Implementation of error classification capability to determine if corrected errors have affected configuration memory in locations essential to the function of the design.
- Provision for error injection to support verification of the controller and evaluation of applications of the controller.

The example design includes:

- Instantiation of the user-configured controller.
- An interface between the controller and external storage. This is required when the controller is configured to perform error classification or error correction by replace.
- An interface between the controller and an external processor for ease of use when the controller is configured to perform error injection.

### **Standards Compliance**

No standards compliance or certification testing is defined. The SEM Controller is exposed to a beam of accelerated particles as part of an extensive hardware validation process.

### **Resource Utilization**

Resource utilization metrics for the SEM Controller are derived from post-synthesis reports and are for budgetary purposes only. Actual resource utilization may vary.

| Device                                    | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs          |
|-------------------------------------------|----------------------------------------------|------|-----|------|---------------------|
| Zynq-7000<br>All Devices                  | Complete solution with no optional features  | 433  | 322 | 11   | 3 RAMB18            |
| Zynq-7000<br>XC7Z010                      | Complete solution with all optional features | 835  | 506 | 56   | 3 RAMB18, 2 RAMB36  |
| Zynq-7000<br>XC7Z020                      | Complete solution with all optional features | 835  | 506 | 56   | 3 RAMB18, 3 RAMB36  |
| Zynq-7000<br>XC7Z030                      | Complete solution with all optional features | 869  | 508 | 56   | 3 RAMB18, 5 RAMB36  |
| Zynq-7000<br>XC7Z045                      | Complete solution with all optional features | 975  | 510 | 56   | 3 RAMB18, 10 RAMB36 |
| Zynq-7000A,<br>Zynq-7000Q,<br>All Devices | Same as Zynq-7000                            |      | ·   | ·    |                     |

Table 2-1: Resource Utilization for Zynq-7000 Devices<sup>(1)(2)</sup>

#### Notes:

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

| Device                                                       | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs          |
|--------------------------------------------------------------|----------------------------------------------|------|-----|------|---------------------|
| Kintex-7<br>All Devices                                      | Complete solution with no optional features  | 433  | 322 | 11   | 3 RAMB18            |
| Kintex-7<br>XC7K70T                                          | Complete solution with all optional features | 835  | 506 | 56   | 3 RAMB18, 3 RAMB36  |
| Kintex-7<br>XC7K160T                                         | Complete solution with all optional features | 869  | 508 | 56   | 3 RAMB18, 5 RAMB36  |
| Kintex-7<br>XC7K325T                                         | Complete solution with all optional features | 974  | 510 | 56   | 3 RAMB18, 9 RAMB36  |
| Kintex-7<br>XC7K355T                                         | Complete solution with all optional features | 975  | 510 | 56   | 3 RAMB18, 10 RAMB36 |
| Kintex-7<br>XC7K410T                                         | Complete solution with all optional features | 1005 | 510 | 56   | 3 RAMB18, 11 RAMB36 |
| Kintex-7<br>XC7K420T                                         | Complete solution with all optional features | 1040 | 510 | 56   | 3 RAMB18, 13 RAMB36 |
| Kintex-7<br>XC7K480T                                         | Complete solution with all optional features | 1040 | 510 | 56   | 3 RAMB18, 13 RAMB36 |
| Kintex-7 -2L,<br>Kintex-7Q,<br>Kintex-7Q -2L,<br>All Devices | Same as Kintex-7                             |      |     | ·    |                     |

Table 2-2: Resource Utilization for Kintex-7 Devices<sup>(1)(2)</sup>

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

 Table 2-3:
 Resource Utilization for Virtex-7 Devices (Non-SSI)<sup>(1)(2)</sup>

| Device                  | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs          |
|-------------------------|----------------------------------------------|------|-----|------|---------------------|
| Virtex-7<br>All Devices | Complete solution with no optional features  | 433  | 322 | 11   | 3 RAMB18            |
| Virtex-7<br>XC7VX330T   | Complete solution with all optional features | 975  | 510 | 56   | 3 RAMB18, 10 RAMB36 |
| Virtex-7<br>XC7VX415T   | Complete solution with all optional features | 1005 | 510 | 56   | 3 RAMB18, 12 RAMB36 |
| Virtex-7<br>XC7VX485T   | Complete solution with all optional features | 1074 | 510 | 56   | 3 RAMB18, 14 RAMB36 |
| Virtex-7<br>XC7VX550T   | Complete solution with all optional features | 1179 | 512 | 56   | 3 RAMB18, 20 RAMB36 |
| Virtex-7<br>XC7V585T    | Complete solution with all optional features | 1042 | 510 | 56   | 3 RAMB18, 15 RAMB36 |
| Virtex-7<br>XC7VX690T   | Complete solution with all optional features | 1179 | 512 | 56   | 3 RAMB18, 20 RAMB36 |

| Device                   | IP Core Configuration                        | LUTs | FFs | I/Os     | Block RAMs          |
|--------------------------|----------------------------------------------|------|-----|----------|---------------------|
| Virtex-7<br>XC7VX980T    | Complete solution with all optional features | 1317 | 512 | 56       | 3 RAMB18, 26 RAMB36 |
| Virtex-7Q<br>All Devices | Same as Virtex-7                             |      |     | <u>.</u> |                     |

Table 2-3: Resource Utilization for Virtex-7 Devices (Non-SSI)<sup>(1)(2)</sup> (Cont'd)

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

2. The Error Injection Interface is connected to I/Os; use of ChipScope increases LUTs/FFs but decreases I/Os.

| Device                    | IP Core Configuration                        | LUTs | FFs  | I/Os | Block RAMs           |
|---------------------------|----------------------------------------------|------|------|------|----------------------|
| Virtex-7<br>XC7VH580T     | Complete solution with no optional features  | 1289 | 878  | 19   | 7 RAMB18             |
| Virtex-7<br>XC7VH580T     | Complete solution with all optional features | 2303 | 1336 | 64   | 7 RAMB18, 18 RAMB36  |
| Virtex-7<br>XC7VH870T     | Complete solution with no optional features  | 1741 | 1206 | 27   | 10 RAMB18            |
| Virtex-7<br>XC7VH870T     | Complete solution with all optional features | 3210 | 1856 | 72   | 10 RAMB18, 27 RAMB36 |
| Virtex-7<br>XC7VX1140T    | Complete solution with no optional features  | 2196 | 1534 | 35   | 13 RAMB18            |
| Virtex-7<br>XC7VX1140T    | Complete solution with all optional features | 4119 | 2376 | 80   | 13 RAMB18, 36 RAMB36 |
| Virtex-7<br>XC7V2000T     | Complete solution with no optional features  | 2195 | 1534 | 35   | 13 RAMB18            |
| Virtex-7<br>XC7V2000T     | Complete solution with all optional features | 4397 | 2376 | 80   | 13 RAMB18, 48 RAMB36 |
| Virtex-7Q,<br>All Devices | Same as Virtex-7                             |      | •    |      |                      |

Table 2-4: Resource Utilization for Virtex-7 Devices (SSI)<sup>(1)(2)</sup>

#### Notes:

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

| dulle 2-5. Resource offiziation for Artik-7 Devices and |                       |      |     |      |  |  |
|---------------------------------------------------------|-----------------------|------|-----|------|--|--|
| Device                                                  | IP Core Configuration | LUTs | FFs | I/Os |  |  |
|                                                         |                       |      |     |      |  |  |

| Table 2-5:        | Resource Utilization for Artix-7 Devices <sup>(1)(2</sup> |
|-------------------|-----------------------------------------------------------|
| <i>Tuble 2-5:</i> | Resource Utilization for Artix-7 Devices *                |

| Device                 | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs         |
|------------------------|----------------------------------------------|------|-----|------|--------------------|
| Artix-7<br>All Devices | Complete solution with no optional features  | 433  | 322 | 11   | 3 RAMB18           |
| Artix-7<br>XC7A100T    | Complete solution with all optional features | 835  | 506 | 56   | 3 RAMB18, 3 RAMB36 |
| Artix-7<br>XC7A200T    | Complete solution with all optional features | 900  | 508 | 56   | 3 RAMB18, 7 RAMB36 |

DeviceIP Core ConfigurationLUTsFFsI/OsBlock RAMsArtix-7 -2L,<br/>Artix-7A,<br/>Artix-7Q,<br/>Artix-7Q, Artix-7Q -2L,<br/>All DevicesSame as Artix-7

 Table 2-5:
 Resource Utilization for Artix-7 Devices<sup>(1)(2)</sup>

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

2. The Error Injection Interface is connected to I/Os; use of ChipScope increases LUTs/FFs but decreases I/Os.

| Device                                                      | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs |
|-------------------------------------------------------------|----------------------------------------------|------|-----|------|------------|
| Virtex-6<br>All Devices                                     | Complete solution with no optional features  | 402  | 315 | 11   | 3 RAMB18   |
| Virtex-6<br>All Devices                                     | Complete solution with all optional features | 459  | 383 | 52   | 3 RAMB18   |
| Virtex-6 -1L,<br>Virtex-6Q,<br>Virtex-6Q -1L<br>All Devices | Same as Virtex-6                             |      |     | L    |            |

Table 2-6: Resource Utilization for Virtex-6 Devices<sup>(1)(2)</sup>

#### Notes:

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

Table 2-7: Resource Utilization for Spartan-6 Devices<sup>(1)(2)</sup>

| Device      | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs        |
|-------------|----------------------------------------------|------|-----|------|-------------------|
| Spartan-6   | Complete solution with no optional features  | 694  | 393 | 11   | 4 RAMB16, 1 RAMB8 |
| XC6SLX4     | Complete solution with all optional features | 795  | 458 | 52   | 4 RAMB16, 1 RAMB8 |
| Spartan-6   | Complete solution with no optional features  | 695  | 393 | 11   | 4 RAMB16, 1 RAMB8 |
| XC6SLX9     | Complete solution with all optional features | 797  | 458 | 52   | 4 RAMB16, 1 RAMB8 |
| Spartan-6   | Complete solution with no optional features  | 698  | 393 | 11   | 6 RAMB16          |
| XC6SLX16    | Complete solution with all optional features | 794  | 458 | 52   | 6 RAMB16          |
| Spartan-6   | Complete solution with no optional features  | 718  | 393 | 11   | 7 RAMB16          |
| XC6SLX25(T) | Complete solution with all optional features | 808  | 458 | 52   | 7 RAMB16          |

| Device                                                                                        | IP Core Configuration                        | LUTs | FFs | I/Os | Block RAMs |
|-----------------------------------------------------------------------------------------------|----------------------------------------------|------|-----|------|------------|
| Spartan-6                                                                                     | Complete solution with no optional features  | 715  | 393 | 11   | 10 RAMB16  |
| XC6SLX45(T)                                                                                   | Complete solution with all optional features | 814  | 458 | 52   | 10 RAMB16  |
| Spartan-6                                                                                     | Complete solution with no optional features  | 696  | 393 | 11   | 15 RAMB16  |
| XC6SLX75(T)                                                                                   | Complete solution with all optional features | 794  | 458 | 52   | 15 RAMB16  |
| Spartan-6                                                                                     | Complete solution with no optional features  | 717  | 393 | 11   | 18 RAMB16  |
| XC6SLX100(T)                                                                                  | Complete solution with all optional features | 812  | 457 | 52   | 18 RAMB16  |
| Spartan-6                                                                                     | Complete solution with no optional features  | 725  | 393 | 11   | 24 RAMB16  |
| XC6SLX150(T)                                                                                  | Complete solution with all optional features | 821  | 457 | 52   | 24 RAMB16  |
| Spartan-6 -1L,<br>Spartan-6Q,<br>Spartan-6Q<br>-1L,<br>Automotive<br>Spartan-6<br>All Devices | Same as Spartan-6                            |      |     |      |            |

Table 2-7: Resource Utilization for Spartan-6 Devices<sup>(1)(2)</sup> (Cont'd)

1. The complete solution is the SEM Controller and the example design, which are intended to be used together.

2. The Error Injection Interface is connected to I/Os; use of ChipScope increases LUTs/FFs but decreases I/Os.

### Performance

Performance metrics for the SEM Controller are derived from silicon specifications and direct measurement, and are for budgetary purposes only. Actual performance may vary.

### **Solution Reliability**

The system-level design example is analyzed in the following section to provide an estimate of the FIT of the solution itself, as implemented in the FPGA. This analysis method is also appropriate for generating estimates of other circuits implemented in the FPGA.



In this analysis, all features are considered enabled, with all signals brought to I/O pins. ChipScope<sup>™</sup> analyzer is specifically excluded from analysis, as it is unlikely a production design will include this interactive debug and experimentation capability. As a result, the estimate represents an upper bound.

### **Estimation Data**

Xilinx device FIT data is reported in the *Xilinx Device Reliability Report* (UG116) [Ref 1]. Table 2-8 provides example data for a sample reliability estimation.

**Note:** The data in Table 2-8 is an example. This example data is for illustrative purposes only and must not be used in critical design decisions. See the *Xilinx Device Reliability Report* (UG116) [Ref 1] for current device FIT data.

| Device    | Memory Cell Type                                  | Real Time Soft Error Rate<br>FIT/Mbit |
|-----------|---------------------------------------------------|---------------------------------------|
|           | Configuration Memory                              | 77                                    |
| 7 Series  | Block Memory                                      | 69                                    |
| FPGAs     | Distributed Memory (same as Configuration Memory) | 77                                    |
|           | Flip-flops                                        | Unspecified                           |
|           | Configuration Memory                              | 101                                   |
| Virtex-6  | Block Memory                                      | 245                                   |
| FPGAs     | Distributed Memory (same as Configuration Memory) | 101                                   |
|           | Flip-flops                                        | Unspecified                           |
|           | Configuration Memory                              | 185                                   |
| Spartan-6 | Block Memory                                      | 388                                   |
| FPGAs     | Distributed Memory (same as Configuration Memory) | 185                                   |
|           | Flip-flops                                        | Unspecified                           |

Table 2-8: Example Device FIT Data

Table 2-9 provides an approximate relationship between resources and the number of configuration memory cells associated with each resource.

Table 2-9: Configuration Bits Per Device Feature

| Device   | Device Feature<br>(Includes Routing) | Approximate Number<br>of Configuration Bits |
|----------|--------------------------------------|---------------------------------------------|
|          | Logic Slice                          | 1,166                                       |
| 7 Series | Block RAM (36 Kb)                    | 9,396                                       |
| FPGAs    | Block RAM (18 Kb)                    | 4,698                                       |
|          | I/O Block                            | 2,850                                       |

| Device    | Device Feature<br>(Includes Routing) | Approximate Number<br>of Configuration Bits |
|-----------|--------------------------------------|---------------------------------------------|
|           | Logic Slice                          | 1,166                                       |
| Virtex-6  | Block RAM (36 Kb)                    | 9,396                                       |
| FPGAs     | Block RAM (18 Kb)                    | 4,698                                       |
|           | I/O Block                            | 2,850                                       |
|           | Logic Slice                          | 1,166                                       |
| Spartan-6 | Block RAM (18 Kb)                    | 4,698                                       |
| FPGAs     | Block RAM (9 Kb)                     | 2,349                                       |
|           | I/O Block                            | 2,850                                       |

Table 2-9: Configuration Bits Per Device Feature

Typically fewer than 10% of configuration memory cells directly impact the active design if a soft error occurs. Therefore, the sample reliability estimation uses a 10% de-rating factor.

### Sample 7 Series Reliability Estimation (Non-SSI Devices)

The controller and shims use approximately 250 logic slices, 56 I/O blocks, three block RAM (18 Kb), and nine block RAM (36 Kb) in a mid-size XC7K325T device, with all optional features enabled. Consider the configuration bit contribution:

Config FIT = 10% \* (250 \* 1,166 + 56 \* 2,850 + 3 \* 4,698 + 9 \* 9,396) \* 77 FIT/Mbit

Config FIT = 4.0 FIT

The controller and shims use several hundred flip-flops for data, their contribution is ignored due to the small number of bits.

The controller and shims use 65 LUT RAM. The usage breakdown is as follows:

- The MON shim uses 31 LUT RAM for data buffering, but the buffers are generally empty and data corruption not observable. These memory bits are therefore ignored.
- The controller uses 34 LUT RAM for data storage. Errors in used locations are highly likely halt the controller. Approximately 416 memory bits are used.

LUT RAM FIT = 100% \* 416 \* 77 FIT/Mbit

LUT RAM FIT = 0.03 FIT

The controller uses three block RAM (18 Kb) and nine block RAM (36 Kb). The usage breakdown is:

• An internal buffer uses one block RAM. In the data array, 9600 bits are allocated to data buffers used in correction and classification; a soft error here would only cause potential issue if it occurred *during* mitigation activity. No permanent data resides here;

these are therefore ignored. Another 7480 bits are allocated to constant storage; errors in these locations are highly likely to break the controller and must be considered in the analysis. The remaining 1352 bits are unused.

- The controller firmware resides in two block RAMs. The word count is approximately 1932 out of 2048, with at least 336 of the used words only executed one time at system start and therefore ignored. The number of bits considered for the analysis is 28728.
- The enhanced repair algorithm within the controller stores frame-level CRCs in the remaining block RAM (36 Kb). These block RAM contents are protected by built-in ECC of the block RAM, and do not contribute to the block RAM Bit FIT. As computed above, these block RAMs do contribute to the Configuration Bit FIT.

Block RAM FIT = 100% \* 36208 \* 69 FIT/Mbit

Block RAM FIT = 2.4 FIT

The total controller FIT is then:

4.0 FIT + 0.03 FIT + 2.4 FIT  $\approx$  6.5 FIT

### Sample 7 Series Reliability Estimation (SSI Devices)

The controller and shims use approximately 1024 logic slices, 80 I/O blocks, 13 block RAM (18 Kb), and 36 block RAM (36 Kb) in a large XC7VX1140T device, with all optional features enabled. Consider the configuration bit contribution:

Config FIT = 10% \* (1024 \* 1,166 + 80 \* 2,850 + 13 \* 4,698 + 36 \* 9,396) \* 77 FIT/Mbit

Config FIT = 13.4 FIT

The controller and shims use several hundred flip flops for data. Their contribution is ignored due to the small number of bits.

Each controller contains 21 LUT RAM:

• The LUT RAMs are used for data storage (stack, registers, and scratchpad). Errors in the used locations are highly likely to halt the controller. Approximately 416 memory bits are used.

The MON shim contains 57 LUT RAM:

- Some LUT RAMs are used for data storage (stack and registers). Errors in the used locations are highly likely to halt the MON shim. Approximately 160 memory bits are used.
- Some LUT RAMs are used for data buffering, but the buffers are generally empty and data corruption not observable. These memory bits are therefore ignored.

LUT RAM FIT = 100% \* (4 \* 416 + 1 \* 160) \* 77 FIT/Mbit

LUT RAM FIT = 0.13 FIT

Each controller contains three block RAM (18 Kb) and nine block RAM (36 Kb):

- An internal buffer uses one block RAM. In the data array, 9,600 bits are allocated to data buffers used in correction and classification; a soft error here would only cause an issue if it occurred during mitigation activity. No permanent data resides here and errors are therefore ignored. Another 7,480 bits are allocated to constant storage; errors in these locations are highly likely to break the controller and must be considered in the analysis. The remaining 1,352 bits are unused.
- The controller firmware resides in two block RAMs. The word count is approximately 1,932 out of 2,048, with at least 336 of the used words only executed at system start and are therefore ignored. The number of bits considered for the analysis is 28,728.
- The enhanced repair algorithm within the controller stores frame-level CRCs in the remaining block RAM (36 Kb). These block RAM contents are protected by the built-in ECC of the block RAM and do not contribute to the Block RAM Bit FIT. As computed above, these block RAMs do contribute to the Configuration Bit FIT.

The MON shim contains 1 block RAM (18 Kb).

• The MON shim firmware uses 1 block RAM. The word count is approximately 420 out of 1,024. The number of bits considered for the analysis is 7,560.

Block RAM FIT = 100% \* (4 \* 36,208 + 1 \* 7,560) \* 69 FIT/Mbit

Block RAM FIT = 10.0 FIT

The total controller FIT is then:

13.4 FIT + 0.13 FIT + 10.0 FIT  $\approx$  23.5 FIT

### Sample Virtex-6 Reliability Estimation

The controller and shims use approximately 148 logic slices, 52 I/O blocks, and 3 block RAM (18 Kb). Consider the configuration bit contribution:

Config FIT = 10% \* (148 \* 1,166 + 52 \* 2,850 + 3 \* 4,698) \* 101 FIT/Mbit

Config FIT = 3.2 FIT

The controller and shims use several hundred flip-flops for data, their contribution is ignored due to the small number of bits.

The controller and shims use 65 LUT RAM. The usage breakdown is as follows:

• The MON shim uses 31 LUT RAM for data buffering, but the buffers are generally empty and data corruption not observable. These memory bits are therefore ignored.

• The controller uses 34 LUT RAM for data storage. Errors in used locations are highly likely halt the controller. Approximately 256 memory bits are used.

LUT RAM FIT = 100% \* 256 \* 101 FIT/Mbit

LUT RAM FIT = 0.02 FIT

The controller uses three block RAM (18 Kb). The usage breakdown is:

- An internal buffer uses one block RAM. In the data array, 10368 bits are allocated to data buffers used in correction and classification; a soft error here would only cause potential issue if it occurred *during* mitigation activity. No permanent data resides here; these are therefore ignored. Another 7552 bits are allocated to constant storage; errors in these locations are highly likely to break the controller and must be considered in the analysis. The remaining 512 bits are unused.
- The controller firmware resides in two block RAMs. The word count is approximately 1550 out of 2048, with at least 150 of the used words only executed one time at system start and therefore ignored. The number of bits considered for the analysis is 25200.

Block RAM FIT = 100% \* 32752 \* 245 FIT/Mbit

Block RAM FIT = 7.7 FIT

The total controller FIT is then:

 $3.2 \text{ FIT} + 0.02 \text{ FIT} + 7.7 \text{ FIT} \approx 11.0 \text{ FIT}$ 

### Sample Spartan-6 Reliability Estimation

The controller and shims use approximately 241 logic slices, 52 I/O blocks, and 10 block RAM (18 Kb) in a mid-size XC6SLX45T device. Consider the configuration bit contribution:

Config FIT = 10% \* (241 \* 1,166 + 52 \* 2,850 + 10 \* 4,698) \* 185 FIT/Mbit

Config FIT = 8.4 FIT

The controller and shims use several hundred flip-flops for data, their contribution is ignored due to the small number of bits.

The controller and shims use 70 LUT RAM. The usage breakdown is as follows:

- The MON shim uses 36 LUT RAM for data buffering, but the buffers are generally empty and data corruption not observable. These memory bits are therefore ignored.
- The controller uses 34 LUT RAM for data storage. Errors in used locations are highly likely halt the controller. Approximately 256 memory bits are used.

LUT RAM FIT = 100% \* 256 \* 185 FIT/Mbit

LUT RAM FIT = 0.05 FIT

The controller uses ten block RAM (18 Kb). The usage breakdown is:

- An internal buffer uses one block RAM. In the data array, 3268 bits are allocated to data buffers used in correction and classification; a soft error here would only cause potential issue if it occurred during mitigation activity. No permanent data resides here; these are therefore ignored. Another 6812 bits are allocated to constant storage; errors in these locations are highly likely to break the controller and must be considered in the analysis. The remaining 8352 bits are unused.
- The controller firmware resides in two block RAMs. The word count is approximately 1732 out of 2048, with at least 444 of the used words only executed one time at system start or as debug and therefore ignored. The number of bits considered for the analysis is 23184.
- The soft logic FRAME ECC module within the controller stores the ECC checksums in the remaining block RAM. These block RAM contents are protected by the FRAME ECC, and do not contribute to the Block RAM Bit FIT. As computed above, these block RAMs do contribute to the Configuration Bit FIT.

Block RAM FIT = 100% \* (6812+23184) \* 388 FIT/Mbit

Block RAM FIT = 11.1 FIT

The total controller FIT is then:

8.4 FIT + 0.05 FIT + 11.1 FIT  $\approx$  19.6 FIT

### **Maximum Frequency**

The maximum frequency of operation of the SEM Controller is not guaranteed. In no case may the maximum frequency of operation exceed the internal configuration access port (ICAP) Fmax specified in the relevant FPGA data sheet as configuration interface AC timing parameter Frbcck. Table 2-10 provides a summary of ICAP Fmax values.

|          | Device              | ICAP F <sub>MAX</sub>  |
|----------|---------------------|------------------------|
|          | Zynq-7000           | 100 MHz <sup>(1)</sup> |
|          | Zynq-7000A          | 100 MHz <sup>(1)</sup> |
|          | Zynq-7000Q          | 100 MHz <sup>(1)</sup> |
|          | Kintex-7            | 100 MHz <sup>(1)</sup> |
| -        | Kintex-7 -2L        | 70 MHz                 |
| -        | Kintex-7Q           | 100 MHz <sup>(1)</sup> |
| -        | Kintex-7Q -2L       | 70 MHz                 |
| 7 Series | Virtex-7 (Non-SSI)  | 100 MHz <sup>(1)</sup> |
| FPGAs    | Virtex-7Q (Non-SSI) | 100 MHz <sup>(1)</sup> |
| -        | Virtex-7 (SSI)      | 70 MHz                 |
| -        | Virtex-7Q (SSI)     | 70 MHz                 |
| -        | Artix-7             | 100 MHz <sup>(1)</sup> |
| -        | Artix-7 -2L         | 70 MHz                 |
| -        | Artix-7Q            | 100 MHz <sup>(1)</sup> |
| -        | Artix-7Q -2L        | 70 MHz                 |
| -        | Artix-7A            | 100 MHz <sup>(1)</sup> |
|          | Virtex-6            | 100 MHz                |
| Virtex-6 | Virtex-6 -1L        | 60 MHz                 |
| FPGAs    | Virtex-6Q           | 100 MHz                |
| -        | Virtex-6Q -1L       | 60 MHz                 |

Table 2-10: ICAP Maximum Frequency

|           | Device                                               |        |  |
|-----------|------------------------------------------------------|--------|--|
|           | Spartan-6<br>XC6SLX4 to XC6SLX75(T)                  | 50 MHz |  |
|           | Spartan-6<br>XC6SLX100(T) to XC6SLX150(T)            | 35 MHz |  |
|           | Spartan-6 -1L<br>XC6SLX4 to XC6SLX75(T)              | 30 MHz |  |
|           | Spartan-6 -1L<br>XC6SLX100(T) to XC6SLX150(T)        | 20 MHz |  |
| Spartan-6 | Spartan-6Q<br>XQ6SLX4 to XQ6SLX75(T)                 | 50 MHz |  |
| FPGAs     | Spartan-6Q<br>XQ6SLX100(T) to XQ6SLX150(T)           | 35 MHz |  |
|           | Spartan-6Q -1L<br>XQ6SLX4 to XQ6SLX75(T)             | 30 MHz |  |
|           | Spartan-6Q -1L<br>XQ6SLX100(T) to XQ6SLX150(T)       | 20 MHz |  |
|           | Automotive Spartan-6<br>XA6SLX4 to XA6SLX75(T)       | 50 MHz |  |
|           | Automotive Spartan-6<br>XA6SLX100(T) to XA6SLX150(T) | 35 MHz |  |

Table 2-10: ICAP Maximum Frequency (Cont'd)

1. CORE Generator maximum clock frequency is 70 MHz. See <u>SEM core release notes</u> for more information.

Other maximum frequency limitations may apply. For more details on determining the maximum frequency of operation for the SEM Controller, see Interfaces in Chapter 3.

### **Solution Latency**

The error mitigation latency of the solution is defined as the total time that elapses between the creation of an error condition and the conclusion of the mitigation process. The mitigation process consists of detection, correction, and classification.

### **Estimation Data**

The solution behaviors are based on processing of FPGA configuration memory frames. Single-bit errors always reside in a single frame. Generally, an *N*-bit error can present in several ways, ranging from one frame containing all bit errors, to *N* frames each containing one bit error. When multiple frames are affected by an error, the sequence of detection, correction, and classification is repeated for each affected frame.

The solution properly mitigates an arbitrary workload of errors. The error mitigation latency estimation of an arbitrary workload is complex. This section focuses on the common case involving a single frame, but provides insight into the controller behavior to aid in understanding other scenarios.

### Start-Up Latency

Start-up latency is the delay between the end of FPGA configuration and the completion of the controller initialization, as marked by entry into the observation state. This latency is a function of the FPGA size (frame count) and the solution clock frequency. It is also a function of the selected correction mode.

The start-up latency is incurred only once. It is not part of the mitigation process. Table 2-11 illustrates start-up latency, decomposed into sub-steps of boot and initialization. The boot time is independent of the selected correction mode, while the initialization time is dependent on the selected correction mode.

|          | Device           | Boot Time at<br>ICAP Fmax | Initialization Time at ICAP<br>Fmax (Repair/Replace) | Initialization Time at ICAP<br>Fmax (Enhanced Repair) |
|----------|------------------|---------------------------|------------------------------------------------------|-------------------------------------------------------|
|          | XC7A100T         | 110 ms                    | 24.1 ms                                              | 2.9 s                                                 |
|          | XC7A200T         | 110 ms                    | 55.4 ms                                              | 6.6 s                                                 |
|          | ХС7К70Т          | 110 ms                    | 17.8 ms                                              | 2.1 s                                                 |
|          | XC7K160T         | 110 ms                    | 38.8 ms                                              | 4.6 s                                                 |
|          | XC7K325T         | 110 ms                    | 71.0 ms                                              | 9.3 s                                                 |
|          | XC7K355T         | 110 ms                    | 79.9 ms                                              | 11.9 s                                                |
|          | XC7K410T         | 110 ms                    | 91.5 ms                                              | 15.4 s                                                |
|          | ХС7К420Т         | 110 ms                    | 106.6 ms                                             | 21.1 s                                                |
|          | XC7K480T         | 110 ms                    | 106.6 ms                                             | 21.1 s                                                |
|          | XC7VX330T        | 110 ms                    | 77.3 ms                                              | 11.1 s                                                |
|          | XC7VX415T        | 110 ms                    | 98.1 ms                                              | 17.7 s                                                |
| 7 Series | XC7VX485T        | 110 ms                    | 115.7 ms                                             | 24.5 s                                                |
| FPGAs    | XC7VX550T        | 110 ms                    | 163.5 ms                                             | 48.7 s                                                |
|          | XC7VH580T (SSI)  | 110 ms                    | 74.3 ms                                              | 10.2 s                                                |
|          | XC7V585T         | 110 ms                    | 124.4 ms                                             | 28.3 s                                                |
|          | XC7VX690T        | 110 ms                    | 163.5 ms                                             | 48.7 s                                                |
|          | XC7VH870T (SSI)  | 110 ms                    | 74.3 ms                                              | 10.2 s                                                |
|          | XC7VX980T        | 110 ms                    | 213.3 ms                                             | 82.6 s                                                |
|          | XC7VX1140T (SSI) | 110 ms                    | 74.3 ms                                              | 10.2 s                                                |
|          | XC7VX2000T (SSI) | 110 ms                    | 95.4 ms                                              | 16.7 s                                                |
|          | XC7Z010          | 110 ms                    | 12.2 ms                                              | 1.5 s                                                 |
|          | XC7Z020          | 110 ms                    | 24.2 ms                                              | 2.9 s                                                 |
|          | XC7Z030          | 110 ms                    | 34.1 ms                                              | 4.1 s                                                 |
|          | XC7Z045          | 110 ms                    | 82.0 ms                                              | 11.8 s                                                |

#### Table 2-11: Start-Up Latency

Table 2-11: Start-Up Latency (Cont'd)

|            | Device                      | Boot Time at<br>ICAP Fmax | Initialization Time at ICAP<br>Fmax (Repair/Replace) | Initialization Time at ICAP<br>Fmax (Enhanced Repair) |
|------------|-----------------------------|---------------------------|------------------------------------------------------|-------------------------------------------------------|
|            | XC6VCX75T                   | 110 ms                    | 18.6 ms                                              | N/A                                                   |
|            | XC6VCX130T                  | 110 ms                    | 31.2 ms                                              | N/A                                                   |
|            | XC6VCX195T                  | 110 ms                    | 45.0 ms                                              | N/A                                                   |
|            | XC6VCX240T                  | 110 ms                    | 54.0 ms                                              | N/A                                                   |
|            | XC6VHX250T                  | 110 ms                    | 56.1 ms                                              | N/A                                                   |
|            | XC6VHX255T                  | 110 ms                    | 56.1 ms                                              | N/A                                                   |
|            | XC6VHX380T                  | 110 ms                    | 84.0 ms                                              | N/A                                                   |
|            | XC6VHX565T                  | 110 ms                    | 117.9 ms                                             | N/A                                                   |
| Virtex-6   | XC6VLX75T                   | 110 ms                    | 18.6 ms                                              | N/A                                                   |
|            | XC6VLX130T                  | 110 ms                    | 31.2 ms                                              | N/A                                                   |
|            | XC6VLX195T                  | 110 ms                    | 45.0 ms                                              | N/A                                                   |
|            | XC6VLX240T                  | 110 ms                    | 54.0 ms                                              | N/A                                                   |
|            | XC6VLX365T                  | 110 ms                    | 75.6 ms                                              | N/A                                                   |
|            | XC6VLX550T                  | 110 ms                    | 113.1 ms                                             | N/A                                                   |
|            | XC6VLX760                   | 110 ms                    | 149.7 ms                                             | N/A                                                   |
|            | XC6VSX315T                  | 110 ms                    | 72.3 ms                                              | N/A                                                   |
|            | XC6VSX475T                  | 110 ms                    | 108.3 ms                                             | N/A                                                   |
|            | XC6SLX4                     | 110 ms                    | 18.2 ms                                              | N/A                                                   |
|            | XC6SLX9                     | 110 ms                    | 18.2 ms                                              | N/A                                                   |
|            | XC6SLX16                    | 110 ms                    | 26.8 ms                                              | N/A                                                   |
| Constant C | XC6SLX25(T) <sup>(1)</sup>  | 110 ms                    | 45.5 ms                                              | N/A                                                   |
| Spartan-6  | XC6SLX45(T) <sup>(1)</sup>  | 110 ms                    | 81.7 ms                                              | N/A                                                   |
|            | XC6SLX75(T) <sup>(1)</sup>  | 110 ms                    | 138.3 ms                                             | N/A                                                   |
|            | XC6SLX100(T) <sup>(1)</sup> | 110 ms                    | 260.8 ms                                             | N/A                                                   |
|            | XC6SLX150(T) <sup>(1)</sup> | 110 ms                    | 350.0 ms                                             | N/A                                                   |

1. For Spartan-6 LXT devices, the initialization time is reduced if scanning is disabled in the GT row(s).

The start-up latency is the sum of the boot and initialization latency, using the correct column of initialization latency data for the selected correction mode. The start-up latency at the actual frequency of operation can be estimated using data from Table 2-11 and Equation 2-1.

 $StartUpLatency_{ACTUAL} = StartUpLatency_{ICAP_{F_{MAX}}} \cdot \left[\frac{ICAP_{F_{MAX}}}{Frequency_{ACTUAL}}\right]$  Equation 2-1

**Soft Error Mitigation Controller v3.4.1** PG036 September 30, 2015

### **Error Detection Latency**

Error detection latency is the major component of the total error mitigation latency. Error detection latency is a function of the FPGA size (frame count) and the solution clock frequency. It is also a function of the type of error and the relative position of the error with respect to the position of the silicon readback process. Table 2-12 illustrates full device scan times.

|          | Device           | Scan Time at ICAP F <sub>MAX</sub> |  |
|----------|------------------|------------------------------------|--|
|          | XC7A100T         | 8.0 ms                             |  |
| -        | XC7A200T         | 18.3 ms                            |  |
| -        | ХС7К70Т          | 5.9 ms                             |  |
| -        | XC7K160T         | 12.9 ms                            |  |
| -        | ХС7К325Т         | 23.5 ms                            |  |
| -        | ХС7К355Т         | 26.5 ms                            |  |
| -        | ХС7К410Т         | 30.3 ms                            |  |
| -        | ХС7К420Т         | 35.3 ms                            |  |
| -        | ХС7К480Т         | 35.3 ms                            |  |
| -        | XC7VX330T        | 25.6 ms                            |  |
| -        | XC7VX415T        | 32.5 ms                            |  |
|          | XC7VX485T        | 38.3 ms                            |  |
| 7 Series | XC7VX550T        | 54.1 ms                            |  |
|          | XC7VH580T (SSI)  | 24.6 ms                            |  |
| -        | XC7V585T         | 41.2 ms                            |  |
| -        | XC7VX690T        | 54.1 ms                            |  |
|          | XC7VH870T (SSI)  | 24.6 ms                            |  |
|          | XC7VX980T        | 70.7 ms                            |  |
|          | XC7VX1140T (SSI) | 24.6 ms                            |  |
|          | XC7VX2000T (SSI) | 31.6 ms                            |  |
|          | XC7Z010          | 4.0 ms                             |  |
|          | XC7Z020          | 8.0 ms                             |  |
|          | XC7Z030          | 11.3 ms                            |  |
|          | XC7Z045          | 27.2 ms                            |  |

Table 2-12: Device Scan Times at ICAP Maximum Frequency

|           | Device                      | Scan Time at ICAP F <sub>MAX</sub> |  |
|-----------|-----------------------------|------------------------------------|--|
|           | XC6VCX75T                   | 6.2 ms                             |  |
|           | XC6VCX130T                  | 10.4 ms                            |  |
|           | XC6VCX195T                  | 15.0 ms                            |  |
|           | XC6VCX240T                  | 18.0 ms                            |  |
|           | XC6VHX250T                  | 18.7 ms                            |  |
|           | XC6VHX255T                  | 18.7 ms                            |  |
|           | XC6VHX380T                  | 28.0 ms                            |  |
|           | XC6VHX565T                  | 39.3 ms                            |  |
| Virtex-6  | XC6VLX75T                   | 6.2 ms                             |  |
|           | XC6VLX130T                  | 10.4 ms                            |  |
|           | XC6VLX195T                  | 15.0 ms                            |  |
|           | XC6VLX240T                  | 18.0 ms                            |  |
|           | XC6VLX365T                  | 25.2 ms                            |  |
|           | XC6VLX550T                  | 37.7 ms                            |  |
|           | XC6VLX760                   | 49.9 ms                            |  |
|           | XC6VSX315T                  | 24.1 ms                            |  |
|           | XC6VSX475T                  | 36.1 ms                            |  |
|           | XC6SLX4                     | 9.1 ms                             |  |
|           | XC6SLX9                     | 9.1 ms                             |  |
|           | XC6SLX16                    | 13.4 ms                            |  |
| Coordon C | XC6SLX25(T) <sup>(1)</sup>  | 22.7 ms                            |  |
| Spartan-6 | XC6SLX45(T) <sup>(1)</sup>  | 40.8 ms                            |  |
|           | XC6SLX75(T) <sup>(1)</sup>  | 69.1 ms                            |  |
|           | XC6SLX100(T) <sup>(1)</sup> | 130.2 ms                           |  |
|           | XC6SLX150(T) <sup>(1)</sup> | 174.7 ms                           |  |

Table 2-12: Device Scan Times at ICAP Maximum Frequency (Cont'd)

1. The scan time and coverage for Spartan-6 devices is reduced if scanning is disabled in the GT rows.

The device scan time for the target device, at the actual frequency of operation, can be estimated using data from Table 2-12 and Equation 2-2.

$$ScanTime_{ACTUAL} = ScanTime_{ICAP_{F_{MAX}}} \cdot \left[\frac{ICAP_{F_{MAX}}}{Frequency_{ACTUAL}}\right]$$

Equation 2-2

The error detection latency can be bounded as follows:

- Absolute minimum error detection latency is effectively zero.
- Average error detection latency for detection by ECC is 0.5 \* Scan Time<sub>ACTUAL</sub>
- Maximum error detection latency for detection by ECC is Scan Time<sub>ACTUAL</sub>

 Absolute maximum error detection latency for detection by CRC alone is 2.0 \* Scan Time<sub>ACTUAL</sub>

The frame-based ECC method used always detects single, double, triple, and all odd-count bit errors in a frame. The remaining error types are usually detected by the frame-based ECC method as well. It is rare to encounter an error that defeats the ECC and is detected by CRC alone.

### **Error Correction Latency**

After detecting an error, the solution attempts correction. Errors are correctable depending on the selected correction mode and error type. Table 2-13 provides error correction latency for a configuration frame upset, assuming no throttling on the Monitor Interface.

| Device<br>Family                       | Correction<br>Mode | Errors in Frame<br>(Correctability)             | Error Correction<br>State at ICAP_F <sub>MAX</sub> |  |
|----------------------------------------|--------------------|-------------------------------------------------|----------------------------------------------------|--|
|                                        | Donair             | 1-bit (Correctable)                             | 610 µs                                             |  |
|                                        | Repair             | (Correctability) State at ICAP_F <sub>MAX</sub> |                                                    |  |
|                                        |                    | 1-bit (Correctable)                             | 610 µs                                             |  |
| 7 Series                               | Enhanced           | 2-bit (Correctable)                             | 18750 µs                                           |  |
| FPGAs                                  | Repair             | 2-bit (Uncorrectable)                           | 9110 µs                                            |  |
|                                        |                    | BFR <sup>(1)</sup> -only (Uncorrectable)        | 10 µs                                              |  |
|                                        | Replace            | Any (Correctable)                               | 830 µs                                             |  |
|                                        | Any                | CRC-only (Uncorrectable)                        | 10 µs                                              |  |
|                                        | Deneir             | 1-bit (Correctable)                             | 490 µs                                             |  |
| Virtex-6                               | Repair             | 2-bit (Uncorrectable)                           | 20 µs                                              |  |
| FPGAs                                  | Replace            | Any (Correctable)                               | 660 µs                                             |  |
|                                        | Any                | CRC-only (Uncorrectable)                        | 10 µs                                              |  |
|                                        | Dopair             | 1-bit (Correctable)                             | 370 µs                                             |  |
| Spartan-6<br>LX4 through LX75(T)       | Repair             | 2-bit (Uncorrectable)                           | 35 µs                                              |  |
|                                        | Any                | CRC-only (Uncorrectable)                        | 15 µs                                              |  |
|                                        | <b>.</b> .         | 1-bit (Correctable)                             | 525 µs                                             |  |
| Spartan-6<br>LX100(T) through LX150(T) | Repair             | 2-bit (Uncorrectable)                           | 50 µs                                              |  |
|                                        | Any                | CRC-only (Uncorrectable)                        | 25 µs                                              |  |

Table 2-13: Error Correction Latency, No Throttling on Monitor Interface

#### Notes:

1. BFR is an error condition due to a multi-bit upset in an enhanced repair checksum stored in block RAM.

The error correction latency at the actual frequency of operation can be estimated using data from Table 2-13 and Equation 2-3.

```
CorrectionLatency_{ACTUAL} = CorrectionLatency_{ICAP_{MAX}} \cdot \left[\frac{ICAP_{F_{MAX}}}{Frequency_{ACTUAL}}\right] \quad Equation 2-3
```

### **Error Classification Latency**

After attempting correction of an error, the solution classifies the error. The classification result depends on the correction mode, error type, error location, and selected classification mode. Table 2-14 provides error classification latency for a configuration frame upset, assuming no throttling on the Monitor Interface.

| Device<br>Family                       | Correction<br>Mode | Errors in Frame<br>(Correctability) | Classification<br>Mode | Error Classification<br>State at ICAP_F <sub>MAX</sub> |
|----------------------------------------|--------------------|-------------------------------------|------------------------|--------------------------------------------------------|
| 7 Series<br>FPGAs                      | Any                | Correctable                         | Enabled                | 750 µs                                                 |
|                                        | Any                | Uncorrectable                       | Disabled               | 10 µs                                                  |
|                                        | Any                | Uncorrectable                       | Any                    | 10 µs                                                  |
| Virtex-6<br>FPGAs                      | Any                | Correctable                         | Enabled                | 610 µs                                                 |
|                                        | Any                | Correctable                         | Disabled               | 10 µs                                                  |
|                                        | Any                | Uncorrectable                       | Any                    | 10 µs                                                  |
| Spartan-6<br>LX4 through LX75(T)       | Repair             | Correctable                         | Enabled                | 435 µs                                                 |
|                                        |                    | Correctable                         | Disabled               | 10 µs                                                  |
|                                        |                    | Uncorrectable                       | Any                    | 10 µs                                                  |
| Spartan-6<br>LX100(T) through LX150(T) | Repair             | Correctable                         | Enabled                | 620 µs                                                 |
|                                        |                    | Correctable                         | Disabled               | 15 µs                                                  |
|                                        | Any                | Uncorrectable                       | Any                    | 15 µs                                                  |

Table 2-14: Error Classification Latency, No Throttling on Monitor Interface

The error classification latency at the actual frequency of operation can be estimated using data from Table 2-14 and Equation 2-4.

 $ClassificationLatency_{ACTUAL} = ClassificationLatency_{ICAP_{F_{MAX}}} \cdot \left[\frac{ICAP_{F_{MAX}}}{Frequency_{ACTUAL}}\right] \quad Equation 2-4$ 

### Sources of Additional Latency

It is highly desirable to avoid throttling on the Monitor Interface, because it increases the total error mitigation latency:

• After an attempted error correction, but before exiting the error correction state (at which time the correctable status flag is updated), the controller issues a detection and correction report through the Monitor Interface. If the MON Shim transmit FIFO becomes full during this report generation, the controller dwells in this state until it has written the entire report into the MON Shim transmit FIFO. When this happens, the error correction latency increases.

• After classifying an error, but before exiting the error classification state (at which time the essential status flag is updated), the controller issues a classification report through the Monitor Interface. If the MON Shim transmit FIFO becomes full during this report generation, the controller dwells in this state until it has written the entire report into the MON Shim transmit FIFO. When this happens, the error classification latency increases.

The approaches to completely eliminate the potential bottleneck are to remove the MON Shim and leave the Monitor Interface unused, or use the Monitor Interface with a peripheral that never signals a buffer full condition. In the event the Monitor Interface is unused, the Status Interface remains available for monitoring activity.

For peripherals where the potential bottleneck is a concern, it can be mitigated. This is accomplished by adjusting the transmit FIFO size to accommodate the longest burst of status messages that are anticipated so that the transmit FIFO never goes full during error mitigation.

If a transmit FIFO full condition does occur, the increase in the total error mitigation latency is roughly estimated as shown in Equation 2-5.

AdditionalLatency = 
$$\frac{MessageLength - BufferDepth}{TransmissionRate}$$
 Equation 2-5

In Equation 2-5, MessageLength-BufferDepth is in message bytes, and the Transmission Rate is in bytes per unit of time.

### **Sample Latency Estimation**

The first sample estimation illustrates the calculation of error mitigation latency for a single-bit error by the solution implemented in an XC6VLX240T device with a 66 MHz clock. The solution is configured for error correction by repair, with error classification disabled. The initial assumption is that no throttling occurs on the Monitor Interface.

$$DetectionLatency = 0.5 \cdot ScanTime_{ACTUAL} = 0.5 \cdot 18.0ms \cdot \left[\frac{100MHz}{66MHz}\right] = 13.636ms \quad Equation 2-6$$

$$CorrectionLatency = 490 \mu s \cdot \left[\frac{100 MHz}{66 MHz}\right] = 0.742 ms \qquad Equation 2-7$$

$$ClassificationLatency = 10 \mu s \cdot \left[\frac{100 MHz}{66 MHz}\right] = 0.015 ms \qquad Equation 2-8$$

The second sample estimation illustrates the calculation of error mitigation latency for a two-bit error by the solution implemented in an XC6VLX240T device with a 66 MHz clock. The solution is configured for error correction by replace, with error classification enabled. Again, it is assumed that no throttling occurs on the Monitor Interface.

$$DetectionLatency = 0.5 \cdot ScanTime_{ACTUAL} = 0.5 \cdot 18.0ms \cdot \left[\frac{100MHz}{66MHz}\right] = 13.636ms$$
Equation 2-10

$$CorrectionLatency = 660 \mu s \cdot \left[\frac{100MHz}{66MHz}\right] = 1.000 ms \qquad Equation 2-11$$

$$ClassificationLatency = 610 \mu s \cdot \left[\frac{100 MHz}{66 MHz}\right] = 0.924 ms \qquad Equation 2-12$$

The final sample estimation illustrates an assessment of the additional latency that would result from throttling on the Monitor Interface. Assume the message length in both the first and second samples is approximately 80 bytes, but the buffer depth of the MON Shim is 32 bytes. Further, the MON Shim has been modified to raise the bit rate from 9600 baud to 460800 baud. The standard 8-N-1 protocol used requires 10 bit times on the serial link to transmit a one byte payload:

$$AdditionalLatency = \frac{80bytes - 32bytes}{\left[\frac{460800bittimes}{s} \cdot \frac{byte}{10bittimes} \cdot \frac{s}{1000ms}\right]} = 1.042ms \qquad Equation 2-14$$

This result illustrates that the additional latency resulting from throttling on the Monitor Interface can become significant, especially when the data transmission is serialized and the data rate is low.

### Throughput

The throughput metrics of the SEM Controller are not specified.

### Power

The power metrics of the SEM Controller are not specified.

### **Port Descriptions**

The SEM Controller is the kernel of the soft error mitigation solution. Figure 2-1 shows the SEM Controller ports. The ports are clustered into six groups. Shading indicates port groups that only exist in certain configurations.



*Figure 2-1:* **SEM Controller Ports** 

The SEM Controller has no reset input or output. It automatically initializes itself with an internal synchronous reset derived from the de-assertion of the global GSR signal.

The SEM Controller is a fully synchronous design using icap\_clk as the single clock. All state elements are synchronous to the rising edge of this clock. As a result, all interfaces are also synchronous to the rising edge of this clock.

### **ICAP** Interface

The ICAP Interface is a point-to-point connection between the SEM Controller and the ICAP primitive. The ICAP primitive enables read and write access to the registers inside the FPGA configuration system. The ICAP primitive and the behavior of the signals on this interface are described in the 7 Series FPGAs Configuration User Guide (UG470) [Ref 2], Virtex-6 FPGA Configuration User Guide (UG360) [Ref 3], and Spartan ®-6 FPGA Configuration User Guide (UG380) [Ref 4].

For 7 series devices, icap\_busy is not part of the ICAP Interface.

| Name                   | Sense | Direction | Description                                                                                                                                                                                                                                                                               |  |
|------------------------|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| icap_busy              | HIGH  | In        | Receives BUSY output of ICAP. For 7 series devices, icap_busy is not part of the ICAP Interface.                                                                                                                                                                                          |  |
| icap_o[icap_width-1:0] | HIGH  | In        | Receives O output of ICAP. The variable icap_width is equal to 32 for 7 series and Virtex-6 devices and 16 for Spartan-6 devices.                                                                                                                                                         |  |
| icap_csib / icap_csb   | LOW   | Out       | Drives CSIB (7 series) / CSB (Virtex-6 and Spartan-6) input of ICAP.                                                                                                                                                                                                                      |  |
| icap_rdwrb             | LOW   | Out       | Drives RDWRB input of ICAP.                                                                                                                                                                                                                                                               |  |
| icap_i[icap_width-1:0] | HIGH  | Out       | Drives I input of ICAP. The variable icap_width is equal to 32 for 7 series and Virtex-6 devices and 16 for Spartan-6 devices.                                                                                                                                                            |  |
| icap_clk               | EDGE  | In        | Receives the clock for the design. This same clock<br>also must be applied to the CLK input of ICAP. The<br>clock frequency must comply with the ICAP input<br>clock requirements as specified in the target device<br>data sheet.                                                        |  |
| icap_request           | HIGH  | Out       | This signal is reserved for future use. Leave this port OPEN.                                                                                                                                                                                                                             |  |
| icap_grant             | HIGH  | In        | Tie this port to VCC. Receives an ICAP initialization<br>grant signal from the user. For 7 series controllers,<br>icap_grant can be used to hold off the controller<br>initialization state. For Virtex-6 and Spartan-6<br>controllers, this port is reserved and must be tied to<br>VCC. |  |

Table 2-15: ICAP Interface Signals

### FRAME\_ECC Interface

The FRAME\_ECC Interface is a point-to-point connection between the SEM Controller and the FRAME\_ECC primitive. The FRAME\_ECC primitive is an output-only primitive that provides a window into the soft error detection function in the FPGA configuration system. The FRAME\_ECC primitive and the behavior of the signals on this interface are described in the 7 Series FPGAs Configuration User Guide (UG470) [Ref 2] and Virtex-6 FPGA Configuration User Guide (UG360) [Ref 3].

For Spartan-6 devices, the FRAME\_ECC primitive and the soft error detection functionality are implemented in soft logic within the SEM Controller. This logic implements the same capabilities as present in Virtex-6 FPGAs. As a result, no FRAME\_ECC Interface exists on implementations of the SEM Controller for Spartan-6 devices.

| Name                    | Sense                                        | Direction | Description                                                                                                          |  |  |
|-------------------------|----------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------|--|--|
| fecc_crcerr             | HIGH                                         | In        | Receives CRCERROR output of FRAME_ECC.                                                                               |  |  |
| fecc_eccerr             | HIGH                                         | In        | Receives ECCERROR output of FRAME_ECC.                                                                               |  |  |
| fecc_eccerrsingle       | HIGH In Receives ECCERRORSINGLE output of FR |           |                                                                                                                      |  |  |
| fecc_syndromevalid      | HIGH                                         | In        | Receives SYNDROMEVALID output of FRAME_ECC.                                                                          |  |  |
| fecc_syndrome[12:0]     | HIGH                                         | In        | Receives SYNDROME output of FRAME_ECC.                                                                               |  |  |
| fecc_far[far_width-1:0] | HIGH                                         | In        | Receives FAR output of FRAME_ECC. The variable for far_width is 26 for 7 series devices and 24 for Virtex-6 devices. |  |  |
| fecc_synbit[4:0]        | HIGH                                         | In        | Receives SYNBIT output of FRAME_ECC.                                                                                 |  |  |
| fecc_synword[6:0]       | HIGH                                         | In        | Receives SYNWORD output of FRAME_ECC.                                                                                |  |  |

Table 2-16: FRAME\_ECC Interface Signals

Advanced users can monitor the FRAME\_ECC Interface to provide an early warning of soft error detection.

Monitoring of the FRAME\_ECC Interface offers additional advantage when the SEM Controller is configured for error correction by repair, with error classification disabled. In this configuration, the user can implement a custom error classification algorithm that executes in parallel with the SEM Controller error correction algorithm, providing a very low delay between error detection and the completion of error classification.

## **Status Interface**

The Status Interface provides a convenient set of decoded outputs that indicate, at a high level, what the controller is doing.

Table 2-17: Status Interface Signals

| Name                  | Sense | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| status_heartbeat      | HIGH  | Out       | The heartbeat signal is active while<br>status_observation is TRUE. This output issues a<br>single-cycle high pulse at least once every 128 clock<br>cycles for 7 series and Virtex-6 devices, and at least<br>once every 512 clock cycles for Spartan-6 devices.<br>This signal can be used to implement an external<br>watchdog timer to detect "controller stop" scenarios<br>that can occur if the controller or clock distribution<br>is disabled by soft errors. When status_observation<br>is FALSE, the behavior of the heartbeat signal is<br>unspecified. |
| status_initialization | HIGH  | Out       | The initialization signal is active during controller initialization, which occurs one time after the design begins operation.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| status_observation    | HIGH  | Out       | The observation signal is active during controller<br>observation of error detection signals. This signal<br>remains active after an error detection while the<br>controller queries the hardware for information.                                                                                                                                                                                                                                                                                                                                                  |
| status_correction     | HIGH  | Out       | The correction signal is active during controller correction of an error or during transition through this controller state if correction is disabled.                                                                                                                                                                                                                                                                                                                                                                                                              |
| status_classification | HIGH  | Out       | The classification signal is active during controller classification of an error or during transition through this controller state if classification is disabled.                                                                                                                                                                                                                                                                                                                                                                                                  |
| status_injection      | HIGH  | Out       | The injection signal is active during controller<br>injection of an error. When an error injection is<br>complete, and the controller is ready to inject<br>another error or return to observation, this signal<br>returns inactive.                                                                                                                                                                                                                                                                                                                                |
| status_essential      | HIGH  | Out       | The essential signal is an error classification status<br>signal. Prior to exiting the classification state, the<br>controller sets this signal to reflect whether the<br>error occurred on an essential bit(s). Then, the<br>controller exits classification state.                                                                                                                                                                                                                                                                                                |
| status_uncorrectable  | HIGH  | Out       | The uncorrectable signal is an error correction<br>status signal. Prior to exiting the correction state,<br>the controller sets this signal to reflect the<br>correctability of the error. Then, the controller exits<br>correction state.                                                                                                                                                                                                                                                                                                                          |

The status\_heartbeat output provides an indication that the controller is active. Although the controller mitigates soft errors, it can also be disrupted by soft errors. For example, the controller clock can be disabled by a soft error. If the status\_heartbeat signal stops, the user can take remedial action.

The status\_initialization, status\_observation, status\_correction, status\_classification, and status\_injection outputs indicate the current controller state. The status\_uncorrectable and status\_essential outputs qualify the nature of detected errors.

Two additional controller state can be decoded from the five controller state outputs. If all five signals are low, the controller is idle (inactive but ready to resume). If all five signals are high, the controller is halted (inactive due to fatal error).

## **Error Injection Interface**

The Error Injection Interface provides a convenient set of inputs to command the controller to inject a bit error into configuration memory.

| Name                                 | Sense | Direction | Description                                                                                                                                                                                                                                                                                                        |
|--------------------------------------|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inject_strobe                        | HIGH  | In        | The error injection control is used to indicate an<br>error injection request. The inject_strobe signal<br>should be pulsed high for one cycle concurrent with<br>the application of a valid address to the<br>inject_address input. The error injection control<br>must only be used when the controller is idle. |
| inject_address<br>[inject_width-1:0] | HIGH  | In        | The error injection address bus is used to specify the<br>parameters for an error injection. The value on this<br>bus is captured at the same time inject_strobe is<br>sampled active. For 7 series devices, the variable<br>inject_width is 40, and for Virtex-6 and Spartan-6<br>devices, the variable is 36.    |

Table 2-18: Error Injection Interface Signals

The user provides an error injection address and command on inject\_address and asserts inject\_strobe to indicate an error injection request.

In response, the controller injects a bit error. The controller confirms receipt of the error injection command by asserting status\_injection. When the injection command has completed, the controller deasserts status\_injection. To inject errors affecting multiple bits, a sequence of error injections can be performed.

For more information on error injection commands, see Error Injection Interface in Chapter 3.

## **Monitor Interface**

The Monitor Interface provides a mechanism for the user to interact with the controller.

The controller is designed to read commands and write status information to this interface as ASCII strings. The status and command capability of the Monitor Interface is a superset of the Status Interface and the Error Injection Interface. The Monitor Interface is intended for use in processor based systems.

| Name                | Sense | Direction | Description                                                                                                |
|---------------------|-------|-----------|------------------------------------------------------------------------------------------------------------|
| monitor_txdata[7:0] | HIGH  | Out       | Parallel transmit data from controller.                                                                    |
| monitor_txwrite     | HIGH  | Out       | Write strobe, qualifies validity of parallel transmit data.                                                |
| monitor_txfull      | HIGH  | In        | This signal implements flow control on the transmit channel, from the shim (peripheral) to the controller. |
| monitor_rxdata[7:0] | HIGH  | In        | Parallel receive data from the shim (peripheral).                                                          |
| monitor_rxread      | HIGH  | Out       | Read strobe, acknowledges receipt of parallel receive data.                                                |
| monitor_rxempty     | HIGH  | In        | This signal implements flow control on the receive channel, from the shim (peripheral) to the controller.  |

Table 2-19: Monitor Interface Signals

## **Fetch Interface**

The Fetch Interface provides a mechanism for the controller to request data from an external source.

During error correction and error classification, the controller may need to fetch a frame of configuration data or a frame of essential bit data. The controller is designed to write a command describing the desired data to the Fetch Interface in binary. The external source must use the information to fetch the data and return it to the Fetch Interface.

Table 2-20: Fetch Interface Signals

| Name              | Sense | Direction | Description                                                                                                |
|-------------------|-------|-----------|------------------------------------------------------------------------------------------------------------|
| fetch_txdata[7:0] | HIGH  | Out       | Parallel transmit data from controller.                                                                    |
| fetch_txwrite     | HIGH  | Out       | Write strobe, qualifies validity of parallel transmit data.                                                |
| fetch_txfull      | HIGH  | In        | This signal implements flow control on the transmit channel, from the shim (peripheral) to the controller. |
| fetch_rxdata[7:0] | HIGH  | In        | Parallel receive data from the shim (peripheral).                                                          |
| fetch_rxread      | HIGH  | Out       | Read strobe, acknowledges receipt of parallel receive data.                                                |

|                     | 0     | . ,       |                                                                                                           |
|---------------------|-------|-----------|-----------------------------------------------------------------------------------------------------------|
| Name                | Sense | Direction | Description                                                                                               |
| fetch_rxempty       | HIGH  | In        | This signal implements flow control on the receive channel, from the shim (peripheral) to the controller. |
| fetch_tbladdr[31:0] | HIGH  | In        | Used to specify the starting address of the controller data table in the external source.                 |

Table 2-20: Fetch Interface Signals (Cont'd)



## Chapter 3

# Designing with the Core

This chapter provides details on how to apply the core from three different levels, using a bottom-up approach. This chapter includes the following sections:

- Interfaces describes how to connect to the solution.
- Behaviors describes how to interact with the solution through its interfaces.
- Systems describes integrating the solution into a larger system.

## Interfaces

The system-level design example exposes four to six interfaces, depending on the options selected when it is generated. Each interface is described separately. The interface-level descriptions are intended to convey how to connect each interface.

## **Clock Interface**

The following recommendations exist for the input clock. These recommendations are derived from the FPGA data sheet requirements for clock signals applied to the FPGA configuration system:

Duty Cycle: 45% minimum, 55% maximum

The higher the frequency of the input clock, the lower the mitigation latency of the solution. Therefore, faster is better. There are several important factors that must be considered in determination of the maximum input clock frequency:

- Frequency must not exceed FPGA configuration system maximum clock frequency. Consult the device data sheet for the target device for this information.
- Frequency must not exceed the maximum clock frequency as reported in the static timing analyzer. This is generally not a limiting constraint.

Based on the fully synchronous design methodology, additional considerations arise in clock frequency selections that relate to the timing of external interfaces, if the system-level design example is used:

• For the EXT shim and memory interface:

- The SPI bus timing budget must be evaluated to determine the maximum SPI bus clock frequency; a sample analysis is presented in External Interface, page 46.
- The SPI bus clock is the input clock divided by two; therefore, the input clock cannot exceed twice the maximum SPI bus clock frequency.
- For the MON shim and serial interface:
  - The input clock and the serial interface baud rate are related by an integer multiple of sixteen. For very high baud rates or very low input clock frequencies, the solution space may be limited if standard baud rates are desired.
  - A sample analysis is presented in Monitor Interface, page 45.

After considering the factors, select an input clock frequency that satisfies all requirements.

### **Status Interface**

Direct, logic-signal-based event reporting is available from the Status Interface. The Status Interface can be used for many purposes, but its use is entirely optional. This interface reports three different types of information:

- State: Indicates what a controller is doing.
- Flags: Identifies the type of error detected.
- Heartbeat: Indicates scanning is active.

For stacked silicon interconnect (SSI) implementations of the system-level example design, there is a controller instance on each super logic region (SLR) and therefore an independent Status Interface per SLR. In most cases, desired signals from the Status Interface should be brought to I/O pins on the FPGA. The system-level design example brings all of the signals to I/O pins.

Externally, the status signals can be connected to indicators for viewing, or to another device for observation. To properly capture event reporting, the switching behavior of the Status Interface must be accounted for when interfacing to another device.

The Status Interface can become unwieldy, especially in SSI implementations, due to the number of signals. Only the heartbeat event is unique to the Status Interface. The other information is also available on the Monitor Interface.

The signals in the Status Interface are generated by sequential logic processes in controllers using the clock supplied to the system-level design example. As a result, the pulse widths are always an integer number of clock cycles.

The collective switching behavior of the state signals status\_initialization, status\_observation, status\_correction, status\_classification, and status\_injection is illustrated in Figure 3-1. In the figure, the status\_[state]

signal represents the five state signals, as a group, which can be considered an indication of the controller state.



*Figure 3-1:* Status Interface State Signals Switching Characteristics

The switching behavior of the flag signals status\_uncorrectable and status\_essential is relative to the exit from the states where these flags are updated, as illustrated in Figure 3-2 and Figure 3-3. The figures illustrate a window of time when the flags are valid with respect to transitions out of the state in which they can be updated. Specific flag values are not shown in the waveform.



Figure 3-2: Status Interface Uncorrectable Flag Switching Characteristics



*Figure 3-3:* Status Interface Essential Flag Switching Characteristics

The switching behavior of the heartbeat signal status\_heartbeat is illustrated in Figure 3-4. This signal is a direct output from the readback process, and is active during the observation state. Upon entering the observation state, the heartbeat signal will become active when the readback process is scanning for errors. The first heartbeat pulse observed during the observation state must be used to arm any circuit that monitors for loss of heartbeat. In all other states, the heartbeat signal behavior is unspecified.

The first heartbeat after entering the observation state should occur within three readback scan times. A readback scan time depends on the device and clock frequency. See

Table 2-12 to determine how long a readback scan takes for the device being used.



Figure 3-4: Status Interface Heartbeat Switching Characteristics

Due to the small pulse widths involved, approaches such as sampling the Status Interface signals through embedded processor GPIO using software polling are not likely to work. Instead, use other approaches such as using counter/timer inputs, edge sensitive interrupt inputs, or inputs with event capture capability.

## **Monitor Interface**

The Monitor Interface consists of two signals implementing an RS-232 protocol compatible, full duplex serial port for exchange of commands and status. The following configuration is used:

- Baud: 9600
- Settings: 8-N-1
- Flow Control: None
- Terminal Setup: VT100
  - TX Newline: CR (Terminal transmits CR [0x0D] as end of line)
  - RX Newline: CR+LF (Terminal receives CR [0x0D] as end of line, and expands to CR+LF [0x0D, 0x0A])
  - Local Echo: NO

Any external device connected to the Monitor Interface must support this configuration. Figure 3-5 shows the switching behavior, and is representative of both transmit and receive.



*Figure 3-5:* Monitor Interface Switching Characteristics

Transmit and receive timing is derived from a 16x bit rate enable signal which is created inside the system-level example design using a counter. The behavior of this counter is to start counting from zero, up to and including a terminal count (a condition detected and used to synchronously reset the counter). The terminal count output is also supplied to transmit and receive processes as a time base.

From a compatibility perspective, the advantages of 9600 baud are that it is a standard bit rate, and it is also realizable with a broad range of input clock frequencies. It is used in the system-level design example for these reasons.

From a practical perspective, the disadvantage of such a low bit rate is communication performance (both data rate and latency). This performance can throttle the controller. For this reason, changing to a higher bit rate is strongly encouraged. A wide variety of other bit rates are possible, including standard bit rates: 115200, 230400, 460800, and 921600 baud.

In the MON shim system-level example design module, the parameter V\_ENABLETIME sets the communication bit rate. The value for V\_ENABLETIME is calculated using:

V\_ENABLETIME= round to integer 
$$\left[\frac{input \ clock \ frequency}{16 \times nominal \ bitrate}\right] - 1$$
 Equation 3-1

A rounding error as great as +/- 0.5 can result from the computation of V\_ENABLETIME. This error produces a bit rate that is slightly different than the nominal bit rate. A difference of 2% between RS-232 devices is considered acceptable, which suggests a bit rate tolerance of +/- 1% for each device.

**Example**: The input clock is 66 MHz, and the desired bit rate is 115200 baud.

V\_ENABLETIME= round to integer 
$$\left[\frac{66000000}{16 \times 115200}\right] - 1 = 35$$
 Equation 3-2

The actual bit rate that results is approximately 114583 baud, which deviates -0.54% from the nominal bit rate of 115200 baud. This is acceptable because the difference is within +/ - 1%.

When exploring bit rates, if the difference from nominal exceeds the +/- 1% tolerance, select another combination of bit rate and input clock frequency that yields less error. No additional switching characteristics are specified.

Electrically, the I/O pins used by the Monitor Interface use LVCMOS signaling, which is suitable for interfacing with other devices. No specific I/O mode is required. When full electrical compatibility with RS-232 is desired, an external level translator must be used.

## **External Interface**

The External Interface consists of four signals implementing a SPI bus protocol compatible, full duplex serial port. This interface is only present when one or both of the following controller options are enabled:

- Error Correction by Replacement
- Error Classification

The implementations of these functions require external storage. The system-level design example provides a fixed-function SPI bus master in the EXT shim to fetch data from a single external SPI Flash device. Table 3-1 provides the SPI Flash density requirement for each supported FPGA.



| Device           | Error Classification<br>Only | Error Correction by<br>Replacement Only | Error Classification with<br>Error Correction by<br>Replacement |
|------------------|------------------------------|-----------------------------------------|-----------------------------------------------------------------|
| XC7A100T         | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |
| XC7A200T         | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC7K70T          | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |
| XC7K160T         | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC7K325T         | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7K355T         | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7K410T         | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7K420T         | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7K480T         | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7VX330T        | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7VX415T        | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7VX485T        | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7VX550T        | 256 Mbit                     | 256 Mbit                                | 512 Mbit                                                        |
| XC7VH580T (SSI)  | 256 Mbit                     | 256 Mbit                                | 512 Mbit                                                        |
| XC7V585T         | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC7VX690T        | 256 Mbit                     | 256 Mbit                                | 512 Mbit                                                        |
| XC7VH870T (SSI)  | 256 Mbit                     | 256 Mbit                                | 512 Mbit                                                        |
| XC7VX980T        | 256 Mbit                     | 256 Mbit                                | 512 Mbit                                                        |
| XC7VX1140T (SSI) | 512 Mbit                     | 512 Mbit                                | 1024 Mbit                                                       |
| XC7VX2000T (SSI) | 512 Mbit                     | 512 Mbit                                | 1024 Mbit                                                       |
| XC7Z010          | 16 Mbit                      | 16 Mbit                                 | 32 Mbit                                                         |
| XC7Z020          | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |
| XC7Z030          | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC7Z045          | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC6VCX75T        | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |
| XC6VCX130T       | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |
| XC6VCX195T       | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC6VCX240T       | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC6VHX250T       | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC6VHX255T       | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |
| XC6VHX380T       | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC6VHX565T       | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |
| XC6VLX75T        | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |

Table 3-1: External Storage Requirements

| Device     | Error Classification<br>Only | Error Correction by<br>Replacement Only | Error Classification with<br>Error Correction by<br>Replacement |  |  |  |  |  |  |
|------------|------------------------------|-----------------------------------------|-----------------------------------------------------------------|--|--|--|--|--|--|
| XC6VLX130T | 32 Mbit                      | 32 Mbit                                 | 64 Mbit                                                         |  |  |  |  |  |  |
| XC6VLX195T | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |  |  |  |  |  |  |
| XC6VLX240T | 64 Mbit                      | 64 Mbit                                 | 128 Mbit                                                        |  |  |  |  |  |  |
| XC6VLX365T | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |  |  |  |  |  |  |
| XC6VLX550T | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |  |  |  |  |  |  |
| XC6VLX760  | 256 Mbit                     | 256 Mbit                                | 512 Mbit                                                        |  |  |  |  |  |  |
| XC6VSX315T | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |  |  |  |  |  |  |
| XC6VSX475T | 128 Mbit                     | 128 Mbit                                | 256 Mbit                                                        |  |  |  |  |  |  |
| XC6SLX4    | 4 Mbit                       | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX9    | 4 Mbit                       | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX16   | 4 Mbit                       | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX25T  | 8 Mbit                       | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX45T  | 16 Mbit                      | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX75T  | 16 Mbit                      | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX100T | 32 Mbit                      | N/A                                     | N/A                                                             |  |  |  |  |  |  |
| XC6SLX150T | 32 Mbit                      | N/A                                     | N/A                                                             |  |  |  |  |  |  |

Table 3-1: External Storage Requirements (Cont'd)

The EXT shim is designed for legacy SPI Flash devices supporting the fast read command (0x0B), with one byte of dummy cycles prior to data validity. The EXT shim issues the enable four-byte addressing command (0xB7) when the density of the required SPI Flash exceeds 128 Mbits.

Figure 3-6 shows the connectivity between an FPGA and a SPI Flash device. Note the presence of level translators (marked "LT"). These are required because commonly available SPI Flash devices use 3.3V I/O, which may not be available depending on the selected FPGA or I/O bank voltage.



Figure 3-6: SPI Flash Device Connection, Including Level Translators

The level translators must exhibit low propagation delay to maximize the SPI bus performance. The SPI bus performance can potentially affect the maximum frequency of operation of the entire system-level design example.

The following sections illustrate how to analyze the SPI bus timing budgets. This is a critical analysis which must be performed to ensure reliable data transfer over the SPI bus. Every implementation should be considered unique and be carefully evaluated to ensure the timing budgets posed in the example are satisfied.

#### SPI Bus Clock Waveform and Timing Budget

The SPI Flash device has requirements on the switching characteristics of its input clock. This analysis is for the clock signal generated for the SPI Flash device by the system-level design example. Completion of this analysis requires board-level signal integrity simulation capability.



Figure 3-7: SPI Flash Device Input Clock Requirements

The following parameters, shown in Figure 3-7, are defined as requirements on the clock input to the SPI Flash device:

- T<sub>clch</sub> = SPI bus clock maximum rise time requirement
- T<sub>chcl</sub> = SPI bus clock maximum fall time requirement

- T<sub>cl</sub> = SPI bus clock minimum low time requirement
- T<sub>ch</sub> = SPI bus clock minimum high time requirement

Based on the physical construction of the SPI bus, the I/O characteristics of the FPGA, and the I/O characteristics of any level translator used, the SPI bus clock signal originating at the FPGA will exhibit maximum rise and fall times ( $T_{rise}$  and  $T_{fall}$ ) at the SPI Flash device. Satisfaction of  $T_{clch}$  and  $T_{chcl}$  requirements by  $T_{rise}$  and  $T_{fall}$  must be verified. Should  $T_{clch}$  and  $T_{chcl}$  requirements not be satisfied, avenues of correction include:

- Change I/O slew rate for the system-level design example SPI bus clock output.
- Change I/O drive strength for the system-level design example SPI bus clock output.
- Select an alternate level translator with more suitable I/O characteristics.

Generally, the  $T_{clch}$  and  $T_{chcl}$  requirements are easy to satisfy. They exist to prohibit exceptionally long rise and fall times that might occur on a true bus with many loads, rather than the point-to-point scheme used with the system-level design example.

The SPI bus clock generated by the system-level design example is the input clock divided by two. Therefore, the SPI bus clock high and low times are nominally equal to  $T_{clk}$ . However, considering actual  $T_{rise}$  and  $T_{fall}$ , also ensure satisfaction of the following:

- $T_{clk} \ge T_{rise} + T_{ch}$
- $T_{clk} \ge T_{fall} + T_{cl}$

#### Example:

- T<sub>clch</sub> = 33 ns (from SPI Flash data sheet)
- T<sub>chcl</sub> = 33 ns (from SPI Flash data sheet)
- T<sub>cl</sub> = 9 ns (from SPI Flash data sheet)
- T<sub>ch</sub> = 9 ns (from SPI Flash data sheet)
- T<sub>rise</sub> = 2 ns (from PCB simulation)
- T<sub>fall</sub> = 2 ns (from PCB simulation)

Given this data, perform the following:

- 1. Check: Is  $T_{clch} \ge T_{rise}$ ? Is 33 ns  $\ge$  2 ns? Yes
- 2. Check: Is  $T_{chcl} \ge T_{fall}$ ? Is 33 ns  $\ge$  2 ns? Yes
- 3. Calculate:  $T_{clk} \ge T_{rise} + T_{ch}$  requires  $T_{clk} \ge 2$  ns + 9 ns, or  $T_{clk} \ge 11$  ns
- 4. Calculate:  $T_{clk} \ge T_{fall}$  + Tcl requires  $T_{clk} \ge 2$  ns + 9 ns, or  $T_{clk} \ge 11$  ns

The rise time requirements are satisfied. These requirements on  $T_{clk}$  indicate that the SPI Bus Clock Waveform and Timing Budget will restrict the system-level design example input clock cycle time to be 11 ns or larger.

#### SPI Bus Transmit Waveform and Timing Budget

The SPI Flash device has requirements on the switching characteristics of its input data with respect to its input clock. This analysis is for data capture at the SPI Flash device, when receiving data from the system-level design example.



Figure 3-8: SPI Flash Device Input Data Capture Requirements

The following parameters, shown in Figure 3-8, are defined as requirements for successful data capture by the SPI Flash device:

- T<sub>dvch</sub> = SPI Flash minimum data setup requirement with respect to clock
- T<sub>chdx</sub> = SPI Flash minimum data hold requirement with respect to clock

The analysis assumes minimum propagation delays are zero. This analysis also assumes the following skews are negligible:

- Skew on input clock distribution to FPGA output flip-flops.
- Skew on output signal paths from FPGA output flip-flops to FPGA pins.
- Skew in PCB level translator channel delays. The level translator on clock and datapaths must be matched for this to be true.
- Skew in PCB trace segment delays. The trace delay on clock and datapaths must be matched for this to be true
- Duty cycle distortion.

The following parameters are defined as implementation parameters of the EXT shim and PCB:

- T<sub>clk</sub> = input clock cycle time (icap\_clk)
- T<sub>afpga</sub> = FPGA output delay with respect to icap\_clk
- $T_{w1}$  = FPGA to level translator PCB trace delay
- $T_{w2}$  = Level translator to SPI Flash PCB trace delay

• T<sub>dly</sub> = Level translator channel delay

The memory system signaling generated by the EXT shim implementation is shown in Figure 3-9.



Figure 3-9: Input Data Capture Timing

Given the stated assumptions, the delays on both the clock and datapaths are identical and track each other over process, voltage, and temperature variations. The following relationships exist:

- $T_{clk} \ge T_{dvch}$
- $T_{clk} \ge T_{chdx}$

#### Example:

- T<sub>dvch</sub> = 2 ns (from SPI Flash data sheet)
- T<sub>chdx</sub> = 5 ns (from SPI Flash data sheet)
- 1. Calculate:  $T_{clk} \ge T_{dvch}$  requires  $T_{clk} \ge 2$  ns
- 2. Calculate:  $T_{clk} \ge T_{chdx}$  requires  $T_{clk} \ge 5$  ns

These requirements on T<sub>clk</sub> indicate that the SPI Transmit Waveform and Timing Budget will restrict the system-level design example input clock cycle time to be 5 ns or larger.



#### SPI Bus Receive Waveform and Timing Budget

The SPI Flash device will exhibit certain output switching characteristics of its output data with respect to its input clock. This analysis is for data capture at the system-level design example, when receiving data from the SPI Flash device.



Figure 3-10: SPI Flash Device Output Data Switching Characteristics

The following parameters, shown in Figure 3-10, are defined as the output switching behavior of the SPI Flash device:

- T<sub>clav</sub> = SPI Flash maximum output valid with respect to clock
- $T_{clgx} = SPI$  Flash minimum output hold with respect to clock

The analysis assumes minimum propagation delays are zero. This analysis also assumes the following skews are negligible:

- Skew on input clock distribution to FPGA output and input flip-flops.
- Skew in PCB level translator channel delays. The level translator on clock and datapaths must be matched for this to be true.
- Duty cycle distortion.

The following parameters are defined as implementation parameters of the EXT shim and PCB:

- T<sub>clk</sub> = input clock cycle time (icap\_clk)
- T<sub>afpga</sub> = FPGA output delay with respect to icap\_clk
- T<sub>sfpga</sub> = FPGA input setup requirement with respect to icap\_clk
- T<sub>hfpga</sub> = FPGA input hold requirement with respect to icap\_clk
- $T_{w1}$  = FPGA to level translator PCB trace delay
- $T_{w2}$  = Level translator to SPI Flash PCB trace delay
- $T_{w3}$  = SPI Flash to level translator PCB trace delay
- $T_{w4}$  = Level translator to FPGA PCB trace delay
- T<sub>dlv</sub> = Level translator channel delay

The timing path is a two cycle path for the EXT shim, but a single cycle path to the SPI Flash device. For the timing analysis, the clock to out of the SPI Flash device is modeled as a combinational delay. Both setup and hold requirements at the FPGA must be considered.

The memory system signaling generated by the EXT shim implementation is shown in Figure 3-11 and Figure 3-12.







Figure 3-12: Output Data Capture Timing (Setup Analysis)

The hold path analysis is a pass/fail test. The hold path analysis must be calculated using minimum delay values, for which the following relationship must be verified:

 $T_{hfpga} \le T_{qfpga,min} + T_{w1} + T_{dly} + T_{w2} + T_{clqx} + T_{w3} + T_{dly} + T_{w4}$ 

Substituting zero as a conservative minimum delay for  $T_{w1}$ ,  $T_{w2}$ ,  $T_{w3}$ ,  $T_{w4}$ , and  $T_{dly}$  yields:

 $T_{hfpga} \le T_{qfpga,min} + T_{clqx}$ 

The setup path analysis must be calculated using maximum delay values:

 $T_{clk} \ge 0.5*(T_{qfpga,max} + T_{w1} + T_{dly} + T_{w2} + T_{clqv} + T_{w3} + T_{dly} + T_{w4} + T_{sfpga})$ 

#### Example 1: ISE Design Suite, Virtex-6 FPGA

- T<sub>clay</sub> = 8 ns (from SPI Flash data sheet)
- T<sub>clax</sub> = 0 ns (from SPI Flash data sheet)
- T<sub>dlv</sub> = 3 ns (from level translator data sheet)
- T<sub>w1</sub> = 1 ns (from board simulation)
- T<sub>w2</sub> = 1 ns (from board simulation)
- T<sub>w3</sub> = 1 ns (from board simulation)
- T<sub>w4</sub> = 1 ns (from board simulation)

The FPGA timing parameters must be obtained from the timing report that results from the implementation of the system-level design example in the FPGA targeted for use in the application. To generate the necessary reports, the timing analyzer must be run using the "-fastpaths" option.

The examples that follow are excerpts from the timing analyzer report generated from a Virtex-6 device implementation of the system-level design example. The purpose of the examples are to illustrate where to find the required information.

Locate T<sub>qfpga</sub> by searching the timing report for flip-flop to pad maximum path timing analysis, where the destination pad is identified as "external\_c".

- T<sub>afpaa</sub> = I/O Datapath Delay (external\_c)
- $T_{qfpqa} = 3.360 \text{ ns}, \text{ maximum}$

```
Slack: 13.042ns (requirement - (clock arrival + clock path + datapath + uncertainty))
Source: example_ext/example_ext_byte/ext_c_ofd (FF)
Destination: external_c (PAD)
Source Clock: icap_clk rising at 0.000ns
Requirement: 20.000ns
Datapath Delay: 3.360ns (Levels of Logic = 1)
Clock Path Delay: 3.573ns (Levels of Logic = 2)
Clock Uncertainty: 0.025ns
Clock Uncertainty: 0.025ns ((TSJ^2 + TIJ^2)^1/2 + DJ) / 2 + PE
Total System Jitter (TSJ): 0.050ns
Total Input Jitter (TIJ): 0.000ns
Discrete Jitter (DJ): 0.000ns
Phase Error (PE): 0.000ns
```

Maximum Clock Path at Slow Process Corner: clk to example\_ext/example\_ext\_byte/ext\_c\_ofd Location Delay type Delay(ns) Physical Resource Logical Resource(s) \_\_\_\_\_ U23.I Tiopi 0.702 clk clk\_IBUFG BUFGCTRL\_X0Y0.I0 net (fanout=1) 0.938 clk\_IBUFG BUFGCTRL\_X0Y0.0 Tbgcko\_0 0.092 example\_bufg example\_bufg OLOGIC\_X0Y194.CLK net (fanout=283) 1.841 icap\_clk \_\_\_\_\_ \_\_\_\_\_ Total 3.573ns (0.794ns logic, 2.779ns route) (22.2% logic, 77.8% route) Maximum Datapath at Slow Process Corner: example\_ext/example\_ext\_byte/ext\_c\_ofd to external\_c Location Delay type Delay(ns) Physical Resource Logical Resource(s) \_\_\_\_\_ OLOGIC\_X0Y194.0Q Tockq 0.625 external\_c\_OBUF example\_ext/example\_ext\_byte/ext\_c\_ofd E33.0 net (fanout=1) 0.002 external\_c\_OBUF E33.PAD Tioop 2.733 external\_c external\_c\_OBUF external\_c \_\_\_\_\_ Total **3.360ns** (3.358ns logic, 0.002ns route) (99.9% logic, 0.1% route) \_\_\_\_\_ \_\_\_\_\_

Locate T<sub>qfpga</sub> by searching the timing report for flip-flop to pad minimum path timing analysis, where the destination pad is identified as "external\_c".

- T<sub>afpga</sub> = I/O Datapath Delay (external\_c)
- $T_{qfpqa} = 1.473$  ns, minimum

```
_____
Delay (fastest paths): 2.951ns (clock arrival + clock path + datapath - uncertainty)
Source: example_ext/example_ext_byte/ext_c_ofd (FF)
Destination: external_c (PAD)
Source Clock: icap_clk rising at 0.000ns
Datapath Delay: 1.473ns (Levels of Logic = 1)
Clock Path Delay: 1.503ns (Levels of Logic = 2)
Clock Uncertainty: 0.025ns
Clock Uncertainty: 0.025ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1/2</sup> + DJ) / 2 + PE
Total System Jitter (TSJ): 0.050ns
Total Input Jitter (TIJ): 0.000ns
Discrete Jitter (DJ): 0.000ns
Phase Error (PE): 0.000ns
Minimum Clock Path at Fast Process Corner:
clk to example_ext/example_ext_byte/ext_c_ofd
Location Delay type Delay(ns) Physical Resource Logical Resource(s)
_____
U23.I Tiopi
                0.316 clk clk_IBUFG
BUFGCTRL_X0Y0.I0 net (fanout=1) 0.367 clk_IBUFG
BUFGCTRL_X0Y0.0 Tbgcko_0 0.033 example_bufg example_bufg
OLOGIC X0Y194.CLK net (fanout=283) 0.787 icap clk
_____
            1.503ns (0.349ns logic, 1.154ns route)
Total
           (23.2% logic, 76.8% route)
```

Locate  $T_{sfpga}$  by searching the timing report for pad to flip-flop maximum path timing analysis, where the source pad is identified as "external\_q".

- T<sub>sfpga</sub> = I/O Datapath Delay (external\_q)
- T<sub>sfpga</sub> = 4.943 ns, maximum

```
_____
Slack (setup): 18.398ns (requirement - (datapath - clock path - clock arrival +
uncertainty))
Source:
        external_q (PAD)
Destination: example_ext/example_ext_byte/ext_q_ifd (FF)
Destination Clock: icap_clk rising at 0.000ns
Requirement: 20.000ns
Datapath Delay: 4.943ns (Levels of Logic = 1)
Clock Path Delay: 3.366ns (Levels of Logic = 2)
Clock Uncertainty: 0.025ns
Clock Uncertainty: 0.025ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1/2</sup> + DJ) / 2 + PE
Total System Jitter (TSJ): 0.050ns
Total Input Jitter (TIJ): 0.000ns
Discrete Jitter (DJ): 0.000ns
Phase Error (PE): 0.000ns
Maximum Datapath at Slow Process Corner:
external_q to example_ext/example_ext_byte/ext_q_ifd
Location Delay type Delay(ns) Physical Resource Logical Resource(s)
_____
C33.I Tiopi 0.766 external_q external_q_IBUF
ILOGIC X0Y187.DDLY net (fanout=1) 4.046 external g IBUF
ILOGIC_X0Y187.CLK Tidockd 0.131 fetch_rxdata<0> example_ext/example_ext_byte/ext_q_ifd
_____
            4.943ns (0.897ns logic, 4.046ns route)
Total
           (18.1% logic, 81.9% route)
Minimum Clock Path at Slow Process Corner:
clk to example_ext/example_ext_byte/ext_q_ifd
Location Delay type Delay(ns) Physical Resource Logical Resource(s)
_____
U23.I Tiopi 0.670 clk clk_IBUFG
BUFGCTRL_X0Y0.I0 net (fanout=1) 0.865 clk_IBUFG
BUFGCTRL X0Y0.0 Tbgcko 0 0.087 example bufg example bufg
ILOGIC X0Y187.CLK net (fanout=283) 1.744 icap clk
 _____
            3.366ns (0.757ns logic, 2.609ns route)
Total
```

(22.5% logic, 77.5% route)

Locate  $T_{hfpga}$  by searching the timing report for pad to flip-flop minimum path timing analysis, where the source pad is identified as "external\_q".

- T<sub>hfpga</sub> = I/O Datapath Delay (external\_q)
- $T_{hfpga} = -1.800$  ns, minimum

```
_____
        Slack (hold): 0.131ns (requirement - (clock path + clock arrival + uncertainty - datapath))
Source: external_q (PAD)
Destination: example_ext/example_ext_byte/ext_q_ifd (FF)
Destination Clock: icap_clk rising at 0.000ns
Requirement: 0.000ns
Datapath Delay: 1.800ns (Levels of Logic = 1)
Clock Path Delay: 1.644ns (Levels of Logic = 2)
Clock Uncertainty: 0.025ns
Clock Uncertainty: 0.025ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1/2</sup> + DJ) / 2 + PE
Total System Jitter (TSJ): 0.050ns
Total Input Jitter (TIJ): 0.000ns
Discrete Jitter (DJ): 0.000ns
Phase Error (PE): 0.000ns
Minimum Datapath at Fast Process Corner:
external_q to example_ext/example_ext_byte/ext_q_ifd
Location Delay type Delay(ns) Physical Resource Logical Resource(s)
_____ _____
C33.I
       Tiopi
              0.371 external_g external_g external_g_IBUF
ILOGIC_X0Y187.DDLY net (fanout=1) 1.432 external_q_IBUF
ILOGIC_X0Y187.CLK Tiockdd (-Th) 0.003 fetch_rxdata<0> example_ext_byte/ext_q_ifd
 _____
             1.800ns (0.368ns logic, 1.432ns route)
Total
           (20.4% logic, 79.6% route)
Maximum Clock Path at Fast Process Corner:
clk to example_ext/example_ext_byte/ext_q_ifd
Location Delay type Delay(ns) Physical Resource Logical Resource(s)
_____
U23.I Tiopi
              0.371 clk clk clk_IBUFG
BUFGCTRL X0Y0.IO net (fanout=1) 0.397 clk IBUFG
BUFGCTRL X0Y0.0 Tbgcko 0 0.035 example bufg example bufg
ILOGIC_X0Y187.CLK net (fanout=283) 0.841 icap_clk
_____
            1.644ns (0.406ns logic, 1.238ns route)
Total
           (24.7% logic, 75.3% route)
_____
```

Check:

- Is  $T_{hfpqa} \leq T_{qfpqa,min} + T_{clqx}$ ?
- Is  $-1.800 \text{ ns} \le 1.473 \text{ ns} + 0 \text{ ns}$ ?
- Is -1.800 ns ≤ 1.473 ns? YES

Calculate:

$$T_{clk} \ge 0.5*(T_{qfpga,max} + T_{w1} + T_{dly} + T_{w2} + T_{clqv} + T_{w3} + T_{dly} + T_{w4} + T_{sfpga})$$

requires

```
T_{clk} \ge 0.5*(3.360 \text{ ns} + 1 \text{ ns} + 3 \text{ ns} + 1 \text{ ns} + 8 \text{ ns} + 1 \text{ ns} + 3 \text{ ns} + 1 \text{ ns} + 4.943 \text{ ns})
```

or

 $T_{clk} \ge 13.152 \text{ ns}$ 

The hold requirement is satisfied, and the requirement on  $T_{clk}$  indicates that the SPI Receive Waveform and Timing Budget will restrict the system-level design example input clock cycle time to be 13.152 ns or larger.

#### Example 2: Vivado Design Suite, Kintex-7 FPGA

- T<sub>clgv</sub> = 8 ns (from SPI Flash data sheet)
- $T_{clgx} = 0$  ns (from SPI Flash data sheet)
- T<sub>dlv</sub> = 3 ns (from level translator data sheet)
- $T_{w1} = 1$  ns (from board simulation)
- $T_{w2} = 1$  ns (from board simulation)
- $T_{w3} = 1$  ns (from board simulation)
- $T_{w4} = 1$  ns (from board simulation)

The FPGA timing parameters must be obtained from the timing report from the implementation of the system-level design example in the FPGA targeted for use in the application. To generate the necessary report, use "report\_timing\_summary" to generate a report using the "min\_max" option.

The examples that follow are excerpts from the timing report generated from a Kintex-7 device implementation of the system-level example design. The purpose of the example is to illustrate where to find the required information. If the information is not easily located in the report, increase the maximum number of paths reported.

Locate T<sub>qfpga</sub> by searching the timing report for flip-flop to pad path analysis at Max at Slow Process Corner, where the destination is identified as "external\_c".

- T<sub>qfpqa</sub> = I/O Datapath Delay (external\_c)
- T<sub>qfpqa</sub> = 3.211 ns, maximum

Destination: external\_c (output port clocked by clk {rise@0.000ns fall@7.576ns period=15.151ns}) Path Group: clk Path Type: Max at Slow Process Corner Requirement: 15.151ns 
 Requirement:
 15.151HS

 Data Path Delay:
 3.211ns (logic 3.211ns (100.000%) route 0.000ns (0.000%))

 Logic Levels:
 1 (OBUF=1)
 Output Delay: -15.151ns Clock Path Skew: -6.385ns (DCD - SCD + CPR) Destination Clock Delay (DCD): 0.000ns Source Clock Delay (SCD): 6.385ns Clock Pessimism Removal (CPR): 0.000ns Clock Uncertainty: 0.035ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1/2</sup> + DJ) / 2 + PE Total System Jitter (TSJ): 0.071ns Total Input Jitter (TIJ): 0.000ns Discrete Jitter (DJ): 0.000ns (PE): 0.000ns Phase Error Location Delay type Incr(ns) Path(ns) Netlist Resource(s) \_\_\_\_\_ \_\_\_\_\_ 0.000 0.000 r 0.000 0.000 r clk 0.000 0.000 clk (clock clk rise edge) R24 net (fo=0) R24 r example\_ibuf/I IBUF (Prop\_ibuf\_I\_0) 1.176 1.176 r example\_ibuf/0 R24 3.130 4.305 clk\_ibufg net (fo=1, routed) BUFGCTRL X0Y0 r example\_bufg/I BUFG (Prop\_bufg\_I\_O) 0.093 net (fo=477, routed) 1.987 BUFGCTRL\_X0Y0 4.398 r example\_bufg/0 1.987 6.385 example\_ext/ example\_ext\_byte/icap\_clk OLOGIC\_X0Y37 r example\_ext/ example\_ext\_byte/ext\_c\_ofd/C \_\_\_\_\_ \_\_\_\_\_ OLOGIC\_X0Y37 FDRE (Prop\_fdre\_C\_Q) 0.366 6.751 r example\_ext/ example\_ext\_byte/ext\_c\_ofd/Q 0.000 6.751 n\_96\_example\_ext net (fo=1, routed) AB20 r external\_c\_OBUF\_inst/I OBUF (Prop\_obuf\_I\_O) 2.845 9.596 r external\_c\_OBUF\_inst/O AB20 0.000 9.596 external\_c net (fo=0) AB20 r external\_c \_\_\_\_\_ \_\_\_\_\_ (clock clk rise edge) 15.151 15.151 r 0.000 15.151 clock pessimism -0.035 15.116 clock uncertainty output delay 15.151 30.267 \_\_\_\_\_ required time 30.267 arrival time -9 596 \_\_\_\_\_ 20.670 slack

Locate T<sub>afpga</sub> by searching the timing report for flip-flop to pad path analysis at Min at Fast Process Corner, where the destination is identified as "external c".

- $T_{dfpda} = I/O Datapath Delay (external_c)$
- $T_{qfpqa} = 1.379$  ns, minimum

```
Slack (MET) :
                         4.460ns
                         example_ext/example_ext_byte/ext_c_ofd/C
 Source:
                          (rising edge-triggered cell FDRE clocked by clk {rise@0.000ns
fall@7.576ns period=15.151ns})
 Destination:
                         external_c
                           (output port clocked by clk {rise@0.000ns fall@7.576ns
period=15.151ns})
                        clk
 Path Group:
 Path Type:
                        Min at Fast Process Corner
 Requirement:
                        0.000ns

        Requirement:
        0.000005

        Data Path Delay:
        1.379ns (logic 1.379ns (100.000%) route 0.000ns (0.000%))

        Logic Levels:
        1 (OBUF=1)

 Output Delay:
                        0.000ns
 Clock Path Skew: -3.117ns (DCD - SCD - CPR)
   Destination Clock Delay (DCD): 0.000ns
                                    3.117ns
   Source Clock Delay (SCD):
   Clock Pessimism Removal (CPR): -0.000ns
 Clock Uncertainty: 0.035ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1/2</sup> + DJ) / 2 + PE
   Total System Jitter (TSJ): 0.071ns
   Total Input Jitter
                          (TIJ):
                                    0.000ns
                           (DJ): 0.000ns
   Discrete Jitter
                           (PE): 0.000ns
   Phase Error
   Location
                      Delay type
                                               Incr(ns) Path(ns) Netlist Resource(s)
  _____
_____
                                                    0.000
                                                             0.000 r
                        (clock clk rise edge)
                                                     0.000 0.000 r clk
0.000 0.000 clk
   R24
                        net (fo=0)
   R24
                                                                  r example_ibuf/I

      IBUF (Prop_ibuf_I_0)
      0.616
      0.616 r example_ibuf/0

      net (fo=1, routed)
      1.675
      2.291
      clk_ibufg

   R24
                        net (fo=1, routed)
   BUFGCTRL_X0Y0
                                                                r example_bufg/I

        BUFG (Prop_bufg_I_0)
        0.026
        2.317 r
        example_bufg/0

        net (fo=477, routed)
        0.800
        3.117
        example_ext/

   BUFGCTRL_X0Y0
example_ext_byte/icap_clk
   OLOGIC X0Y37
                                                                    r example_ext/
example_ext_byte/ext_c_ofd/C
 _____
_____
   OLOGIC_X0Y37 FDRE (Prop_fdre_C_Q) 0.192 3.309 r example_ext/
example_ext_byte/ext_c_ofd/Q
                        net (fo=1, routed) 0.000 3.309 n_96_example_ext
   AB20
                                                               r external_c_OBUF_inst/I
                     OBUF (Prop_obuf_I_0) 1.187 4.495 r external_c_OBUF_inst/0
   AB20
                                                 0.000 4.495 external_c
                      net (fo=0)
   AB20
                                                                   r external_c
  _____
_____
```

(clock clk rise edge)

0.000 0.000 r

| clock pessimism   | 0.000  | 0.000  |
|-------------------|--------|--------|
| clock uncertainty | 0.035  | 0.035  |
| output delay      | -0.000 | 0.035  |
|                   |        |        |
| required time     |        | -0.035 |
| arrival time      |        | 4.495  |
|                   |        |        |
| slack             |        | 4.460  |

Locate T<sub>sfpga</sub> by searching the timing report for pad to flip-flop path analysis at Max at Slow Process Corner, where the source pad is identified as "external\_q".

- Tsfpga = I/O Datapath Delay (external\_q)
- Tsfpga = 7.813 ns, maximum

28.041ns Slack (MET) : Source: external\_q (input port clocked by clk {rise@0.000ns fall@7.576ns period=15.151ns}) Destination: example\_ext/example\_ext\_byte/ext\_q\_ifd/D (rising edge-triggered cell FDRE clocked by clk {rise@0.000ns fall@7.576ns period=15.151ns}) Path Group: clk Max at Slow Process Corner Path Type: 

 Path Type.

 Requirement:
 15.151ns

 Data Path Delay:
 7.813ns (logic 7.813ns (100.000%) route 0.000ns (0.000%))

 2
 (TPUE-1 ZHOLD DELAY=1)

 Logic Levels: Input Delay: -15.151ns Clock Path Skew: 5.588ns (DCD - SCD + CPR) Destination Clock Delay (DCD): 5.588ns Source Clock Delay (SCD): 0.000ns Clock Pessimism Removal (CPR): 0.000ns Clock Uncertainty: 0.035ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1</sup>/2 + DJ) / 2 + PE Total System Jitter (TSJ): Total Input Jitter (TIJ): 0.071ns 0.000ns Discrete Jitter (DJ): 0.000ns Phase Error (PE): 0.000ns Location Delay type Incr(ns) Path(ns) Netlist Resource(s) \_\_\_\_\_ \_\_\_\_\_ (clock clk rise edge) 0.000 0.000 r input delay -15.151 -15.151 0.000 -15.151 r external\_q AD21 0.000 -15.151 external\_q net (fo=0) AD21 r external\_q\_IBUF\_inst/I IBUF (Prop\_ibuf\_I\_O) 1.161 -13.990 r external\_q\_IBUF\_inst/O net (fo=1, routed) 0.000 -13.990 example\_ext/ AD21 example\_ext\_byte/external\_q\_IBUF ILOGIC\_X0Y30 r example\_ext/ example\_ext\_byte/ext\_q\_ifd\_OPT\_INSERTED/DLYIN ILOGIC\_X0Y30 ZHOLD\_DELAY (Prop\_zhold\_delay\_DLYIN\_DLYIFF) 6.797 -7.193 r example\_ext/ example\_ext\_byte/ext\_q\_ifd\_OPT\_INSERTED/DLYIFF net (fo=1, routed) 0.000 -7.193 example\_ext/ example\_ext\_byte/OPT\_ZHD\_N\_ext\_q\_ifd

| ILOGIC_X0Y30                                                            |                       |        | r        | example_ext/   |
|-------------------------------------------------------------------------|-----------------------|--------|----------|----------------|
| <pre>example_ext_byte/ex     ILOGIC_X0Y30     example_ext_byte/ex</pre> | FDRE (Setup_fdre_C_D) | -0.145 | -7.338   | example_ext/   |
|                                                                         |                       |        |          |                |
|                                                                         |                       |        |          |                |
|                                                                         |                       |        |          |                |
|                                                                         | (clock clk rise edge) |        |          |                |
| R24                                                                     |                       | 0.000  | 15.151 r | clk            |
|                                                                         | net (fo=0)            | 0.000  | 15.151   | clk            |
| R24                                                                     |                       |        | r        | example_ibuf/I |
| R24                                                                     | IBUF (Prop_ibuf_I_O)  | 1.113  | 16.264 r | example_ibuf/0 |
|                                                                         | net (fo=1, routed)    | 2.604  | 18.868   | clk_ibufg      |
| BUFGCTRL_X0Y0                                                           |                       |        | r        | example_bufg/I |
| BUFGCTRL_X0Y0                                                           | BUFG (Prop_bufg_I_O)  | 0.083  | 18.951 r | example_bufg/0 |
|                                                                         | net (fo=477, routed)  | 1.788  | 20.739   | example_ext/   |
| example_ext_byte/ic                                                     | ap_clk                |        |          |                |
| ILOGIC_X0Y30                                                            |                       |        | r        | example_ext/   |
| example_ext_byte/ex                                                     | t_q_ifd/C             |        |          |                |
|                                                                         | clock pessimism       | 0.000  | 20.739   |                |
|                                                                         | clock uncertainty     | -0.035 | 20.703   |                |
|                                                                         |                       |        |          |                |
|                                                                         | required time         |        | 20.703   |                |
|                                                                         | arrival time          |        | 7.338    |                |
|                                                                         | slack                 |        | 28.041   |                |
|                                                                         | BIACK                 |        | 20.041   |                |

Locate T<sub>hfpga</sub> by searching the timing report for pad to flip-flop path analysis at Min at Fast Process Corner, where the source pad is identified as "external\_q".

- T<sub>hfpga</sub> = I/O Datapath Delay (external\_q)
- $T_{hfpga} = -3.386 \text{ ns}, \text{ minimum}$

```
Slack (MET) :
                             29.797ns
  Source:
                             external_q
                                (input port clocked by clk {rise@0.000ns fall@7.576ns
period=15.151ns})
  Destination:
                             example_ext/example_ext_byte/ext_q_ifd/D
                              (rising edge-triggered cell FDRE clocked by clk {rise@0.000ns
fall@7.576ns period=15.151ns})
  Path Group:
                             clk
  Path Type:
                            Min at Fast Process Corner

        Requirement:
        0.000ns

        Data Path Delay:
        3.386ns (logic 3.386ns (100.000%) route 0.000ns (0.000%))

        Logic Levels:
        2 (IBUF=1 ZHOLD_DELAY=1)

  Logic Levels:
  Input Delay:
                             30.302ns
  Input Delay:50.502118Clock Path Skew:3.856ns (DCD - SCD - CPR)
    Destination Clock Delay (DCD): 3.856ns
    Source Clock Delay (SCD):
                                          0.000ns
    Clock Pessimism Removal (CPR):
                                          -0.000ns
  Clock Uncertainty: 0.035ns ((TSJ<sup>2</sup> + TIJ<sup>2</sup>)<sup>1</sup>/2 + DJ) / 2 + PE
    Total System Jitter (TSJ): 0.071ns
                                          0.000ns
    Total Input Jitter
                              (TIJ):
    Discrete Jitter
                               (DJ):
                                          0.000ns
                                          0.000ns
    Phase Error
                                (PE):
```

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Location             | Delay type                 | Incr(ns)   | Path(ns)    | N   | Netlist Resource(s) |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------------|------------|-------------|-----|---------------------|
| input delay 30.302 30.302<br>AD21 0.000 30.302 r external_q<br>AD21 ret (fo=0) 0.000 30.302 r external_q<br>AD21 r external_q_IBUF_inst/I<br>AD21 IBUF (Prop_ibuf_I_O) 0.601 30.903 r external_q_IBUF_inst/I<br>AD21 ret (fo=1, routed) 0.000 30.903 r external_q_IBUF_inst/O<br>net (fo=1, routed) 0.000 30.903 r external_q_IBUF_inst/O<br>example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIN<br>ILOGIC_X0Y30 r extarple_ext/<br>example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF<br>net (fo=1, routed) 0.000 33.842 r example_ext/<br>example_ext_byte/OPT_ZHD_N_ext_q_ifd<br>ILOGIC_X0Y30 r extarple_ext/<br>example_ext_byte/ext_q_ifd/D r example_ext/<br>example_ext_byte/ext_q_ifd/D r example_ext/<br>example_ext_byte/ext_q_ifd/D r example_ext/<br>example_ext_byte/ext_q_ifd/D r example_ext/<br>example_ext_byte/ext_q_ifd<br>ILOGIC_X0Y30 PDRR (Hold_fdre_C_D) -0.154 33.688 example_ext/<br>example_ext_byte/ext_q_ifd<br>r example_ext_byte/ext_q_ifd<br>r example_ext_byte/ext_q_ifd<br>EX24 r example_buf/I<br>R24 fIBUF (Prop_ibuf_I_O) 0.782 0.782 r example_ibuf/I<br>R24 r example_bufg/I<br>BUFGCTRL_X0Y0 BUFG (Prop_bufg_I_O) 0.030 2.795 r example_bufg/I<br>BUFGCTRL_X0Y0 BUFG (Prop_bufg_I_O) 0.030 2.795 r example_bufg/O<br>net (fo=1, routed) 1.061 3.856 example_ext/<br>example_ext_byte/ext_q_ifd/C r example_bufg/O<br>BUFGCTRL_X0Y0 BUFG (Prop_bufg_I_O) 0.030 2.795 r example_bufg/O<br>net (fo=477, routed) 1.061 3.856 example_ext/<br>example_ext_byte/ext_q_ifd/C r example_ext/<br>example_ext_byte/ext_q_ifd/C r example_ext/<br>example_ext_byte/ext_q_ifd/C r example_ext/<br>example_ext_byte/ext_q_ifd/C r example_ext/<br>example_ext_byte/ext_q_ifd/C r example_ext/<br>example_ext_byte/ext_q_ifd/C r ret example_ext/<br>example_ext_byte/ext_q_ifd/C |                      |                            |            |             |     |                     |
| AD21         0.000         30.302 r external_q           net (fo=0)         0.000         30.302 external_q_IBUF_inst/I           AD21         r external_q_IBUF_inst/I           AD21         net (fo=1, routed)         0.000         30.903 r external_q_IBUF_inst/I           example_ext_byte/external_q_IBUF         0.000         30.903 r external_q_IBUF_inst/I           LOGIC_X0730         r example_ext/           example_ext_byte/exterifd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                      | (clock clk rise edge)      | 0.000      | 0.000       | r   |                     |
| AD21         0.000         30.302 r external_q           net (fo=0)         0.000         30.302 external_q_IBUF_inst/I           AD21         r external_q_IBUF_inst/I           AD21         net (fo=1, routed)         0.000         30.903 r external_q_IBUF_inst/I           example_ext_byte/external_q_IBUF         0.000         30.903 r external_q_IBUF_inst/I           LOGIC_X0730         r example_ext/           example_ext_byte/exterifd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |                            | 30.302     | 30.302      |     |                     |
| AD21       r external_q_IBUF_inst/I         AD21       IBUF (Prop_ibuf_T_0)       0.601       30.903 r external_q_IBUF_inst/O         example_ext_byte/external_q_IBUF       0.000       30.903       example_ext/         iLOGIC_X0Y30       r example_ext/         example_ext_byte/exter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | AD21                 |                            |            |             | r   | external_q          |
| AD21         IBUF (Prop_ibuf_I_O)<br>net (fo=1, routed)         0.601         30.903 r external_q_IBUF_inst/O<br>0.000         30.903 example_ext/           example_ext_byte/external_q_IBUF         r         example_ext_byte/external_q_IBUF         r         example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIN           ILOGIC_X0Y30         ZHOLD_DELAY (Prop_shold_delay_DLYIN_DLYIFF)         2.939         33.842 r         example_ext_/           example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF         net (fo=1, routed)         0.000         33.842 r         example_ext/           example_ext_byte/OPT_ZHD_N_ext_q_ifd         r         r         example_ext/           iLOGIC_X0Y30         FDRE (Hold_fdre_C_D)         -0.154         33.688         example_ext/           example_ext_byte/ext_q_ifd         r         r         example_ext/           example_ext_byte/ext_q_ifd         r         rexample_iouf/I           reample_ext_byte/ext_q_ifd         r         r         rexample_iouf/I           reample_ext_byte/ext_q_ifd         r         rexample_iouf/I         rexample_iouf/I           reample_ext_byte/ext_q_ifd         r         rexample_iouf/I         rexample_iouf/I           reample_ext_byte/ext_q_ifd         r         rexample_iouf/I         rexample_iouf/I           reample_ext_byte/ext_q_ifd         r         re exampl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                      | net (fo=0)                 | 0.000      | 30.302      |     | external_q          |
| net (fo=1, routed)0.00030.903example_ext/example_ext_byte/extranl_q_TBUF<br>ILOGIC_X0Y30rexample_ext/example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIN2.93933.842 rexample_ext/example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF<br>net (fo=1, routed)0.00033.842 rexample_ext/example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF<br>net (fo=1, routed)rexample_ext/example_ext_byte/ext_q_ifd/D<br>ILOGIC_X0Y30rexample_ext/example_ext_byte/ext_q_ifd/D<br>ILOGIC_X0Y30rexample_ext/example_ext_byte/ext_q_ifd0.0000.000 rrecomple_ext_byte/ext_q_ifdrexample_ext/example_ext_byte/ext_q_ifdrexample_ibuf/Irecomple_ext_byte/ext_q_ifdrexample_ibuf/Irecomple_ext_byte/ext_q_ifdrexample_ibuf/Irecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrexample_ibuf/Irecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdrrrecomple_ext_byte/ext_q_ifdr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | AD21                 |                            |            | r ez        | xte | ernal_q_IBUF_inst/I |
| example_ext_byte/external_q_IBUF       r       example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIN         ILGGIC_X0Y30       ZHOLD_DELAY (Prop_zhold_delay_DLYIN_DLYIFF)       2.939       33.842 r       example_ext/         example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF       net (fo=1, routed)       0.000       33.842       example_ext/         example_ext_byte/OPT_ZHD_N_ext_q_ifd       r       example_ext_byte/OPT_ZHD_N_ext_q_ifd       r         ILOGIC_X0Y30       FDRE (Hold_fdre_C_D)       -0.154       33.688       example_ext/         example_ext_byte/ext_q_ifd       r       example_ext_byte/ext_q_ifd         ILOGIC_X0Y30       FDRE (Hold_fdre_C_D)       -0.154       33.688       example_ext/         example_ext_byte/ext_q_ifd       r       example_ext/         example_ext_byte/ext_q_ifd       r       example_ext/         example_ext_byte/ext_q_ifd       r       example_lout/r         rexample_ext_byte/ext_q_ifd       r       example_lout/r         rexample_ext_byte/ext_q_ifd       r       rexample_ext/         rexample_ext_byte/r       net (fo=0)       0.000       0.000 r       r         R24       net (fo=1, routed)       1.984       2.765       clk_ibufg         BUFGCTRL_XOYO       r       rexample_ext/       example_bufg/I </td <td>AD21</td> <td>IBUF (Prop_ibuf_I_O)</td> <td>0.601 3</td> <td>30.903 r ez</td> <td>xte</td> <td>ernal_q_IBUF_inst/0</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | AD21                 | IBUF (Prop_ibuf_I_O)       | 0.601 3    | 30.903 r ez | xte | ernal_q_IBUF_inst/0 |
| ILOGIC_X0Y30       r       example_ext_byte/ext_g_ifd_OPT_INSERTED/DLYIN         ILOGIC_X0Y30       ZHOLD_DELAY (Prop_zhold_delay_DLYIN_DLYIFF)       2.939       33.842 r       example_ext/         example_ext_byte/ext_g_ifd_OPT_INSERTED/DLYIFF       net (foe1, routed)       0.000       33.842 r       example_ext/         example_ext_byte/OPT_ZHD_N_ext_g_ifd       r       example_ext_byte/oPT_ZHD_N_ext_g_ifd       r       example_ext_byte/ext_g_ifd/         ILOGIC_X0Y30       FDRE (Hold_fdre_C_D)       -0.154       33.688       example_ext/         example_ext_byte/ext_g_ifd/D       r       example_ext_byte/ext_g_ifd/       example_ext_byte/ext_g_ifd/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      | net (fo=1, routed)         | 0.000      | 30.903      |     | example_ext/        |
| <pre>example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIN<br/>ILOGIC_X0Y30 ZHOLD_DELAY (Prop_zhold_delay_DLYIN_DLYIFF)<br/>2.939 33.842 r example_ext/<br/>example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF<br/>net (fo=1, routed) 0.000 33.842 example_ext/<br/>example_ext_byte/OPT_ZHD_N_ext_q_ifd<br/>ILOGIC_X0Y30 FDRE (Hold_fdre_C_D) -0.154 33.688 example_ext/<br/>example_ext_byte/ext_q_ifd<br/>ILOGIC_X0Y30 FDRE (Hold_fdre_C_D) -0.154 33.688 example_ext/<br/>example_ext_byte/ext_q_ifd<br/>(clock clk rise edge) 0.000 0.000 r clk<br/>R24 (clock clk rise edge) 0.000 0.000 r clk<br/>R24 (fo=0) 0.000 0.000 clk<br/>R24 r example_ibuf/I<br/>R24 IBUF (Prop_ibuf_I_O) 0.782 0.782 r example_ibuf/I<br/>BUFGCTRL_X0Y0 BUFG (Prop_bufg_I_O) 0.030 2.795 r example_bufg/I<br/>BUFGCTRL_X0Y0 BUFG (Prop_bufg_I_O) 0.030 2.795 r example_bufg/O<br/>net (fo=477, routed) 1.061 3.856 example_ext/<br/>example_ext_byte/ext_q_ifd/C<br/>r example_ext_/<br/>example_ext_byte/ext_q_ifd/C<br/>clock uncertainty 0.035 3.892<br/></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | example_ext_byte/ext | ernal_q_IBUF               |            |             |     |                     |
| <pre>ILOGIC_X0Y30 ZHOLD_DELAY (Prop_zhold_delay_DLYIN_DLYIFF)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ILOGIC_X0Y30         |                            |            |             | r   | example_ext/        |
| 2.939 33.842 r example_ext/<br>example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF<br>net (fo=1, routed) 0.000 33.842 example_ext/<br>example_ext_byte/OPT_ZHD_N_ext_q_ifd<br>ILOGIC_X0Y30 FDRE (Hold_fdre_C_D) -0.154 33.688 example_ext/<br>example_ext_byte/ext_q_ifd<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | example_ext_byte/ext | _q_ifd_OPT_INSERTED/DLYIN  |            |             |     |                     |
| <pre>example_ext_byte/ext_q_ifd_OPT_INSERTED/DLYIFF<br/>net (fo=1, routed) 0.000 33.842 example_ext/<br/>example_ext_byte/OPT_ZHD_N_ext_q_ifd<br/>ILOGIC_X0Y30 FDRE (Hold_fdre_C_D) -0.154 33.688 example_ext/<br/>example_ext_byte/ext_q_ifd</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ILOGIC_X0Y30         | ZHOLD_DELAY (Prop_zhold    | delay_DLYI | N_DLYIFF)   |     |                     |
| net (fo=1, routed)0.00033.842example_ext/example_ext_byte/OPT_ZHD_N_ext_q_ifd<br>ILOGIC_X0Y30rexample_ext/example_ext_byte/ext_q_ifd/<br>ILOGIC_X0Y30FDRE (Hold_fdre_C_D)-0.15433.688example_ext/example_ext_byte/ext_q_ifd<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |                            | 2.939      | 33.842      | r   | example_ext/        |
| example_ext_byte/OPT_ZHD_N_ext_q_ifd<br>LLOGIC_X0Y30 r example_ext/<br>example_ext_byte/ext_q_ifd/D<br>LLOGIC_X0Y30 FDRE (Hold_fdre_C_D) -0.154 33.688 example_ext/<br>example_ext_byte/ext_q_ifd<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | example_ext_byte/ext | _q_ifd_OPT_INSERTED/DLYIFF |            |             |     |                     |
| ILOGIC_X0Y30       r       example_ext_byte/ext_q_ifd/D         ILOGIC_X0Y30       FDRE (Hold_fdre_C_D)       -0.154       33.688       example_ext/         example_ext_byte/ext_q_ifd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      | net (fo=1, routed)         | 0.000      | 33.842      |     | example_ext/        |
| example_ext_byte/ext_q_ifd/D       ILOGIC_X0Y30       FDRE (Hold_fdre_C_D)       -0.154       33.688       example_ext/         example_ext_byte/ext_q_ifd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | example_ext_byte/OP1 | _ZHD_N_ext_q_ifd           |            |             |     |                     |
| ILOGIC_X0Y30       FDRE (Hold_fdre_C_D)       -0.154       33.688       example_ext/         example_ext_byte/ext_q_ifd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ILOGIC_X0Y30         |                            |            |             | r   | example_ext/        |
| example_ext_byte/ext_q_ifd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | example_ext_byte/ext | _q_ifd/D                   |            |             |     |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ILOGIC_X0Y30         | FDRE (Hold_fdre_C_D)       | -0.154     | 33.688      |     | example_ext/        |
| (clock clk rise edge)       0.000       0.000 r         R24       0.000       0.000 r         net (fo=0)       0.000       0.000 clk         R24       r       example_ibuf/I         R24       IBUF (Prop_ibuf_I_0)       0.782       0.782 r       example_ibuf/O         net (fo=1, routed)       1.984       2.765       clk_ibufg         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/I         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/O         net (fo=477, routed)       1.061       3.856       example_ext/         example_ext_byte/icap_clk       r       example_ext/         ILOGIC_X0Y30       r       r       example_ext/         required time       -3.892                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | example_ext_byte/ext | _q_ifd                     |            |             |     |                     |
| (clock clk rise edge)       0.000       0.000 r         R24       net (fo=0)       0.000       0.000 clk         R24       net (fo=0)       0.000       0.000 clk         R24       IBUF (Prop_ibuf_T_0)       0.782       0.782 r       example_ibuf/I         R24       IBUF (Prop_ibuf_T_0)       0.782       0.782 r       example_ibuf/I         R24       IBUF (Prop_ibuf_T_0)       0.782       0.782 r       example_ibuf/I         BUFGCTRL_X0Y0       BUFG (Prop_bufg_T_0)       0.030       2.795 r       example_bufg/I         BUFGCTRL_X0Y0       BUFG (Prop_bufg_T_0)       0.030       2.795 r       example_bufg/O         net (fo=477, routed)       1.061       3.856       example_ext/         example_ext_byte/icap_clk       r       example_ext/         ILOGIC_X0Y30       r       r       example_ext/         example_ext_byte/ext_q_ifd/C       r       example_ext/         required time       -3.892                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |                            |            |             |     |                     |
| R24       0.000       0.000 r       clk         R24       net (fo=0)       0.000       0.000 r       clk         R24       IBUF (Prop_ibuf_I_0)       0.782       0.782 r       example_ibuf/I         R24       IBUF (Prop_ibuf_I_0)       0.782       0.782 r       example_ibuf/O         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/I         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/O         net (fo=477, routed)       1.061       3.856       example_ext/         example_ext_byte/icap_clk       r       example_ext/         ILOGIC_X0Y30       r       example_ext/         clock uncertainty       0.035       3.892         required time         arrival time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                      |                            |            |             |     |                     |
| R24       0.000       0.000 r       clk         R24       net (fo=0)       0.000       0.000 r       clk         R24       IBUF (Prop_ibuf_I_0)       0.782       0.782 r       example_ibuf/I         R24       IBUF (Prop_ibuf_I_0)       0.782       0.782 r       example_ibuf/O         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/I         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/O         net (fo=477, routed)       1.061       3.856       example_ext/         example_ext_byte/icap_clk       r       example_ext/         ILOGIC_X0Y30       r       example_ext/         clock uncertainty       0.035       3.892         required time         arrival time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                      |                            |            |             |     |                     |
| net (fo=0)0.0000.000clkR24IBUF (Prop_ibuf_I_0)0.7820.782 rexample_ibuf/IR24IBUF (Prop_ibuf_I_0)0.7820.782 rexample_ibuf/Onet (fo=1, routed)1.9842.765clk_ibufgBUFGCTRL_X0Y0BUFG (Prop_bufg_I_0)0.0302.795 rexample_bufg/IBUFGCTRL_X0Y0BUFG (Prop_bufg_I_0)0.0302.795 rexample_bufg/Onet (fo=477, routed)1.0613.856example_ext/example_ext_byte/icap_clkrexample_ext/ILOGIC_X0Y30rrexample_ext/clock pessimism0.0003.856clock uncertainty0.035required time-3.89233.688arrival time33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                      | (clock clk rise edge)      |            |             |     |                     |
| R24rexample_ibuf/IR24IBUF (Prop_ibuf_I_0)0.7820.782rexample_ibuf/0net (fo=1, routed)1.9842.765clk_ibufgBUFGCTRL_X0Y0BUFG (Prop_bufg_I_0)0.0302.795rexample_bufg/0BUFGCTRL_X0Y0BUFG (Prop_bufg_I_0)1.0613.856example_ext/example_ext_byte/icap_clkrexample_ext_/rexample_ext/ILOGIC_X0Y30clock pessimism0.0003.856clock uncertainty0.0353.892required time-3.892arrival time33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R24                  |                            |            |             |     |                     |
| R24       IBUF (Prop_ibuf_I_0)<br>net (fo=1, routed)       0.782       0.782 r       example_ibuf/0<br>clk_ibufg         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)<br>net (fo=477, routed)       0.030       2.795 r       example_bufg/0<br>example_ext_byte/icap_clk<br>ILOGIC_X0Y30         example_ext_byte/icap_clk       r       example_ext/         clock pessimism       0.000       3.856         clock uncertainty       0.035       3.892         required time         arrival time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      | net (fo=0)                 | 0.000      | 0.000       |     |                     |
| net (fo=1, routed)1.9842.765clk_ibufg<br>rBUFGCTRL_X0Y0BUFG (Prop_bufg_I_O)0.0302.795rexample_bufg/OBUFGCTRL_X0Y0BUFG (Prop_bufg_I_O)0.0302.795rexample_bufg/Onet (fo=477, routed)1.0613.856example_ext/example_ext_byte/icap_clkrexample_ext/ILOGIC_X0Y30rrexample_ext/example_ext_byte/ext_g_ifd/Cclock pessimism0.0003.856clock uncertainty0.0353.892required timearrival time33.68833.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      |                            |            |             |     |                     |
| BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/0         BUFGCTRL_X0Y0       BUFG (Prop_bufg_I_0)       0.030       2.795 r       example_bufg/0         example_ext_byte/icap_clk       1.061       3.856       example_ext/         ILOGIC_X0Y30       r       example_ext/         example_ext_byte/ext_q_ifd/C       r       example_ext/         clock pessimism       0.000       3.856         clock uncertainty       0.035       3.892         required time       -3.892         arrival time       33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R24                  |                            |            |             |     | =                   |
| BUFGCTRL_X0Y0BUFG (Prop_bufg_I_O)<br>net (fo=477, routed)0.030<br>1.0612.795 r<br>example_bufg/O<br>example_ext/example_ext_byte/icap_clk<br>ILOGIC_X0Y30r<br>r<br>example_ext_difd/Cr<br>example_ext/clock pessimism<br>clock uncertainty0.000<br>0.0353.856<br>3.892required time<br>arrival time-3.892<br>33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      | net (fo=1, routed)         | 1.984      | 2.765       |     |                     |
| net (fo=477, routed) 1.061 3.856 example_ext/<br>example_ext_byte/icap_clk<br>ILOGIC_X0Y30 r example_ext/<br>example_ext_byte/ext_q_ifd/C<br>clock pessimism 0.000 3.856<br>clock uncertainty 0.035 3.892<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | BUFGCTRL_X0Y0        |                            |            |             | r   |                     |
| example_ext_byte/icap_clk<br>ILOGIC_X0Y30 r example_ext/<br>example_ext_byte/ext_q_ifd/C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | BUFGCTRL_X0Y0        |                            | 0.030      | 2.795       | r   |                     |
| ILOGIC_X0Y30 r example_ext/<br>example_ext_byte/ext_q_ifd/C<br>clock pessimism 0.000 3.856<br>clock uncertainty 0.035 3.892<br>required time -3.892<br>arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                            | 1.061      | 3.856       |     | example_ext/        |
| example_ext_byte/ext_q_ifd/C<br>clock pessimism 0.000 3.856<br>clock uncertainty 0.035 3.892<br>required time -3.892<br>arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | example_ext_byte/ica | up_clk                     |            |             |     |                     |
| clock pessimism 0.000 3.856<br>clock uncertainty 0.035 3.892<br>required time -3.892<br>arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ILOGIC_X0Y30         |                            |            |             | r   | example_ext/        |
| clock uncertainty 0.035 3.892<br>required time -3.892<br>arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | example_ext_byte/ext | _q_ifd/C                   |            |             |     |                     |
| required time -3.892<br>arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                      | _                          | 0.000      | 3.856       |     |                     |
| arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      | clock uncertainty          | 0.035      | 3.892       |     |                     |
| arrival time 33.688                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      | roquired time              |            | _3 202      |     |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      | -                          |            |             |     |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      | arrivar time               |            | 22.088      |     |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      | slack                      |            | 29.797      |     |                     |

Check:

- Is  $T_{hfpga} \leq T_{qfpga,min} + T_{clqx}$ ?
- Is -3.386 ns ≤ 1.379 ns + 0 ns?
- Is -3.386 ns ≤ 1.379 ns? YES

Calculate:

$$T_{clk} \ge 0.5*(T_{qfpga,max} + T_{w1} + T_{dly} + T_{w2} + T_{clqv} + T_{w3} + T_{dly} + T_{w4} + T_{sfpga})$$

requires

```
T_{clk} \ge 0.5*(3.211 \text{ ns} + 1 \text{ ns} + 3 \text{ ns} + 1 \text{ ns} + 8 \text{ ns} + 1 \text{ ns} + 3 \text{ ns} + 1 \text{ ns} + 7.813 \text{ ns})
```

or

 $T_{clk} \ge 14.512 \text{ ns}$ 

The hold requirement is satisfied, and the requirement on Tclk indicates that the SPI Receive Waveform and Timing Budget will restrict the system-level design example input clock cycle time to be 14.512 ns or larger.

#### **SPI Bus Timing Budget Conclusions**

When the EXT shim and external memory system are present, the SPI bus timing budget must be analyzed to ensure a robust implementation. The result of the analysis confirms that the external memory system is functional, and reveal any constraints it may pose on the maximum frequency of the system-level design example input clock.

#### Example 1 Conclusion

Using the example data from the ISE Design Suite timing report for a Virtex-6 SEM IP implementation, the memory interface is functional. The most stringent requirement on Tclk is that Tclk  $\geq$  13.152 ns, as the memory interface only works when the input clock frequency is 76.037 MHz or lower. Other input clock frequency limits, such as the ICAP maximum clock frequency and the system-level example maximum clock frequency, must also be considered.

#### **Example 2 Conclusion**

Using the example data from the Vivado Design Suite timing report for a Kintex-7 SEM IP implementation, the memory interface is functional. The most stringent requirement on Tclk is that Tclk  $\ge$  14.512 ns, as the memory interface only works when the input clock frequency is 68.908 MHz or lower. Other input clock frequency limits, such as the ICAP maximum clock frequency and the system-level example maximum clock frequency, must also be considered.

### **Error Injection Interface**

The Error Injection Interface consists of an input bus and input strobe, implementing a simple parallel input port. This interface is only present when Error Injection is enabled and I/O Pins are selected. Direct, logic-signal-based error injection is possible from the Error Injection Interface. The use of this interface is entirely optional. This interface accepts four types of commands:

- Command to enter Idle state (halt normal scanning to inject errors)
- Command to enter Observation state (resume normal scanning)
- Inject error at physical frame address

• Inject error at linear frame address

For SSI implementations of the system-level example design, there is a controller instance on each SLR, with all controller instances receiving the signals from the Error Injection Interface. In many cases, signals from the Error Injection Interface can be brought to I/O pins on the FPGA.

In one configuration, the system-level design example brings all of the signals to I/O pins. It is possible to generate and drive the error injection signals inside the FPGA; this is what is done when the ChipScope analyzer is selected rather than I/O pins.

Externally, the error injection signals can be connected to another device for control. To properly capture supplied commands, the timing requirements of the Error Injection Interface must be accounted for when interfacing to another device.

The signals in the Error Injection Interface are received by a sequential logic process in controllers using the strobe to enable an input register. The timing requirements shown in Figure 3-13 must be observed to ensure successful data capture.



Figure 3-13: Error Injection Interface Timing Requirements

The clock signal shown in Figure 3-13 is meant only to illustrate the waveform time scale. While the pulse widths are specified in terms of clock cycles, the external device generating and driving the error injection signals need not be synchronous to the clock signal.

If an error is injected into a frame that is masked or beyond the supported address range for a device or SEU coverage, the error injection command will be ignored and no error will be detected in the observation state.

## **Behaviors**

The system-level design example exhibits certain high-level functional behaviors during operation, based on the controller design. This section is intended to convey expected behaviors and how to interact with the system-level design example. In SSI implementations of the system-level design example, the multiple controller instances exhibit the same behaviors as the single controller in a non-SSI implementation.

## **Controller Activity**

#### Initialization

During FPGA configuration, the controller is held inactive by the FPGA global set/reset signal. At the completion of configuration, the FPGA configuration system deasserts the global set/reset signal and the controller boots. The controller maintains all five state bits on the Status Interface deasserted through the boot process.

In controller implementations for 7 series devices, the controller polls its icap\_grant input during boot to determine if it has been granted permission to enter the initialization state and begin using ICAP. In implementations for most devices, icap\_grant should be tied High. Implementations in Zynq devices, however, require special handling of the icap\_grant signal.

During boot of the Zynq Processing System (PS), access to the configuration logic in the device is given to the PS through the processor configuration access port (PCAP). This provides a path for the PS bootloader to download a bitstream to the Zynq Programmable Logic (PL). When the PS bootloader completes, the PS and PCAP remain in control of the configuration logic to support partial reconfiguration of the PL by the PS.

However, while the PS and PCAP are in control of the configuration logic, the PL and ICAP are locked out of the configuration logic. In order for the controller to function, configuration logic access must be transferred to the ICAP. This is accomplished by clearing PCAP\_PR (bit 27) in the PS device configuration control register (DEVCFG CTRL, address 0xF8007000). Figure 3-14 illustrates how PCAP, ICAP, and PCAP\_PR interact.



*Figure 3-14:* Configuration Logic Access in Zynq-7000

The controller has no simple method to sense the ICAP is locked out. During the initialization state, the controller polls the ICAP, attempting to read the configuration logic IDCODE register, until it observes the expected vendor identification value. However, if the PS clears PCAP\_PR during a controller attempt to access the ICAP, the configuration logic may receive a malformed ICAP transaction. This results in unpredictable behavior of the configuration logic.

To eliminate this possibility, it is necessary for the PS to drive the controller icap\_grant
input via the GPIO and prevent the controller from entering the initialization state until after
PCAP\_PR has been cleared. The GPIO used may either be an EMIO from the PS or a GPIO in the PL, but it must be initialized so that the controller observes icap\_grant deasserted immediately upon completion of PL configuration.

When software running on the PS has completed all necessary PCAP activity, it clears PCAP\_PR and then sets the GPIO connected to the controller icap\_grant input, allowing

the controller to proceed with initialization. The signal applied to the icap\_grant input must be properly synchronized to the icap\_clk signal. The software implementation of this behavior is outside the scope of this document. See Zynq-7000 EPP Software Developers Guide (UG821) [Ref 5] and OS and Libraries Document Collection (UG643) [Ref 6], for detailed information about software development for Baremetal and Linux environments.

During the initialization state, status\_initialization is TRUE. Initialization includes some internal housekeeping, as well as directly observable events such as the generation of a status report on the Monitor Interface. The specific activities are:

- A first readback cycle during which the frame-level ECC checksums are computed
- A second readback cycle during which the device-level CRC checksum is computed
- An additional readback cycle during which an additional checksum is computed (only executed if Virtex-6 or 7 series devices are targeted)
- An additional readback cycle during which the frame-level CRC checksums are computed and stored in block RAM (only executed if correction by enhanced repair is used)

At the completion of initialization, the controller transitions to the observation state.

#### Observation

The controller spends virtually all of its time in the observation state. During the observation state, status\_observation is TRUE and the controller observes the FPGA configuration system for indication of error conditions. If no error exists, and the controller receives a command (from either the Error Injection Interface or the Monitor Interface), then the controller processes the received command. Only two commands are supported in the observation state, the "enter idle" and "status report" commands. The controller ignores all other commands.

The "enter idle" command can be applied through either the Error Injection Interface or the Monitor Interface, and is used to idle the controller so that error injections can be performed. This command causes the controller to transition to the idle state.

The "status report" command is not frequently used; it provides some diagnostic information, and can be helpful as a mechanism to "ping" the controller without idling it. This command is only supported on the Monitor Interface.

In the event an error is detected, the controller reads additional information from the hardware in preparation for a correction attempt. After the controller has gathered the available information, it transitions to the correction state.

#### Correction

The controller attempts to correct errors in the correction state. The controller always passes through the correction state, even if correction is disabled. During the correction state, status\_correction is TRUE.

If the error is a CRC-only error, the controller sets status\_uncorrectable and generates a report on the Monitor Interface. It then transitions to the classification state. If the error is not a CRC-only error, then the behavior of the controller depends on how it has been configured to correct errors.

If the controller is configured for correction by replace, it generates a replacement data request on the Fetch Interface. In the system-level design example, the EXT shim translates this request into a read of the external memory. The return data is provided to the controller by the EXT shim. The controller then performs active partial reconfiguration to re-write the frame with the correct contents. The controller clears <code>status\_uncorrectable</code> and generates a report on the Monitor Interface. It then transitions to the classification state.

If the controller is configured for correction by repair or correction by enhanced repair, it attempts to correct the error using algorithmic methods. If the error is correctable, the controller performs active partial reconfiguration to re-write the frame with the corrected contents and clears status\_uncorrectable. Otherwise, the controller sets status\_uncorrectable. In either case, the controller generates a report and then transitions to the classification state.

#### Classification

The controller classifies errors in the classification state. The controller always passes through the classification state, even if classification is disabled. During the classification state, status\_classification is TRUE.

All errors signaled as uncorrectable during the correction state are signaled as essential. The only reason an error can be uncorrectable is because it cannot be located. And, if this is the case, the controller cannot look up the error to determine whether it is essential. In these cases, the controller sets status\_essential, generates a report, and then transitions to the idle state. After an uncorrectable error is encountered, the controller does not continue looking for errors. At this point, the FPGA must be reconfigured.

The treatment of errors signaled as correctable during the correction state depends on the controller option setting. If error classification is disabled, all correctable errors are unconditionally signaled as essential. If error classification is enabled, the controller generates a classification data request on the Fetch Interface. In the system-level design example, the EXT shim translates this request into a read of the external memory. The return data is provided to the controller by the EXT shim. With this data, the controller then determines whether it is essential. In all cases, the controller generates a report, changes status\_essential as appropriate, and then transitions to the observation state to resume looking for errors.

#### Idle

The idle state is similar to the observation state, except that the controller does not observe the FPGA configuration system for indication of error conditions. The idle state is indicated by the de-assertion of all five state bits on the Status Interface. If the controller receives a command (from either the Error Injection Interface or the Monitor Interface), then the controller processes the received command. The error injection commands are only supported in the idle state.

The "enter observation" command can be applied through either the Error Injection Interface or the Monitor Interface, and is used to return the controller to the observation state so that errors can be detected.

The "status report" command is not frequently used; it provides some diagnostic information, and can be helpful as a mechanism to "ping" the controller. This command is only supported on the Monitor Interface.

Any desired set of "error injection" commands can be applied through either the Error Injection Interface or the Monitor Interface. These commands direct the controller to perform error injections. The primary reason the idle state exists is to halt actions taken in response to error detections so that multi-bit errors can be constructed.

#### Injection

The controller performs error injections in the injection state. The controller always passes through the injection state in response to a valid error injection command issued from the idle state, even if error injection is disabled; this can occur if error injection commands are presented on the Monitor Interface, as the Monitor Interface exists even when error injection is disabled. During the injection state, status\_injection is TRUE.

The error injection process is a simple read-modify-write to invert one configuration memory bit at an address specified as part of the error injection command.

The controller always transitions from the injection state back to the idle state. Multi-bit errors can be constructed by repeated error injections commands, each resulting in a transition through the injection state. At the end of error injection, the controller must be moved from the idle state back into the observation state.

#### **Fatal Error**

The controller enters the fatal error state when it detects an internal inconsistency. Although very unlikely, it is possible for the controller to halt due to soft errors that affect the controller-related configuration memory or the controller design state elements.

The fatal error state is indicated by the assertion of all five state bits on the Status Interface, along with a fatal error report message. This condition is non-recoverable, and the FPGA must be reconfigured.

## **Error Injection Interface Commands**

The Error Injection Interface commands define what a user can send to the controller through the Error Injection Interface. This command set offers basic capability to inject errors.

Commands are presented by applying a value to the inject\_address bus, and then asserting the inject\_strobe signal. After a command is presented, do not present another command until the Status Interface or Monitor Interface has confirmed completion of the previous command.

#### **Directed State Changes**

The controller can be moved between observation and idle states by a directed state change. The command format is shown in Figure 3-15 through Figure 3-18, with "X" representing a "don't care."

| 3<br>9 | 3<br>8                                                | 3<br>7 | 33<br>65   | 3<br>4 | 3<br>3 | 3<br>2 | 3<br>1    | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | _      | 2<br>4 | -      | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9      | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |
|--------|-------------------------------------------------------|--------|------------|--------|--------|--------|-----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|-----|-----|-----|
| 1      | 1                                                     | 1      | 0 X        | X      | Х      | Х      | Х         | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х | Х | Х | Х | Х | X | Х   | Х   | Х   |
|        | Figure 3-15: 7 Series Enter Idle                      |        |            |        |        |        |           |        |        |        |        |        |        |        | le S   | Sta    | te     | Со     | mn     | na     | nd     |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
|        |                                                       |        |            |        |        |        |           |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
| С      | c                                                     | c      | <b> </b>   | c      | С      | С      | С         | С      | r      | r      | r      | r      | r      | r      | r      | r      | r      | r      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 9      | 0 | 7 | c | F | 4 | c | 2   | 1   | 0   |
| 5<br>9 | 5<br>8                                                | 5<br>7 | 5 5<br>6 5 | 4      | 3      | 2      | 5<br>1    | 0      | 2      | 2      | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2      | 2      | 2      | 9      | 8      | 1<br>7 | 6      | 1<br>5 | 4      | т<br>З | 2      | 1      | 0      | 9      | 0 | / | 0 | Э | 4 | З | Z   | Т   | 0   |
| 1      | 0                                                     | 1      | 0 X        | X      | Х      | Х      | Х         | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х      | Х | Х | Х | Х | Х | Х | Х   | Х   | Х   |
|        | Figure 3-16: 7 Series Enter Observation State Command |        |            |        |        |        |           |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
|        |                                                       |        |            |        |        |        |           |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
| -      | _                                                     | _      | _          | _      | _      | _      |           | _      | _      | _      | _      | -      |        | _      | _      | _      | -      | _      |        |        | _      |        |        |        | _      |        | _      | _      | _      | - | - | _ | _ | _ |   | _   |     |     |
| 3      | 3                                                     | 3      | 3          |        | 3<br>0 |        | 2         | 2<br>3 | 2<br>7 | 2<br>6 | 2<br>5 | 2      | 2      | 2<br>3 | 2<br>2 | 2<br>1 | 2      | 1<br>9 | 1<br>8 | 3      | 1<br>7 | 1<br>6 | 1<br>5 |        | 1      |        |        | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 2 1 | . 0 |
| 1      |                                                       | -      | 0          |        | -      | -      |           |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        | Х      | Х      | Х | Х | Х | Х | Х | X | X   | XX  | X   |
|        |                                                       |        |            |        |        |        |           |        |        |        |        |        |        |        |        |        |        | d S    |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
|        |                                                       |        |            |        |        |        |           |        | -      |        |        |        |        |        |        |        |        |        | -      |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
|        |                                                       |        |            |        |        |        |           |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |     |     |     |
| 3<br>5 | 3                                                     | 3      | 3<br>2     | 3      | 3      | 2      | 2         | 2      | 2<br>7 | 2<br>6 | 2<br>5 | 2      | 2      |        | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1      | -      | 1      | 1<br>6 | 1      | 1<br>4 | 1      | -      | 1<br>2 | 1      | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1 0 |
| 5      |                                                       |        | 2          |        | -      | -      | -         | _      |        | -      | -      | -      | -      |        | -      | -      | Ŭ      |        | -      |        | -      | -      | -      | -      |        |        | _      | T      | Ŭ      | V | V | V | V | V | V | V   | V   | v v |
|        | 0                                                     | 1      | U          | X      | Х      |        | ,<br>Tiai |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   | X | X   | X   | ХХ  |

*Figure 3-18:* Virtex-6 and Spartan-6 Enter Observation State Command

Completion of the command is indicated on the Status Interface by a change in the state outputs indicating the controller has entered the requested state. Completion of the command is indicated on the Monitor Interface by a change in the command prompt indicating the controller has entered the requested state.

### **Error Injection**

There are two addressing schemes to specify the frame address for an error injection. These are linear frame addressing and physical frame addressing. Linear frame addressing is simple, but the addresses do not provide information about type and physical location of the frame. The error injection command formats for linear frame address are shown in Figure 3-19 through Figure 3-21, with borders marking nibble boundaries and shading marking separate bit fields in the command.

 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 2
 2
 2
 2
 2
 2
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1

#### Figure 3-19: 7 Series Error Injection Command (Linear Frame Address)

Where:

- SS = Hardware SLR number for SSI (2-bit) and set to 00 for non-SSI
- LLLLLLLLLLLLL = linear frame address (17-bit)
- WWWWWWW = word address (7-bit)
- BBBBB = bit address (5-bit)

| 3 | 3 | 3 | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | L | L | L | L | L | L | L | L | L | L | L | L | L | L | L | L | L | W | W | W | W | W | W | W | В | В | В | В | В |

Figure 3-20: Virtex-6 Error Injection Command (Linear Frame Address)

#### Where:

- LLLLLLLLLLLLL = linear frame address (17-bit)
- WWWWWWW = word address (7-bit)
- BBBBB = bit address (5-bit)

| - | - | 3<br>3 | - | - | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|--------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | 1 | 0      | 0 | 0 | 0 | 0 | 0 | 0 | L | L | L | L | L | L | L | L | L | L | L | L | L | L | L | W | W | W | W | W | W | W | 0 | В | В | В | В |

#### Figure 3-21: Spartan-6 Error Injection Command (Linear Frame Address)

#### Where:

- LLLLLLLLLLLL = linear frame address (15-bit)
- WWWWWWW = word address (7-bit)

• BBBB = bit address (4-bit)

An error injection command using physical frame address has the form shown in Figure 3-22 through Figure 3-24.

 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 3
 2
 2
 2
 2
 2
 2
 2
 2
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1

Where:

- SS = Hardware SLR number for SSI (2-bit) and set to 00 for non-SSI
- TT = block type (2-bit)
- H = half address (1-bit)
- RRRRR = row address (5-bit)
- CCCCCCCCC = column address (10-bit)
- MMMMMMM = minor address (7-bit)
- WWWWWWW = word address (7-bit)
- BBBBB = bit address (5-bit)

| - | 3<br>4 | - | - | - | - | _ | _   | _   | _   | _  | _ | _    | _    | _    | _   | -    | _   | _   | _   | _  | _   | _   | _  | _   | -    | 9    | 8   | 7    | 6   | 5   | 4   | 3 | 2 | 1 | 0 |
|---|--------|---|---|---|---|---|-----|-----|-----|----|---|------|------|------|-----|------|-----|-----|-----|----|-----|-----|----|-----|------|------|-----|------|-----|-----|-----|---|---|---|---|
| 0 | Т      | Т | Η | R | R |   |     |     | _   |    |   |      |      |      |     |      |     |     |     |    |     |     |    |     |      |      |     |      |     |     |     |   | В | В | В |
|   |        |   |   |   |   | F | igu | ire | 3-2 | 3: | V | irte | ex-6 | 5 Er | roi | r In | jec | tio | n C | om | nma | and | (P | hvs | sica | n Fi | ran | 1e / | Ado | dre | SS) |   |   |   |   |

Where:

- TT = block type (2-bit)
- H = half address (1-bit)
- RRRRR = row address (5-bit)
- CCCCCCCC = column address (8-bit)
- MMMMMMM = minor address (7-bit)
- WWWWWWW = word address (7-bit)
- BBBBB = bit address (5-bit)

|   | 3 | 3 | 3 | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|   | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |   |   |   |   |   |
| Ī | 0 | 0 | R | R | R | R | М | М | М | М | М | М | М | М | 0 | 0 | m | m | m | m | m | m | m | m | W | W | W | W | W | W | W | 0 | В | В | В | В |

#### Figure 3-24: Spartan-6 Error Injection Command (Physical Frame Address)

Where:

- RRRR = row address (4-bit)
- MMMMMMMM = major address (8-bit)
- mmmmmmmm = minor address (8-bit)
- WWWWWWW = word address (7-bit)
- BBBB = bit address (4-bit)

Completion of the command is indicated on the Status Interface by the de-assertion of the status\_injection output indicating the controller has exited the error injection state. Completion of the command is indicated on the Monitor Interface by a return of the command prompt indicating the controller has exited the error injection state.

### **Monitor Interface Commands**

The Monitor Interface commands define what a user can send to the controller through the Monitor Interface. This command set is intended to offer a superset of the "command capability" available from the Error Injection Interface.

### **Directed State Changes**

The controller can be moved between observation and idle states by a directed state change. "I" command is used to enter idle state. "O" command is used to enter observation state.

### **Status Report**

"S" command is used to request a status report from the controller. The status report format is detailed in the next section which describes status messages generated by the controller. The controller accepts this command when in idle or observation states.

### **Error Injection**

"N" command is used to perform an error injection. The controller only accepts this command when in the idle state. The format of the command is:

N {9-digit hex value} Virtex-6 and Spartan-6
N {10-digit hex value} 7 Series

Issuing this command is analogous to presenting an error injection command on the Error Injection Interface. The hex value supplied with this command represents the same value that would be applied to the Error Injection Interface.

### **Monitor Interface Messages**

The Monitor Interface messages define what messages a user can expect from the controller through the Monitor Interface. This message set is intended to offer a superset of the "reporting" available from the Status Interface.

### **Initialization Report**

As the controller performs the initialization sequence, it generates the initialization report. This report contains diagnostic information. This report is generated only once when the controller first starts. The 7 series device initialization report looks like this:

| X7_SEM_V3_4            | Name and Version               |
|------------------------|--------------------------------|
| SC 01                  | State Change, Initialization   |
| FS {2-digit hex value} | Core Configuration Information |
| ICAP OK                | Status: ICAP Available         |
| RDBK OK                | Status: Readback Active        |
| INIT OK                | Status: Completed Setup        |
| SC 02                  | State Change, Observation      |

The Virtex-6 and Spartan-6 device initialization reports are virtually identical except the controller reports its name and version as V6\_SEM\_V3\_4 and S6\_SEM\_V3\_4, respectively.

### **Command Prompt**

The command prompt issued by the controller is one of two characters, depending on the controller state. If the controller is in observation state (the default state after initialization completes) the prompt issued is O>. If the controller is in idle state, the prompt issued is I>.

### State Change Report

Any time the controller changes state, the controller also issues a state change report. The report is a single line with the following format:

SC {2-digit hex value}

The 2-digit hex value is the representation of the Status Interface outputs.

Table 3-2: State Change Report Decoding

| Report String | State Name     |
|---------------|----------------|
| SC 00         | Idle           |
| SC 01         | Initialization |
| SC 02         | Observation    |
| SC 04         | Correction     |
| SC 08         | Classification |

| Report String | State Name  |
|---------------|-------------|
| SC 10         | Injection   |
| SC 1F         | Fatal Error |

Table 3-2: State Change Report Decoding

Entry into the fatal error state can occur at anytime, even without an explicit state change report. Upon entering this state, the controller issues the following fatal error message:

HALT

#### **Flag Change Report**

Any time the controller changes flags, the controller also issues a flag change report. The report is a single line with the following format:

FC {2-digit hex value}

The 2-digit hex value is the representation of the Status Interface outputs.

Table 3-3: Flag Change Report Decoding

| Report String | Condition Name               |
|---------------|------------------------------|
| FC 00         | Correctable, Non-Essential   |
| FC 20         | Uncorrectable, Non-Essential |
| FC 40         | Correctable, Essential       |
| FC 60         | Uncorrectable, Essential     |

#### **Status Report**

A status report provides more information about the controller state. It is a multiple-line report that is generated in response to the *S* command, provided the controller is in the observation or idle states. The 7 series non-SSI device status report has the following format:

| MF | {8-digit | hex | value} | Maximum Frame (linear count) |
|----|----------|-----|--------|------------------------------|
| SN | {2-digit | hex | value} | Hardware SLR Number          |
| SC | {2-digit | hex | value} | Current State                |
| FC | {2-digit | hex | value} | Current Flags                |
| FS | {2-digit | hex | value} | Feature Set                  |

The 7 series SSI device status report is similar to the non-SSI device status report, but with a sub-report per SLR. The sub-reports are sorted by hardware SLR number. For example, a device with four SLRs generates a report in this format:

MF {8-digit hex value} Maximum Frame (linear count)
SN {2-digit hex value} Hardware SLR Number
SC {2-digit hex value} Current State for this Hardware SLR
FC {2-digit hex value} Current Flags for this Hardware SLR
FS {2-digit hex value} Feature Set

MF {8-digit hex value} Maximum Frame (linear count) SN {2-digit hex value} Hardware SLR Number SC {2-digit hex value} Current State for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FS {2-digit hex value} Feature Set MF {8-digit hex value} Maximum Frame (linear count) SN {2-digit hex value} Hardware SLR Number SC {2-digit hex value} Current State for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FS {2-digit hex value} Feature Set MF {8-digit hex value} Maximum Frame (linear count) SN {2-digit hex value} Hardware SLR Number SC {2-digit hex value} Hardware SLR Number SC {2-digit hex value} Current State for this Hardware SLR FC {2-digit hex value} Current State for this Hardware SLR FC {2-digit hex value} Current State for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FC {2-digit hex value} Current Flags for this Hardware SLR FS {2-digit hex value} Feature Set

The Virtex-6 and Spartan-6 device status reports are virtually identical to the 7 series non-SSI device status report except that the Maximum Frame is reported as a 6-digit hex value and the SLR Number is not reported.

In addition, the Spartan-6 device status report includes the Starting Frame address (linear count). This information is only relevant to Spartan-6 devices because the controller may be configured so that the device scan does not start at 0. The Virtex-6 device status report has the following format:

```
MF {6-digit hex value} Maximum Frame (linear count)
SC {2-digit hex value} Current State
FC {2-digit hex value} Current Flags
FS {2-digit hex value} Feature Set
```

The Spartan-6 device status report has the following format:

SF {6-digit hex value} Starting Frame (linear count)
MF {6-digit hex value} Maximum Frame (linear count)
SC {2-digit hex value} Current State
FC {2-digit hex value} Current Flags
FS {2-digit hex value} Feature Set

### **Error Detection Report**

Upon detection of an error condition, the controller corrects the error as quickly as possible. Therefore, the report information is actually generated after the correction has taken place, assuming it is possible to correct the error. The following scenarios exist:

Diagnosis: CRC error only [cannot identify location or number of bits in error]

SC 04 CRC

Diagnosis: Enhanced repair checksum buffer uncorrectable error

SC 04 BFR

Diagnosis: 1-bit ECC error, SYNDROME is valid. Controller reports physical frame address, linear frame address, word in frame, and bit in word.

```
SC 04
SED OK
PA {8-digit hex value}
LA {8-digit hex value}
WD {2-digit hex value} BT {2-digit hex value}
```

Diagnosis: 1-bit ECC error, SYNDROME is invalid. Controller reports physical frame address and linear frame address.

SC 04 SED NG PA {8-digit hex value} LA {8-digit hex value}

Diagnosis: 2-bit ECC error. Controller reports physical frame address and linear frame address.

SC 04 DED PA {8-digit hex value} LA {8-digit hex value}

The Virtex-6 and Spartan-6 device error detection reports are virtually identical except that frame addresses are reported as 6-digit hex values.

### **Error Correction Report**

The error correction process varies depending on the controller configuration and the nature of what has been detected and what can be corrected.

The general form of the report for an uncorrectable error, or when correction is disabled is:

COR END

Followed by:

FC 20 Bit 5, uncorrectable set (stale essential flag)

or

FC 60 Bit 5, uncorrectable set (stale essential flag)

The general form of the report for a correctable error is:

COR {correction list} END

Followed by:

FC 00 Bit 5, uncorrectable cleared (stale essential flag)

or

FC 40 Bit 5, uncorrectable cleared (stale essential flag)

The {correction list} is one or more lines providing the word in frame and bit in word of each corrected bit. The list can potentially be thousands of lines. This is the same notation used for the error detection report. Each line of the list is formatted as follows:

WD {2-digit hex value} BT {2-digit hex value}

#### **Error Classification Report**

The error classification process involves looking up each of the errors in a frame to determine if any of them are essential. If one or more are identified as essential, the entire event is considered essential.

With error classification enabled, the general form of the report for a correctable, non-essential event is:

SC 08 CLA END FC 00 Bit 6, essential is cleared

With error classification enabled, the general form of the report for a correctable, essential event is:

```
SC 08
CLA
{classification list}
END
FC 40 Bit 6, essential is set
```

The {classification list} is one or more lines providing the word in frame and bit in word of each essential bit. The list can potentially be thousands of lines. This is the same notation used for the error detection report. Each line of the list is formatted as follows:

WD {2-digit hex value} BT {2-digit hex value}

With error classification disabled, no detailed classification list is generated. All errors must be considered essential because the controller has no basis to indicate otherwise. The general form of the report for a correctable event is:

SC08 FC40 Bit 6, essential is set

All uncorrectable errors must be considered essential because the controller has no basis to indicate otherwise. The general form of the report for an uncorrectable event is:

SC 08 FC 60 Bit 6, essential is set

# Systems

Although the soft error mitigation solution can operate autonomously, most applications use the solution in conjunction with an application-level supervisory function. This supervisory function monitors the event reporting and determines if additional actions are necessary (for example, reconfigure the device or reboot the application). The nature of application-level supervisory functions varies from design to design.

As noted previously, there is a small, yet finite possibility that the soft error mitigation solution is disrupted by a soft error. The solution has indicators of general health that the application-level supervisory function can elect to monitor.

- The controller heartbeat, status\_heartbeat: This signal is a direct output from the soft error mitigation solution. This signal exhibits pulses which indicate the FPGA configuration system readback process is active. If, during the observation state, these pulses cease for no apparent reason, the application-level supervisory function should conclude that the FPGA configuration system readback process has experienced a fault. This is an uncorrectable, essential error. In SSI implementations, which have a status\_heartbeat output per SLR, it is necessary to monitor the heartbeat from all SLRs.
- The hardware CRC failure indicator, INIT\_B (7 series and Virtex-6 devices only): This signal is a direct output from the hardware readback process. If the readback process detects a hardware CRC failure, it asserts INIT\_B. A transient assertion of INIT\_B is expected during FPGA configuration and the controller initialization process, after error injections, and in some cases when soft error events occur. If, during observation state, INIT\_B indicates an error and the controller does not transition into correction state after the expected duration of a complete readback cycle, the application-level supervisory function should conclude the controller has experienced a fault. This is an uncorrectable, essential error. In SSI implementations, which have a hardware CRC failure indicator per SLR, the indicators are wire-ORed to form the single INIT\_B device pin.

The recommended interface between the soft error mitigation solution and the application-level supervisory function for normal communication is the serial interface supported by the MON shim. Using the MON shim introduces a small amount of logic, but drastically reduces the number of I/O required. As a result, the MON shim offers higher reliability than using the direct logic signal based interfaces.

# **Customizations**

The system-level design example encapsulates the controller and various shims that serve to interface the controller to other devices. These shims can include I/O Pins, ChipScope, I/O Interfaces, Memory Controllers, or application-specific system management interfaces.

As delivered, the system-level design example is not a reference design, but an integral part of the total solution and fully verified by Xilinx. While designers do have the flexibility to modify the system-level design example, the recommended approach is to use it as delivered. However, if modifications are desired, this chapter provides additional detail required for success.

This chapter does not describe customization of the user application that exists in the system-level design example. This portion of the system-level design example is for demonstration purposes only and not functionally involved in soft error mitigation. The only anticipated customization of the user application is to remove it.

# **HID Shim Customizations**

The HID shim is a bridge between the controller and an interface device. The resulting interface can be used to exchange commands and status with the controller. The HID shim is only present in certain controller configurations. When present, it exports access to the Status Interface and Error Injection Interface through the use of ChipScope analyzer. When absent, the Status Interface and Error Injection Interface are only accessible through I/O pins.

If desired, the Status Interface and Error Injection Interface can be connected in other ways. These interfaces are easy to disconnect from the HID shim or I/O Pins and reconnect to other logic, such as register files or finite state machines. See the Status Interface, page 43 and Error Injection Interface, page 65.

# **MON Shim Customizations**

The MON shim is a bridge between the controller and a standard RS-232 port. The resulting interface can be used to exchange commands and status with the controller. This interface is designed for connection to processors.

### **Increase Bit Rate**

If the RS-232 interface is needed, changing to the highest feasible bit rate is strongly encouraged. This reduces the potential for throttling of the controller due to status report transmission. See Monitor Interface, page 45 for more information.

### **Increase Buffer Depth**

Increasing the MON shim bit rate is the easiest method to reduce the potential for throttling of the controller due to status report transmission. Another method is to increase the buffer depth. The MON shim contains two FIFOs, a transmit buffer and a receive buffer.

There is no need for the buffer depths to be symmetric and little advantage is gained from increasing the depth of the receive buffer. However, increasing the depth of the transmit buffer reduces the potential for throttling of the controller due to status report transmission.

The Xilinx LogiCORE IP FIFO Generator can be used to create replacements for the MON shim FIFOs. The FIFO configuration must be for a common clock (that is, fully synchronous to a single clock) with first word fall through enabled. The data width must be eight, with the depth as great as desired.

**TIP:** When making a FIFO replacement, note that an "empty" flag is the logical inverse of a "data present" flag.

### **Replace with Alternate Function (Non-SSI Devices)**

If an interface other than RS-232 is desired, the MON shim can be replaced with an alternate function. For example, the MON shim could be replaced with a custom processor interface or other scheme for inter-process communication. When replacing the MON shim with an alternate function, it becomes critical to understand the behavior of the controller monitor interface.

For an overview of the signals, see Monitor Interface, page 45. The data exchanged over this interface is ASCII. For a summary of the status and command formats, see Monitor Interface Commands, page 75 and Monitor Interface Messages, page 76.

Figure 3-25 illustrates the protocol used on the transmit portion of the Monitor Interface. When the controller wants to transmit a byte of data, it first samples the monitor\_txfull signal to determine if the transmit buffer is capable of accepting a byte of data. Provided that monitor\_txfull is low, the controller transmits the byte of data by applying the data to monitor\_txdata[7:0] and asserting monitor\_txwrite for a single clock cycle.



Figure 3-25: Monitor Interface Transmit Protocol

The controller can perform burst writes by applying a data sequence to monitor\_txdata[7:0] and asserting monitor\_txwrite for multiple cycles. However, the controller observes monitor\_txfull so that it never over-runs the transmit buffer.

It is the responsibility of the peripheral receiving the data to correctly track its buffer availability and report it through monitor\_txfull. In the cycle after the peripheral samples monitor\_txwrite high, it must assert monitor\_txfull if the data written completely fills the buffer.

Further, the peripheral must only assert monitor\_txfull in response to monitor\_txwrite from the controller. Under no circumstances can the peripheral assert monitor\_txfull based on events internal to the peripheral. This requirement exists because the controller can sample monitor\_txfull several cycles in advance of performing a write.

While monitor\_txfull is asserted by the peripheral, the controller stalls if it is waiting to transmit additional data. This can have negative side effects on the error mitigation performance of the controller. For example, if a correction takes place, the controller successfully corrects (or handles) the error and then send a status report. If the entire message cannot be accepted by the peripheral, the controller will stall, preventing it from returning to the observation state. Therefore, a custom peripheral must have an adequate balance of buffer depth and data consumption rate.

Figure 3-26 illustrates the protocol used on the receive portion of the monitor interface. When the controller wants to receive a byte of data, it first samples the monitor\_rxempty signal to determine if the receive buffer is providing a byte of data. Provided that monitor\_rxempty is low, the controller receives the byte of data from monitor\_rxdata[7:0] and acknowledges reception by asserting monitor\_rxread for a single clock cycle.



Figure 3-26: Monitor Interface Receive Protocol

The controller can perform burst reads by obtaining a data sequence from monitor\_rxdata[7:0] and asserting monitor\_rxread for multiple cycles. However, the controller observes monitor\_rxempty so that it never under-runs the receive buffer.

It is the responsibility of the peripheral providing the data to correctly track its buffer status and report it through monitor\_rxempty. In the cycle after the peripheral samples monitor\_rxread high, it must assert monitor\_rxempty if the data written completely fills the buffer.

Further, the peripheral must only assert monitor\_rxempty in response to monitor\_rxread from the controller. Under no circumstances can the peripheral assert monitor\_rxempty based on events internal to the peripheral. This requirement exists because the controller can sample monitor\_rxempty several cycles in advance of performing a read.

During the initialization state, the controller purges the receive buffer by reading and discarding data until it is empty. The controller assumes the transmit buffer is ready immediately and does not wait for the transmit buffer to empty, as it has no way to observe this condition.

### **Replace with Alternate Function (SSI Devices)**

The MON shim delivered with the system-level example design for implementation in SSI devices implements additional functions such as arbitration and report collation for multiple controller instances.

Xilinx strongly discourages replacing the MON shim in SSI devices.

### Removal

Although it is possible to remove the MON shim, Xilinx strongly discourages this customization. If removing the MON shim, Xilinx recommends preserving the two I/O pins used by the MON shim and making those accessible for probing at test points. Even though the MON shim may not be necessary in certain applications, it offers a critical debugging capability that is required when obtaining assistance from Xilinx technical support teams.

To eliminate the MON shim, disconnect and remove it, including any related signals and ports used to bring the RS-232 signals to I/O pins at the design top level. Then, address the exposed monitor interface on controllers:

- Leave all controller monitor interface outputs "open" or "unconnected."
- Connect all monitor\_txfull inputs to logic zero.
- Connect all monitor\_rxempty inputs to logic one.
- Connect all monitor\_rxdata[7:0] inputs to logic zero.

Elimination of the MON shim reduces the size of the solution and also prevents throttling of the controller due to status report transmission.

### **EXT Shim Customizations**

The EXT shim is a bridge between the controller and a standard SPI bus. The resulting interface can be used to fetch data by the controller. This shim is only present in certain controller configurations and is designed for connection to standard SPI Flash.

### **Replace with Alternate Function (Non-SSI Devices)**

If an interface other than SPI bus is needed, the EXT shim can be replaced with an alternate function. For example, the EXT shim could be replaced with a parallel flash memory controller or other scheme for inter-process communication. When replacing the EXT shim with an alternate function, it becomes critical to understand the behavior of the Controller Fetch Interface.

For an overview of the signals, Fetch Interface in Chapter 2. The byte transfer protocols for the Fetch Interface are identical to those of the Monitor Interface.

Figure 3-27 illustrates the protocol used on the transmit portion of the Fetch Interface. When the controller wants to transmit a byte of data, it first samples the fetch\_txfull signal to determine if the transmit buffer is capable of accepting a byte of data. Provided that fetch\_txfull is low, the controller transmits the byte of data by applying the data to fetch\_txdata[7:0] and asserting fetch\_txwrite for a single clock cycle.



Figure 3-27: Fetch Interface Transmit Protocol

The controller can perform burst writes by applying a data sequence to fetch\_txdata[7:0] and asserting fetch\_txwrite for multiple cycles. However, the controller observes fetch\_txfull so that it never over-runs the transmit buffer.

It is the responsibility of the peripheral receiving the data to correctly track its buffer availability and report it through fetch\_txfull. In the cycle after the peripheral samples fetch\_txwrite high, it must assert fetch\_txfull if the data written completely fills the buffer.

Further, the peripheral must only assert fetch\_txfull in response to fetch\_txwrite from the controller. Under no circumstances can the peripheral assert fetch\_txfull based on events internal to the peripheral. This requirement exists because the controller can sample fetch\_txfull several cycles in advance of performing a write.

While fetch\_txfull is asserted by the peripheral, the controller stalls if it is waiting to transmit additional data. This can have negative side effects on the error mitigation performance of the controller.

Figure 3-28 illustrates the protocol used on the receive portion of the fetch interface. When the controller wants to receive a byte of data, it first samples the fetch\_rxempty signal to determine if the receive buffer is providing a byte of data. Provided that fetch\_rxempty

is low, the controller receives the byte of data from fetch\_rxdata[7:0] and acknowledges reception by asserting fetch\_rxread for a single clock cycle.





The controller can perform burst reads by obtaining a data sequence from fetch\_rxdata[7:0] and asserting fetch\_rxread for multiple cycles. However, the controller observes fetch\_rxempty so that it never under-runs the receive buffer.

It is the responsibility of the peripheral providing the data to correctly track its buffer status and report it through fetch\_rxempty. In the cycle after the peripheral samples fetch\_rxread high, it must assert fetch\_rxempty if the data written completely fills the buffer.

Further, the peripheral must only assert fetch\_rxempty in response to fetch\_rxread from the controller. Under no circumstances can the peripheral assert fetch\_rxempty based on events internal to the peripheral. This requirement exists because the controller can sample fetch\_rxempty several cycles in advance of performing a read.

During the initialization state, the controller purges the receive buffer by reading and discarding data until it is empty. It then performs two more reads. Reads with an empty buffer condition are decoded as a reset signal. The controller assumes the reset signal initializes the transmit buffer and therefore does not wait for the transmit buffer to empty, as it has no way to observe this condition.

The data exchanged is binary and represents a command-response pair. The controller transmits a 6-byte command sequence to initiate a data fetch. The command sequence is:

- Byte 1: ADD[31:24]
- Byte 2: ADD[23:16]
- Byte 3: ADD[15:8]
- Byte 4: ADD[7:0]
- Byte 5: LEN[15:8]
- Byte 6: LEN[7:0]

In response, the peripheral must fetch LEN[15:0] bytes of data starting from address ADD[31:0], and return this data to the controller. After the controller has issued a command, the peripheral must fulfill the command with the exact number of requested bytes. For additional information about the organization of the data in the address space, see External Memory Programming File in Chapter 9.

#### **Replace with Alternate Function (SSI Devices)**

The EXT shim delivered with the system-level example design for implementation in SSI devices is complex, as it implements additional functions such as arbitration for multiple controller instances. Xilinx strongly discourages replacing the EXT shim in SSI devices.

# **Data Consistency**

When using optional features such as error correction by replacement and error classification, the controller requires access to externally stored data. This data is created by bitgen at the same time the programming file for the FPGA is created. The files are related.

Any time the FPGA design is changed and a new programming file is created, the additional data files used by the controller must also be updated. When the hardware design is updated with the new programming file, the externally stored data must also be updated.



**IMPORTANT:** Failure to maintain data consistency can result in unpredictable controller behavior. Xilinx recommends use of an update methodology which ensures that the programming file and the additional data files are always synchronized.

# **Configuration Memory Masking**

By design, certain configuration memory bits can change value during design operation. This is frequently the case where logic slice resources are configured to implement LUTRAM functions such as Distributed RAM or Shift Registers. It also occurs when other resource types with Dynamic Reconfiguration Ports are updated during design operation.

The memory bits associated with these resources must be masked so that they are excluded from CRC and ECC calculations to prevent false error detections. Xilinx FPGA devices implement configuration memory masking to prevent these false error detections. A global control signal, GLUTMASK, selects if masking is enabled or disabled. The controller always enables masking.

# 7 Series FPGAs

7 series FPGAs implement fine grain masking at a resource level. This means individual resources, when configured for dynamic operation, have their configuration memory bits masked. Only the required memory bits are masked, without impacting unrelated memory bits. The masked bits are no longer monitored by the controller.

Configuration memory reads of bits associated with masked resources return constant values (either logic one or logic zero). This prevents false error detections. Configuration memory writes to bits associated with masked resources are discarded. This prevents over-writing the contents of dynamic state elements with stale data. A side effect is that error injections into masked resources do not result in error detections.

In many cases (for example, LUTRAM functions) it is possible for the user design to implement data protection on these bits for purposes of soft error mitigation. Another approach is to modify the user design to eliminate the use of features that introduce configuration memory masking.

# Virtex-6 FPGAs

Virtex-6 FPGAs implement fine grain masking at a resource level. This means individual resources, when configured for dynamic operation, have their configuration memory bits masked. Only the required memory bits are masked, without impacting unrelated memory bits. The masked bits are no longer monitored by the controller.

Configuration memory reads of bits associated with masked resources return constant values (either logic one or logic zero). This prevents false error detections. Configuration memory writes to bits associated with masked resources are discarded. This prevents over-writing the contents of dynamic state elements with stale data. A side effect is that error injections into masked resources do not result in error detections.

In many cases (for example, LUTRAM functions) it is possible for the user design to implement data protection on these bits for purposes of soft error mitigation. Another approach is to modify the user design to eliminate the use of features that introduce configuration memory masking.

### Spartan-6 FPGAs

Spartan-6 FPGAs implement coarse grain masking at a frame level. This means individual resources, when configured for dynamic operation, result in one or more frames of configuration memory being masked. The masked bits are no longer monitored by the controller.

This over-masking can compromise error detection and error injection capability of the controller. The easiest way to avoid over-masking is to reduce the use of functions that involve dynamic memory bits. However, complete elimination may not be possible, and it can be undesirable because it prohibits use of powerful Spartan-6 FPGA features.

Generally, a better approach is to understand the masking rules and then apply placement constraints to cluster resources that involve dynamic memory bits into the same configuration memory frames. A CRC Coverage report can be generated from BitGen that provides details of masked and overmasked resource placement. This report assists in creating placement constraints to increase coverage. Contact Xilinx for more information regarding this BitGen feature. See *Spartan-6 FPGA Configuration User Guide* (UG380) [Ref 4], for additional information regarding the masking rules.

Configuration memory reads of bits associated with masked resources return constant values (either logic one or logic zero). This prevents false error detections. Configuration memory writes to bits associated with masked resources overwrite the contents of dynamic state elements. A side effect is that error injections into masked resources do not result in error detections, although the memory contents have changed.

In many cases (for example, LUTRAM functions) it is possible for the user design to implement data protection on these bits for purposes of soft error mitigation. Another approach is to modify the user design to eliminate the use of features that introduce configuration memory masking.

# Clocking

The master clock is absolutely critical to the controller and therefore needs to be provided from the most reliable source possible. To achieve the very highest reliability, the clock must be connected as directly as possible to the controller. This means the use of an external oscillator of the desired frequency, connected directly to a pin associated directly with a global clock buffer.

The inclusion of any additional logic or interconnect into the clock path results in additional configuration memory being used to control the connection of the clock to the controller. This additional memory has a negative effect on the estimated controller FIT. Although the impact is small, it is best to strive for high reliability unless it poses a significant burden.

When additional logic exists on the clock path (for example, clock management blocks, or logic-based clock division) care must be taken to guarantee by design that the maximum clock frequency the FPGA configuration system and the maximum clock frequency of the system-level design example and controller are not transiently violated. For example, the clock output of a DLL or PLL may be "out of specification" while those functions lock. One method of handling this is to use a global clock buffer with enable. Only enable the global clock buffer after lock is achieved.

The system-level design example, the controller, and the configuration system are all static. This means, any clock frequency can be used up to the specified maximum allowed by the FPGA configuration system or the maximum clock frequency of the system-level design example and controller (whichever is lower). However, higher clock rates result in faster mitigation of errors, which is desirable.

# Resets

There is deliberately no reset for the controller because the entire configuration of the device cannot be reset. The controller is a monitor of the device configuration from the point when the device is configured until the power is removed (or it is reconfigured). The task of the SEM Controller is to monitor and maintain the original configuration state and not restart from some interim (potentially erroneous) state.

# **Additional Considerations**

Design limitations of the SEM core include the following:

- EasyPath devices are not compatible with the error correction by replace method.
- The SEM Controller initializes and manages the FPGA integrated silicon features for soft error mitigation. When the controller is included in a design, do not include any design constraints or options that would enable the built-in detection functions. Enabling the necessary functions to provide detection is performed autonomously by the SEM Controller. For example, do not set POST\_CRC, POST\_CONFIG\_CRC, or any other related constraints. Similarly, do not include options to disable GLUTMASK. The default value of YES is required to prevent false error detections by the SEM core.
- Software computed ECC and CRC values are not supported.
- Simulation of designs that instantiate the controller is supported. However, it is not
  possible to observe the controller behaviors in simulation. Simulation of a design
  including the controller compiles, but the controller will not exit the initialization state.
  Hardware-based evaluation of the controller behaviors is required. Alternatively,
  customers can use ISim Hardware Co-simulation to simulate their design.
- Use of bitstream security (encryption and authentication) is not supported by the controller.
- Use of SelectMAP persistence is not supported by the controller.
- When the controller requires storage of configuration data for correction by replace, this data must be available to the controller through the Fetch Interface, typically through the EXT shim. This decouples the controller from the FPGA configuration method and allows customers flexibility in selection of configuration method, configuration data storage, and soft error mitigation solution data storage.
- The EXT shim implementation supports only one SPI Flash read command (fast read) in SPI Mode 0 (CPOL = 0, CPHA = 0) to a single SPI Flash device.

- Due to potential I/O voltage incompatibility between the FPGA device and standard SPI Flash devices, level translation may be required in the design of the SPI memory system.
- ICAP Arbitration, ICAP Switchover, and Partial Reconfiguration are not supported. Only a single ICAP instance is supported, and it must reside at the primary/top physical location.
- Use of design capture, including the use of the capture primitive and related functionality, is not supported by the controller.
- In implementations for Spartan-6 FPGAs, neither Suspend mode nor PLL DRP can be used.
- Controller implementations for 7 series FPGAs operate on soft errors in Type 0, Type 2, and Type 3 configuration frames. See the 7 Series FPGAs Configuration User Guide (UG470) [Ref 2] for information on 7 series configuration frame types.
- Controller implementations for Virtex-6 FPGAs operate on soft errors in Type 0, Type 2, and Type 3 configuration frames. See the *Virtex-6 FPGA Configuration User Guide* (UG360) [Ref 3] for information on Virtex-6 configuration frame types.
- Controller implementations for Spartan-6 FPGAs operate only on soft errors in Type 0 configuration frames. See the *Spartan-6 FPGA Configuration User Guide* (UG380) [Ref 4] for information on Spartan-6 configuration frame types.



# SECTION II: VIVADO DESIGN SUITE

Customizing and Generating the Core Constraining the Core Detailed Example Design



# Customizing and Generating the Core

This chapter includes information about using Xilinx tools to customize and generate the core in the Vivado® Design Suite environment.

# GUI

To customize and generate the core, locate the IP core in the IP Catalog at **FPGA Features and Design** > **Soft Error Mitigation** > **Soft Error Mitigation** and click it once to select it. Important information regarding the solution is displayed in the Details pane of the Project Manager window. Review this information before proceeding.

### **XILINX**.

Double-click on the IP core in the IP catalog to open the customization dialog box, shown in Figure 4-1.

| Show disabled ports                                                                                                                           |                                                                                                                                                                                                  | Component Name sem_v3_4_0  IP Solution Options IP Solution Summary                               |     |
|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----|
|                                                                                                                                               |                                                                                                                                                                                                  | Soft Error Mitigation IP Solution Options                                                        | \$  |
| fetch_txfull<br>fetch_rxdata[7:0]                                                                                                             | status_heartbeat                                                                                                                                                                                 | Controller Options                                                                               | *   |
| fetch_rxempty<br>fetch_tbladdr[31:0]<br>monitor_txfull                                                                                        | status_initialization -<br>status_observation -<br>status_correction -                                                                                                                           | Enable Error Injection     Enable Error Correction                                               | ^   |
| monitor_rxdata[7:0]                                                                                                                           | status_classification                                                                                                                                                                            | Error Correction Method                                                                          | \$  |
| monitor_rxempty<br>inject_strobe<br>inject_address[39:0]<br>(cap_busy<br>icap_o[31:0]<br>icap_clk<br>icap_grant<br>fecc_crcerr<br>fecc_eccerr | status_injection -<br>status_essential -<br>status_uncorrectable -<br>fetch_txdata[7:0] -<br>fetch_txwrite -<br>fetch_rxread -<br>monitor_txdata[7:0] -<br>monitor_txwrite -<br>monitor_rxread - |                                                                                                  | IHZ |
| fecc_eccerrsingle                                                                                                                             | icap_csb =                                                                                                                                                                                       |                                                                                                  |     |
| fecc_syndromevalid<br>fecc_syndrome[12:0]<br>fecc_far[25:0]<br>fecc_synbit[4:0]<br>fecc_synword[6:0]                                          | icap_csib -<br>icap_rdwrb -<br>icap_i(31:0) -<br>icap_request -                                                                                                                                  | System Level Design Example Options<br>Error Injection Shim pins T<br>Data Retrieval Shim none T | *   |

Figure 4-1: Solution Customization Dialog Box Tab 1

Review each of the available options, and modify them as desired so that the SEM Controller solution meets the requirements of the larger project into which it will be integrated. The following sub-sections discuss the options in detail to serve as a guide.

### **Component Name and Symbol**

The name of the generated component is set by the Component Name field. The name "sem\_v3\_4\_0" is used in this example.

The Component Symbol occupies the left half of the dialog box and provides a visual indication of the ports that will exist on the component, given the current option settings. This diagram is automatically updated when the option settings are modified.

# **Controller Options: Enable Error Injection**

The Enable Error Injection checkbox is used to enable or disable the error injection feature. Error injection is a design verification function that provides a mechanism for users to create errors in Configuration Memory that model a soft error event. This is useful during integration or system level testing to verify that the controller has been properly interfaced with system supervisory logic and that the system responds as desired when a soft error event occurs.

If error injection is enabled, the Error Injection Interface is generated (as indicated by the Component Symbol) and the controller performs error injections in response to commands from the user. These commands can be applied to the Error Injection Interface or to the Monitor Interface.

If error injection is disabled, the Error Injection Interface is removed (as indicated by the Component Symbol) and the controller will not perform any error injections.

**TIP:** The Monitor Interface continues to exist even if the Error Injection Interface is removed. If error injection commands are applied to the Monitor Interface, the controller parses the commands but otherwise ignores them.

### **Controller Options: Enable Error Correction**

The Enable Error Correction checkbox is used to enable or disable the error correction feature. No matter what setting is used, the controller monitors the error detection circuits and reports error conditions.

If error correction is enabled, the controller attempts to correct errors that are detected. The method by which corrections are performed is selectable. Most errors are correctable, and upon successful correction, the controller signals that a correctable error has occurred and was corrected. For errors that are not correctable, the controller signals that an uncorrectable error has occurred.

If error correction is disabled, the controller does not attempt to correct errors. At the first error event, the controller stops scanning after reporting the error condition. Further, when error correction is disabled, the error classification feature is also disabled.

# **Controller Options: Error Correction Method**

With error correction enabled, the error correction method is selectable. The available methods are correction by repair, correction by enhanced repair, and correction by replace.

The controller corrects errors using the method selected by the user. The correction possibilities are:

#### Correction by Repair

• Correction by repair for one-bit errors. The ECC syndrome is used to identify the exact location of the error in a frame. The frame containing the error is read, the relevant bit inverted, and the frame is written back. This is signaled as correctable.

#### Correction by Enhanced Repair

• Correction by repair for one-bit and two-bit adjacent errors. For one-bit errors, the behavior is identical to correction by repair. For two-bit errors, an enhanced CRC-based algorithm capable of correcting two-bit adjacent errors is used. The frame containing the error is read, the relevant bits inverted, and the frame is written back. This is signaled as correctable.

#### Correction by Replace

• Correction by replace for one-bit and multi-bit errors. The frame containing the error is read. The controller requests replacement data for the entire frame from the Fetch Interface. When the replacement data is available, the controller compares the damaged frame with the replacement frame to identify the location of the errors. Then, the replacement data is written back. This is signaled as correctable.

The difference between repair, enhanced repair, and replace methods becomes clear when considering what happens in the uncommon case of errors involving more bits than can be corrected by the repair or enhanced repair methods. In these cases, the repair or enhanced repair methods will not yield a successful correction. However, if such errors are corrected by the replace method, the error is correctable regardless of how many bits were affected.

The fundamental trade-off between the methods is error correction success rate versus the cost of adding or increasing data storage requirements. Using correction by repair as the baseline for comparison:

- Correction by enhanced repair provides superior correction capability through use of additional block RAM to store frame-level CRCs.
- Correction by replace provides ultimate correction capability through the addition of external SPI Flash to store "golden" frame replacement data.

EasyPath devices are not compatible with the error correction by replace method.

# **Controller Options: Enable Error Classification**

The Enable Error Classification checkbox is used to enable or disable the error classification feature. Error classification is automatically disabled if error correction is disabled.

 $\bigcirc$ 

The error classification feature uses the Xilinx Essential Bits technology to determine whether a detected and corrected soft error has affected the function of a user design. Essential Bits are those bits that have an association with the circuitry of the design. If an Essential Bit changes, it changes the design circuitry. However it may not necessarily affect the function of the design.

Without knowing which bits are essential, the system must assume any detected soft error has compromised the correctness of the design. The system level mitigation behavior often results in disruption or degradation of service until the FPGA configuration is repaired and the design is reset or restarted.

For example, if the Vivado Bitstream Generator reports that 20% of the Configuration Memory is essential to an operation of a design, then only 2 out of every 10 soft errors (on average) actually merits a system-level mitigation response. The error classification feature is a table lookup to determine if a soft error event has affected essential Configuration Memory locations. Use of this feature reduces the effective FIT of the design. The cost of enabling this feature is the external storage required to hold the lookup table. When error classification is enabled, the Fetch Interface is generated (as indicated by the Component Symbol) so that the controller has an interface through which it can retrieve external data.

If error classification is enabled, and a detected error has been corrected, the controller will look up the error location. Depending on the information in the table, the controller will either report the error as essential or non-essential. If a detected error cannot be corrected, this is because the error cannot be located. Therefore, the controller conservatively reports the error as essential because it has no way to look up data to indicate otherwise.

If error classification is disabled, the controller unconditionally reports all errors as essential because it has no data to indicate otherwise.

**TIP:** Error classification need not be performed by the controller. It is possible to disable error classification by the controller, and implement it elsewhere in the system using the essential bit data provided by the implementation tools and the error report messages issued by the controller through the Monitor Interface.

### **Controller Options: Controller Clock Frequency**

The controller clock frequency is set by the Clock Frequency field. The error mitigation time decreases as the controller clock frequency increases. Therefore, the frequency should be as high as practical. The dialog box warns if the desired frequency exceeds the capability of the target device.

For designs that require a data retrieval interface to fetch external data for error classification or error correction by replace, an additional consideration exists. The example design implements an external memory interface that is synchronous to the controller. The controller clock frequency therefore also determines the external memory cycle time. The



external memory system must be analyzed to determine its minimum cycle time, as it can limit the maximum controller clock frequency.

Instructions on how to perform this analysis are located in Interfaces in Chapter 3. However, this analysis requires timing data from implementation results. Therefore, Xilinx recommends the following:

- 1. Generate the solution using the desired frequency setting.
- 2. Extract the required timing data from the implementation results.
- 3. Complete the timing budget analysis to determine maximum frequency.
- 4. Re-generate the solution with a frequency at or below the calculated maximum frequency of operation.

### **Example Design Options: Error Injection Shim**

For customizations that include error injection, the example design provides two options for a shim to external control of the Error Injection Interface:

- Direct control through physical pins
- Indirect control through JTAG using Xilinx ChipScope tool

When selecting ChipScope analyzer to control the Error Injection Interface, the ChipScope tool ICON and ChipScope tool VIO cores are not included. Generation of the ICON and VIO core from within the example project automatically adds the necessary sources to the project. The necessary ChipScope tool core settings are described in Generating and Using ChipScope Tool Files.

### **Example Design Options: Data Retrieval Shim**

For customizations that require a data retrieval interface to fetch external data for error classification or error correction by replace, the controller Fetch Interface must be bridged to an external storage device. The example design provides a shim to an external SPI Flash device as the only option. If the data retrieval interface is not required, no shim is generated.

### **Reviewing the Customizations**

Proceed to the second tab of the solution customization dialog box. This tab is shown in Figure 4-2.

| t Error Mitigation                                                                                                                                                                                                                                                                        | •                                                                                                                                                                                                                                                                                             | Component Name sem_v3_4_0                                                                                                                                                                                                                                                                                                                                                                                                 | 7  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                               | IP Solution Options IP Solution Summary                                                                                                                                                                                                                                                                                                                                                                                   |    |
| retch_tatull                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                               | Soft Error Mitigation IP Solution Summary                                                                                                                                                                                                                                                                                                                                                                                 | \$ |
| fetch_rxdata[7:0]<br>fetch_rxemptv<br>fetch_rxemptv<br>fetch_tbladdr[31:0]<br>monitor_txfull<br>monitor_rxdata[7:0]<br>monitor_rxemptv<br>inject_strobe<br>inject_address[39:0]<br>icap_busv<br>icap_0[31:0]<br>icap_clk<br>icap_grant<br>fecc_eccerr<br>fecc_eccerr<br>fecc_eccerrsingle | status_heartbeat<br>status_initialization<br>status_observation<br>status_classification<br>status_classification<br>status_injection<br>status_essential<br>status_uncorrectable<br>fetch_txdata[7:0]<br>fetch_txwrite<br>fetch_rxread<br>monitor_txdata[7:0]<br>monitor_txwrite<br>icap_csb | Controller Summary         Error Injection       Enabled         Error Correction       Repair Er         Error Classification       Disabled         Data Retrieval Port       Disabled         Controller Clock Frequency       8 MHz         System Level Design Example Summary         Error Injection Shim       Pins         Data Retrieval Shim       None         Data Retrieval Frequency       Not Application | *  |
| fecc_syndromevalid<br>fecc_syndrome[12:0]<br>fecc_far[25:0]<br>fecc_synbit[4:0]<br>fecc_synword[6:0]                                                                                                                                                                                      | icap_csib<br>icap_rdwrb<br>icap_i[31:0]<br>icap_request                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                           |    |

*Figure 4-2:* Solution Customization Dialog Box Tab 2

Review the summary to confirm each option is correct. Return to the previous tab, if necessary, to correct or change the selected options. After the options are reviewed and correct, click **OK** to complete the IP customization.

# **Output Generation**

The SEM IP solution delivers files into a number of file groups. The file groups generated can be seen in the IP Sources tab of the Sources window where they are listed for each IP in the project. The file groups available for the SEM core are:

- **Examples**: Includes all source required to be able to open and implement the IP example design project, (Example design HDL and the example design XDC file).
- **Synthesis**: Includes all synthesis sources required by the core. For the SEM core, this is a mix of both encrypted and unencrypted source. Only the unencrypted sources are visible.
- Instantiation Template: Example instantiation template.

# Generating and Using ChipScope Tool Files

This section describes requirements for ChipScope tool files necessary to support the optional error injection feature in the specific customizations where the ChipScope tool is selected as the error injection shim.

# **ChipScope Tool Files for 7 Series FPGAs**

The ChipScope tool ICON core must be generated for the target device, using the default core name "chipscope\_icon", with the following parameters:

```
ENABLE_JTAG_BUFG = TRUE
NUMBER_CONTROL_PORTS = 1
USE_EXT_BSCAN = FALSE
USE_SOFTBSCAN= FALSE
USE_UNUSED_BSCAN = FALSE
```

The USER\_SCAN\_CHAIN can be set as desired. Generation of the ICON core from within the example project automatically adds the necessary sources to the project.

For non-stacked silicon interconnect (SSI) devices, the ChipScope tool VIO core must be generated for the target device, using the default core name "chipscope\_vio", with the following parameters:

```
ENABLE_ASYNCHRONOUS_INPUT_PORT = FALSE
ENABLE_ASYNCHRONOUS_OUTPUT_PORT = FALSE
ENABLE_SYNCHRONOUS_INPUT_PORT = TRUE
ENABLE_SYNCHRONOUS_OUTPUT_PORT = TRUE
INVERT_CLOCK_INPUT = FALSE
SYNCHRONOUS_INPUT_PORT_WIDTH = 8
SYNCHRONOUS_OUTPUT_PORT_WIDTH = 41
```

Generation of the VIO core from within the example project automatically adds the necessary sources to the project. The instantiation and interconnection of the ICON and VIO components inside the HID shim can be inspected, if desired. The mapping of the VIO synchronous input and synchronous output ports is:

```
sync_in[7] receives status_heartbeat
sync_in[6] receives status_uncorrectable
sync_in[5] receives status_essential
sync_in[4] receives status_injection
sync_in[3] receives status_classification
sync_in[1] receives status_observation
sync_in[0] receives status_observation
sync_out[40] drives inject_strobe
sync_out[39:0] drives inject_address[39:0]
```

For SSI devices, the ChipScope tool VIO core must be generated for the target device, using the default core name "chipscope\_vio", with the following parameters:

```
ENABLE_ASYNCHRONOUS_INPUT_PORT = FALSE
ENABLE_ASYNCHRONOUS_OUTPUT_PORT = FALSE
ENABLE_SYNCHRONOUS_INPUT_PORT = TRUE
ENABLE_SYNCHRONOUS_OUTPUT_PORT = TRUE
INVERT_CLOCK_INPUT = FALSE
SYNCHRONOUS_INPUT_PORT_WIDTH = 32
SYNCHRONOUS_OUTPUT_PORT_WIDTH = 41
```

Generation of the VIO core from within the example project automatically adds the necessary sources to the project. The instantiation and interconnection of the ICON and VIO components inside the HID shim can be inspected. The mapping of the VIO synchronous input and synchronous output ports is:

```
sync_in[31] receives slr3_status_heartbeat
sync_in[30] receives slr3_status_uncorrectable
sync_in[29] receives slr3_status_essential
sync_in[28] receives slr3_status_injection
sync_in[27] receives slr3_status_classification
sync_in[26] receives slr3_status_correction
sync_in[25] receives slr3_status_observation
sync_in[24] receives slr3_status_initialization
sync_in[23] receives slr2_status_heartbeat
sync_in[22] receives slr2_status_uncorrectable
sync_in[21] receives slr2_status_essential
sync_in[20] receives slr2_status_injection
sync_in[19] receives slr2_status_classification
sync_in[18] receives slr2_status_correction
sync_in[17] receives slr2_status_observation
sync_in[16] receives slr2_status_initialization
sync_in[15] receives slr1_status_heartbeat
sync_in[14] receives slr1_status_uncorrectable
sync_in[13] receives slr1_status_essential
sync_in[12] receives slr1_status_injection
sync_in[11] receives slr1_status_classification
sync_in[10] receives slr1_status_correction
sync_in[9] receives slr1_status_observation
sync_in[8] receives slr1_status_initialization
```

```
sync_in[7] receives slr0_status_heartbeat
sync_in[6] receives slr0_status_uncorrectable
sync_in[5] receives slr0_status_essential
sync_in[4] receives slr0_status_injection
sync_in[3] receives slr0_status_classification
sync_in[1] receives slr0_status_correction
sync_in[0] receives slr0_status_initialization
sync_out[40] drives inject_strobe
sync_out[39:0] drives inject_address[39:0]
```

# Using ChipScope Analyzer

A project must be created in the ChipScope Analyzer software. The status signals received by the synchronous input port should be represented with LEDs. The inject\_address output value should be represented as HEX for data entry. The inject\_strobe control output must be represented as a three-cycle PULSE output for proper operation.

# **Integration and Validation**

In the development of a complex system, early integration and continual validation of major functional blocks and interfaces is an important best practice. Significant design changes near the end of the development cycle (late integration) or postponing system performance measurements (late validation) increase risk.

Include integration and validation milestones in your project planning and support them with a plan to confirm system functionality and performance throughout the development cycle. Starting as early as possible and incrementally including as much functionality as practical provides the most time for system evaluation under representative workloads. This recommendation complements the commonly used bottom-up design approach, facilitating design reuse and IP-based design.<sup>(1)</sup>

# Integration of the SEM IP Core

The SEM IP core has a small programmable logic footprint, but activates the programmable logic configuration memory system. The configuration memory system works much like a conventional SRAM, except that it is physically distributed throughout the programmable logic array. Just like all other digital switching activity in the device, activity in the configuration memory system generates power noise.

<sup>1.</sup> See Comprehensive Full-Chip Methodology to Verify EM and Dynamic Voltage Drop on High Performance FPGA Designs in the 20nm Technology presented at DesignCon 2014 [Ref 7].

In all device families supported by the SEM IP core, the power noise contribution from the configuration memory system is minor, provided all implementation requirements and design guidance is observed.



**RECOMMENDED:** Xilinx strongly recommends system designers integrating the SEM IP core to use the current version and to keep current with the SEM IP core design advisories and known issues through Xilinx Answer Records for Soft Error Mitigation IP Solutions.

Integrate the SEM IP core as early as possible, ideally at the start of the project. Because the SEM IP core can automatically initialize, the first pass integration of this core can be as simple as instantiating it, connecting a clock, and adding tie-offs to other input ports. As part of this early infrastructure, Xilinx recommends implementing the SEM IP core provisioning controls to allow the system to enable/disable the SEM IP core clock and enable/disable the SEM IP core provides deployment flexibility and also facilitates debug of the SEM IP core integration.

At a later point, the integration can be expanded through definition and implementation of an interface for command/status exchange between the system and the SEM IP core. The preferred method for this uses ASCII communication over the SEM IP core Monitor Interface, either with the UART helper block for a serial connection, or without the UART helper block for a parallel connection using communication FIFOs.

Although the status exchange alone is adequate for the system to log and parse events reported by the SEM IP core, the command exchange is critical to support error injection. Without error injection, there is no practical way to completely test the integration of the SEM IP core and the system response to the SEM IP core event reports, outside of an accelerated particle test at a radiation effects facility. Error injection can also be useful for a minor aspect of continual validation.

# Validation with the SEM IP Core

In a deployed system containing the SEM IP core, the configuration memory system activity is a mix of reads and writes during the SEM IP core initialization state. Afterward the activity is 100% reads during the observation state to perpetually scan the configuration memory for single event upsets. Given the exceptionally low upset rate of the Xilinx configuration memory in a terrestrial environment (that is, mean time between upset is decades at sea level in NYC), the SEM IP core rarely transitions out of the Observation state into the Correction state during which writes can take place.

Continual validation of a system containing the SEM IP core should use a representative SEM IP core workload to ensure validation results will be representative of the system in deployment. Provided the system provisions the SEM IP core to complete the Initialization and enter the Observation state, the default workload of configuration memory scanning with no upsets is not only the easiest, but also representative for validation. If desired, the SEM IP core error injection feature can be used to incorporate an occasional error detection and correction into the workload.



**IMPORTANT:** Xilinx does not recommend "stress testing" with high rate error injection to generate a large number of error detection and correction events, as this stimulus is unnatural and can yield validation results that are irrelevant to reliable operation of the system.

Continual validation of the system should extend beyond the research and development phase into production testing. With the SEM IP core, this requires little to no additional effort, as the system provisioning during production testing need to only enable the SEM IP core.



# Chapter 5

# Constraining the Core

This chapter contains details about applicable constraints.

# **Required Constraints**

The SEM Controller and the system-level design example require the specification of physical implementation constraints to yield a functional result that meets performance requirements. These constraints are provided with the system-level design example in an XDC file. The XDC file, <component name>\_sem\_example.xdc, can be found in the IP Sources tab of the Sources window in the Examples file group.

To achieve consistent implementation results, the XDC provided with the solution must be used. For additional details on the definition and use of a XDC or specific constraints, see the Constraints Guide available through the <u>documentation page for the Vivado Design</u> <u>Suite</u>.

Constraints may require modification to integrate the solution into a larger project, or as a result of changes made to the system-level design example. Modifications should only be made with a thorough understanding of the effect of each constraint. Additionally, support is not provided for designs that deviate from the provided constraints.

# **Contents of the Xilinx Design Constraints File**

Although the XDC delivered with each generated solution shares the same overall structure and sequence of constraints, the contents may vary based on options set at generation. The sections that follow define the structure and sequence of constraints using a Kintex<sup>™</sup>-7 device implementation as an example.

### **Controller Constraints**

The controller, considered in isolation and regardless of options at generation, is a fully synchronous design. Fundamentally, it only requires a clock period constraint on the master clock input. In the generic XDC, this constraint is placed on the system-level design example clock input and propagated into the controller. The constraint is discussed in Example

### **XILINX**.

#### Design Constraints.

The signal paths between the controller and the FPGA configuration system primitives must be considered as synchronous paths. By default, the paths between the internal configuration access port (ICAP) primitive and the controller are analyzed as part of a clock period constraint on the master clock, because the ICAP clock pin is required to be connected to the same master clock signal.

However, the situation is different for the FRAME\_ECC primitive (when present), as it does not have a clock pin. Based on the specific use of the FRAME\_ECC primitive with the ICAP primitive, it is known that FRAME\_ECC primitive pins are synchronous to the master clock signal. Therefore, additional constraints with values derived from the clock period constraint are added:

```
set_max_delay 12.151 -from [get_pins example_cfg/example_frame_ecc/*] -quiet -datapath_only
set_max_delay 30.302 -from [get_pins example_cfg/example_frame_ecc/*] -to [all_outputs]
-quiet -datapath_only
```

### **Example Design Constraints**

The example design constraints are organized by interface, rather than constraint type. The first group is for the master clock input to the entire design. It applies an I/O standard and a period constraint. The period constraint value is based on options set at generation:

```
create_clock -name clk -period 15.151 [get_ports clk]
set_property IOSTANDARD LVCMOS25 [get_ports clk]
```

The second group is for the Status Interface, applying an I/O standard and an output timing constraint to the interface. The output timing constraint is set at two times the period constraint.

```
set_property DRIVE 8 [get_ports status_initialization]
set_property SLEW FAST [get_ports status_initialization]
set_property IOSTANDARD LVCMOS25 [get_ports status_initialization]
set_property DRIVE 8 [get_ports status_observation]
set_property SLEW FAST [get_ports status_observation]
set_property IOSTANDARD LVCMOS25 [get_ports status_observation]
set_property DRIVE 8 [get_ports status_correction]
set_property SLEW FAST [get_ports status_correction]
set_property IOSTANDARD LVCMOS25 [get_ports status_correction]
set_property DRIVE 8 [get_ports status_classification]
set_property SLEW FAST [get_ports status_classification]
set_property IOSTANDARD LVCMOS25 [get_ports status_classification]
set_property DRIVE 8 [get_ports status_injection]
set_property SLEW FAST [get_ports status_injection]
set_property IOSTANDARD LVCMOS25 [get_ports status_injection]
set_property DRIVE 8 [get_ports status_uncorrectable]
set_property SLEW FAST [get_ports status_uncorrectable]
```

set\_property IOSTANDARD LVCMOS25 [get\_ports status\_uncorrectable]

set\_property DRIVE 8 [get\_ports status\_essential]
set\_property SLEW FAST [get\_ports status\_essential]
set\_property IOSTANDARD LVCMOS25 [get\_ports status\_essential]

set\_property DRIVE 8 [get\_ports status\_heartbeat]
set\_property SLEW FAST [get\_ports status\_heartbeat]
set\_property IOSTANDARD LVCMOS25 [get\_ports status\_heartbeat]

set\_output\_delay -clock clk -15.151 [get\_ports [list status\_observation
status\_correction status\_classification status\_injection status\_uncorrectable
status\_essential status\_heartbeat status\_initialization]] -max
set\_output\_delay -clock clk 0 [get\_ports [list status\_observation status\_correction
status\_classification status\_injection status\_uncorrectable status\_essential
status\_heartbeat status\_initialization]] -min

The third group is for the MON shim, applying an I/O standard and input/output timing constraints to the interface. The input and output timing constraints are set at two times the period constraint.

```
set_property DRIVE 8 [get_ports monitor_tx]
set_property SLEW FAST [get_ports monitor_tx]
set_property IOSTANDARD LVCMOS25 [get_ports monitor_tx]
set_property IOSTANDARD LVCMOS25 [get_ports monitor_rx]
set_input_delay -clock clk -max -15.151 [get_ports monitor_rx]
set_output_delay -clock clk -min 30.302 [get_ports monitor_rx]
set_output_delay -clock clk -15.151 [get_ports monitor_tx] -max
set_output_delay -clock clk 0 [get_ports monitor_tx] -min
```

The following group is for the EXT shim, and is only present when the EXT shim is generated based on options set at generation. It applies an I/O standard and input/output timing constraints to the interface. The input and output timing is of considerable importance, as the actual timing must be used in the analysis of the SPI bus timing budget. However, there is no hard requirement for the input and output timing of the FPGA implementation. It varies based on the selected device and speed grade.

As such, the input and output timing constraints are arbitrarily set at two times the period constraint. The additional constraint to use IOB flip-flops yields substantially better input and output timing than the constraint values suggest. It is the actual timing obtained from the timing report that should be used in the analysis of the SPI bus timing budget, not the constraint value.

```
set_property IOB TRUE [get_cells example_ext/example_ext_byte/ext_c_ofd]
set_property IOB TRUE [get_cells example_ext/example_ext_byte/ext_d_ofd]
set_property IOB TRUE [get_cells example_ext/example_ext_byte/ext_q_ifd]
set_property IOB TRUE [get_cells example_ext/ext_s_ofd]
set_property DRIVE 8 [get_ports external_c]
set_property SLEW FAST [get_ports external_c]
set_property IOSTANDARD LVCMOS25 [get_ports external_c]
set_property DRIVE 8 [get_ports external_d]
set_property SLEW FAST [get_ports external_d]
```

set\_property IOSTANDARD LVCMOS25 [get\_ports external\_d]
set\_property DRIVE 8 [get\_ports external\_s\_n]
set\_property SLEW FAST [get\_ports external\_s\_n]
set\_property IOSTANDARD LVCMOS25 [get\_ports external\_s\_n]
set\_property IOSTANDARD LVCMOS25 [get\_ports external\_q]
set\_input\_delay -clock clk -max -15.151 [get\_ports external\_q]
set\_output\_delay -clock clk -min 30.302 [get\_ports external\_q]
set\_output\_delay -clock clk -15.151 [get\_ports [list external\_d external\_s\_n
external\_c]] -max
set\_output\_delay -clock clk 0 [get\_ports [list external\_d external\_c]]
-min

The following group is for the HID shim, and is only present when the HID shim is I/O Pins. It applies an I/O standard and input timing constraint to the interface. The input timing constraint is set at two times the period constraint.

| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | inject_strobe]                   |
|-------------------------|------------|----------|------------|----------------------------------|
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[0]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[1]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[2]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[3]}]             |
| set_property            |            |          | [get_ports | {inject_address[4]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[5]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[6]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[7]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[8]}]</pre>  |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[9]}]             |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[10]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[11]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[12]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[13]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[14]}]            |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[15]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[16]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[17]}]            |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[18]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[19]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[20]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[21]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[22]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[23]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[24]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[25]}]</pre> |
| <pre>set_property</pre> |            |          | [get_ports | <pre>{inject_address[26]}]</pre> |
| <pre>set_property</pre> |            |          | [get_ports | <pre>{inject_address[27]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[28]}]</pre> |
| <pre>set_property</pre> |            |          | [get_ports | <pre>{inject_address[29]}]</pre> |
| <pre>set_property</pre> |            |          | [get_ports | <pre>{inject_address[30]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[31]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[32]}]</pre> |
| <pre>set_property</pre> |            |          | [get_ports | <pre>{inject_address[33]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[34]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[35]}]</pre> |
| set_property            | IOSTANDARD | LVCMOS25 | [get_ports | <pre>{inject_address[36]}]</pre> |
| <pre>set_property</pre> | IOSTANDARD | LVCMOS25 | [get_ports | {inject_address[37]}]            |

```
set_property IOSTANDARD LVCMOS25 [get_ports {inject_address[38]}]
set_property IOSTANDARD LVCMOS25 [get_ports {inject_address[39]}]
set_input_delay -clock clk -max -14.285 [get_ports [list {inject_address[0]}
{inject_address[1]} {inject_address[2]} {inject_address[3]} {inject_address[4]}
{inject_address[5]} {inject_address[6]} {inject_address[7]} {inject_address[8]}
{inject_address[9]} {inject_address[10]} {inject_address[11]} {inject_address[12]}
{inject_address[13]} {inject_address[14]} {inject_address[15]} {inject_address[16]}
{inject_address[17]} {inject_address[18]} {inject_address[19]} {inject_address[20]}
{inject_address[21]} {inject_address[22]} {inject_address[23]} {inject_address[24]}
{inject_address[25]} {inject_address[26]} {inject_address[27]} {inject_address[28]}
{inject_address[29]} {inject_address[30]} {inject_address[31]} {inject_address[32]}
{inject_address[33]} {inject_address[34]} {inject_address[35]} {inject_address[36]}
{inject_address[37]} {inject_address[38]} {inject_address[39]} inject_strobe]]
set_input_delay -clock clk -min 28.57 [get_ports [list {inject_address[0]}
{inject_address[1]} {inject_address[2]} {inject_address[3]} {inject_address[4]}
{inject_address[5]} {inject_address[6]} {inject_address[7]} {inject_address[8]}
{inject_address[9]} {inject_address[10]} {inject_address[11]} {inject_address[12]}
{inject_address[13]} {inject_address[14]} {inject_address[15]} {inject_address[16]}
{inject_address[17]} {inject_address[18]} {inject_address[19]} {inject_address[20]}
{inject_address[21]} {inject_address[22]} {inject_address[23]} {inject_address[24]}
{inject_address[25]} {inject_address[26]} {inject_address[27]} {inject_address[28]}
{inject_address[29]} {inject_address[30]} {inject_address[31]} {inject_address[32]}
{inject_address[33]} {inject_address[34]} {inject_address[35]} {inject_address[36]}
{inject_address[37]} {inject_address[38]} {inject_address[39]} inject_strobe]]
```

The following constraints in the XDC implement a pblock to place portions of the system-level design example into a bounded region of the selected device. The instances included in the pblock depend on the options set at generation. The range values vary depending on device selection.

The pblock forces packing of the soft error mitigation logic into an area physically adjacent to the ICAP site in the device. Most importantly, this maintains reproducibility in timing results. It also improves resource usage; the pblock forces tighter packing and generates a resource usage summary that is helpful in estimating the FIT of the system-level design example.

```
create_pblock SEM_CONTROLLER
resize_pblock -pblock SEM_CONTROLLER -add RAMB18_X2Y50:RAMB18_X4Y59
resize_pblock -pblock SEM_CONTROLLER -add RAMB36_X2Y25:RAMB36_X4Y29
resize_pblock -pblock SEM_CONTROLLER -add SLICE_X36Y125:SLICE_X47Y149
add_cells_to_pblock -pblock SEM_CONTROLLER -cells [get_cells example_controller/*]
add_cells_to_pblock -pblock SEM_CONTROLLER -cells [get_cells example_mon/*]
add_cells_to_pblock -pblock SEM_CONTROLLER -cells [get_cells example_mon/*]
add_cells_to_pblock -pblock SEM_CONTROLLER -cells [get_cells example_ext/*]
set_property LOC FRAME_ECC_X0Y0 [get_cells example_cfg/example_frame_ecc]
set_property LOC ICAP_X0Y1 [get_cells example_cfg/example_icap]
```

The following constraints in the XDC are a template for assigning I/O pin locations to the top-level ports of the system-level example design. These assignments are necessarily board-specific and therefore cannot be automatically generated. To apply these constraints, uncomment them and fill in valid I/O pin locations for the target board.

## set\_property LOC <pin loc> [get\_ports clk]

## set\_property LOC <pin loc> [get\_ports status\_initialization] ## set\_property LOC <pin loc> [get\_ports status\_observation] ## set\_property LOC <pin loc> [get\_ports status\_correction] ## set\_property LOC <pin loc> [get\_ports status\_classification] ## set\_property LOC <pin loc> [get\_ports status\_injection] ## set\_property LOC <pin loc> [get\_ports status\_uncorrectable] ## set\_property LOC <pin loc> [get\_ports status\_essential] ## set\_property LOC <pin loc> [get\_ports status\_heartbeat] ## set\_property LOC <pin loc> [get\_ports monitor\_tx] ## set\_property LOC <pin loc> [get\_ports monitor\_rx] ## set\_property LOC <pin loc> [get\_ports external\_c] ## set\_property LOC <pin loc> [get\_ports external\_d] ## set\_property LOC <pin loc> [get\_ports external\_q] ## set\_property LOC <pin loc> [get\_ports external\_s\_n] ## set\_property LOC <pin loc> [get\_ports inject\_strobe] ## set\_property LOC <pin loc> [get\_ports {inject\_address[0]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[1]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[2]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[3]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[4]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[5]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[6]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[7]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[8]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[9]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[10]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[11]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[12]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[13]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[14]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[15]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[16]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[17]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[18]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[19]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[20]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[21]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[22]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[23]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[24]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[25]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[26]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[27]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[28]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[29]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[30]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[31]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[32]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[33]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[34]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[35]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[36]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[37]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[38]}] ## set\_property LOC <pin loc> [get\_ports {inject\_address[39]}]

### **Constraints for SSI Devices**

In the system-level design example, two to four controller instances are generated depending on the device. The controller instances are named to include an identification number ranging from 0 to 3. The controller instance numbering matches the hardware super logic region (SLR) numbering.

An area constraint is applied to each controller to keep controllers centrally located near their associated configuration logic primitives on each SLR. The configuration logic primitives also have placement constraints. This is very similar to the constraints for non-stacked silicon interconnect (SSI) devices as they are repeated on a per-SLR basis.

The shared blocks such as the HID Shim, MON Shim, and EXT Shim also have area constraints to locate them in the Master SLR, which is centrally located in the device and also contains the BSCAN primitives used by the HID Shim.

### Device, Package, and Speed Grade

There are no additional device, package or speed grade constraints.

## **Clock Frequency**

There are no additional clock frequency constraints.

## **Clock Management**

There are no additional clock management constraints.

## **Clock Placement**

There are no additional clock placement constraints.

## I/O Pins

This section contains details about I/O pins constraints.

### I/O Standard

There are no additional I/O standard constraints.

### I/O Banking

There are no additional I/O banking constraints.

### I/O Placement

There are no additional I/O placement constraints.



# **Detailed Example Design**

This section provides an overview of the SEM Controller system-level example design and the interfaces it exposes. The system-level example design encapsulates the controller and various shims that serve to interface the controller to other devices. These shims can include I/O Pins, ChipScope, I/O Interfaces, Memory Controllers, or application-specific system management interfaces.

The system-level example design is verified along with the controller. As delivered, the system-level example design is not a "reference design," but an integral part of the total solution. While users do have the flexibility to modify the system-level example design, the recommended approach is to use it as delivered.

### **Functions**

In addition to serving as an instantiation vehicle for the controller itself, the system-level design example incorporates five main functions:

- The FPGA configuration system primitives and their connection to the controller.
- The MON shim, a bridge between controllers and a standard RS-232 port. The resulting interface can be used to exchange commands and status with controllers. This interface is designed for connection to processors.
- The EXT shim, a bridge between controllers and a standard SPI bus. The resulting interface can be used to fetch data by controllers. This shim is only present in certain controller configurations and is designed for connection to standard SPI Flash.
- The HID shim, a bridge between controllers and an interface device. The resulting interface can be used to exchange commands and status with controllers. This shim is only present in certain controller configurations.

#### **E** XILINX.

Figure 6-1 shows a block diagram of the system-level design example for non-stacked silicon interconnect (SSI) devices. The blocks drawn in gray only exist in certain configurations.



Figure 6-1: Example Design Block Diagram

Figure 6-2 shows a block diagram of the system-level design example for SSI devices. The blocks drawn in gray only exist in certain configurations.





Figure 6-2: Example Design Block Diagram for SSI Devices

The system-level design example is provided to allow flexibility in system-level interfacing. To support this goal, the system-level design example is provided as RTL source code, unlike the controller itself.

### **Port Descriptions**

Figure 6-3 shows the example design ports for non-SSI devices. The ports are clustered into six groups. The groups shaded in gray only exist in certain configurations.



Figure 6-3: Example Design Ports

In an SSI device, each super logic region (SLR) is numbered. There are two numbering methods: hardware SLR numbering and software SLR numbering.

A hardware SLR number represents the configuration order of the SLR in the device. The Master SLR, which is always present, is hardware SLR 0. The hardware SLR numbers of additional Slave SLRs are approximately assigned radially outward from the Master SLR.

A controller instance located in an SLR determines the hardware SLR number at runtime by reading the IDCODE register via the internal configuration access port (ICAP) on that SLR. In all command and status exchanges with controllers implemented in an SSI device, hardware SLR numbering is used.

 $\bigcirc$ 

A software SLR number represents the bottom-to-top physical order of the SLR in the device. The Master SLR, which is always present, has a software SLR number that varies by device. The software SLR numbers are prominently visible in the device view presented by the Xilinx development software.

Table 6-1 details the mapping between hardware SLR numbers and software SLR numbers.

| Device     | Software SLR Number | Hardware SLR Number | SLR Type |
|------------|---------------------|---------------------|----------|
|            | 2                   | Х                   | GTZ      |
| ХС7VH580Т  | 1                   | 1                   | SLAVE    |
|            | 0                   | 0                   | MASTER   |
|            | 4                   | Х                   | GTZ      |
|            | 3                   | 2                   | SLAVE    |
| XC7VH870T  | 2                   | 0                   | MASTER   |
|            | 1                   | 1                   | SLAVE    |
|            | 0                   | Х                   | GTZ      |
|            | 3                   | 3                   | SLAVE    |
| VC7VV1140T | 2                   | 2                   | SLAVE    |
| XC7VX1140T | 1                   | 0                   | MASTER   |
|            | 0                   | 1                   | SLAVE    |
|            | 3                   | 3                   | SLAVE    |
| VCTV2000T  | 2                   | 2                   | SLAVE    |
| XC7V2000T  | 1                   | 0                   | MASTER   |
|            | 0                   | 1                   | SLAVE    |

Table 6-1:Device SLR Numbers

**TIP:** Understanding and translating the SLR numbering methods is not necessary for successful implementation of controllers in an SSI device. However, this information may be useful in conjunction with error injection if it is desired to direct an injected error to a specific SLR.

Figure 6-4 shows the example design ports for SSI devices. The ports are clustered into six groups. The groups shaded in gray only exist in certain configurations. In SSI devices, the Status Interface ports become busses, where the bus width is determined by the number of SLRs in the SSI device.



Figure 6-4: Example Design Ports for SSI Devices

The system-level design example has no reset input or output. The controller automatically initializes itself. The controller then initializes the shims, as required.

The system-level design example is a fully synchronous design using clk as the single clock. All state elements are synchronous to the rising edge of this clock. As a result, the interfaces are generally synchronous to the rising edge of this clock.

#### **Status Interface**

The Status Interface is a direct pass-through from controllers. See Chapter 2, Status Interface for a description of this interface.

#### **Clock Interface**

The Clock Interface is used to provide a clock to the system-level design example. Internally, the clock signal is distributed on a global clock buffer to all synchronous logic elements.

Table 6-2: Clock Interface Details

| Name | Sense | Direction | Description                                                    |
|------|-------|-----------|----------------------------------------------------------------|
| clk  | EDGE  | In        | Receives the master clock for the system-level design example. |

### **Monitor Interface**

The Monitor Interface is always present. The MON shim in the system-level design example is a UART. This shim serializes status information generated by controllers (a byte stream of ASCII codes) for serial transmission. Similarly, the shim de-serializes command information presented to controllers (a bitstream of ASCII codes) for parallel presentation to controllers.

The shim uses a standard serial communication protocol. The shim contains synchronization and over sampling logic to support asynchronous serial devices that operate at the same nominal baud rate. See Chapter 3, Designing with the Core for additional information.

The resulting interface is directly compatible with a wide array of devices ranging from embedded microcontrollers to desktop computers. External level translators may be necessary depending on system requirements.

| Name       | Sense | Direction | Description                                            |
|------------|-------|-----------|--------------------------------------------------------|
| monitor_tx | LOW   | Out       | Serial transmit data from system-level design example. |
| monitor_rx | LOW   | In        | Serial receive data to system-level design example.    |

Table 6-3: Monitor Interface Details

#### **External Interface**

The External Interface is present when controllers require access to external data. When present, the EXT shim in the system-level design example is a fixed-function SPI bus master. This shim accepts commands from controllers that consist of an address and a byte count. The shim generates SPI bus transactions to fetch the requested data from an external SPI Flash. The shim formats the returned data for controllers to pick up.

The shim uses standard SPI bus protocol, implementing the most common mode (CPOL = 0, CPHA = 0, often referred to as "Mode 0"). The SPI bus clock frequency is locked to one half of the master clock for the system-level design example. See Chapter 3, Designing with the Core for information on external timing budgets.

The resulting interface is directly compatible with a wide array of standard SPI Flash. External level translators may be necessary depending on system requirements.

| Name         | Sense | Direction | Description                                                      |
|--------------|-------|-----------|------------------------------------------------------------------|
| external_c   | EDGE  | Out       | SPI bus clock for an external SPI Flash.                         |
| external_d   | HIGH  | Out       | SPI bus "master out, slave in" signal for an external SPI Flash. |
| external_s_n | LOW   | Out       | SPI bus select signal for an external SPI Flash.                 |
| external_q   | HIGH  | In        | SPI bus "master in, slave out" signal for an external SPI Flash. |

 Table 6-4:
 External Interface Details

### **Error Injection Interface**

The Error Injection Interface is present when controllers support error injection and the HID shim is set to I/O Pins. This interface is bussed to all controllers. See Chapter 2, Error Injection Interface for a description of this interface.

When controllers support error injection and the HID shim is set to ChipScope, or when error injection is disabled, this interface is absent.

### **Demonstration Test Bench**

No simulation test bench is provided with the example design.

### Implementation

The example design is not generated by default. The example design is generated by user request and can be opened in a new instance of Vivado. This allows users to view and modify the example of various cores being used without touching their own design. To generate the example design, right-click the sem\_v3\_4.xci file under **Design Sources** and select **Open IP Example Design**.

Implementation of the controller, when configured to use the optional error classification function or the optional correction by replace function, requires a large amount of system RAM.

### 0

**TIP:** Xilinx recommends the use of a 64-bit operating system with 16 Gb or more of system RAM.

### **Run Synthesis and Implementation**

Synthesis and implementation can be run separately by clicking on the appropriate option in the left side menu.

### **Generate the Bitstream**

If error classification or correction by replace options are enabled, additional write\_bitstream options must be specified prior to bitstream generation to create supplemental files. Select **Bitstream Settings** from the left hand **Flow Navigator** menu and enter -ise -bitgen\_options {-g essentialbits:yes} in the **More Options** field.



| 9                          | Bitstream                                                        |                                             |  |
|----------------------------|------------------------------------------------------------------|---------------------------------------------|--|
| General<br>Q<br>Simulation | -raw_bitfile<br>-mask_file<br>-no_binary_bitfile<br>More Options | -ise -bitgen_options {-g essentialbits:yes} |  |
| Synthesis                  |                                                                  |                                             |  |
| mplementation<br>Bitstream |                                                                  |                                             |  |

Figure 6-5: Bitstream Generation

Create the bitstream by selecting **Generate Bitstream** in the left side menu.

#### Creating the External Memory Programming File for Non-SSI Devices

If the solution requires external data storage to support error classification or error correction by replace, an additional TCL script is called to post-process special bitgen output files into a SPI Flash programming file. Select **Window > Design Runs**, then select the implementation design run, impl\_1. The Implementation Run Properties window specifies the directory where the implementation results were captured.

At a terminal prompt, go to the implementation results directory containing the EBC and EBD files created during bitstream generation. Depending on which options are enabled, the following command generates the necessary files. These examples show the general path and the specific instances used in this example flow.

If classification and correction by replace are enabled (used in the example outlined in these steps):

```
xtclsh ../../../project_1.srcs/sources_1/ip/<component name>/<component name>/
implement/makedata.tcl -ebc <ebc filename> -ebd <ebd filename> datafile
```

```
xtclsh ../../../project_1.srcs/sources_1/ip/sem_v3_4_1/sem_v3_4_1/implement/
makedata.tcl -ebc sem_v3_4_1_sem_example.ebc -ebd sem_v3_4_1_sem_example.ebd
datafile
```

If correction by replace is enabled:

```
xtclsh ../../../project_1.srcs/sources_1/ip/<component name>/<component name>/
implement/makedata.tcl -ebc <ebc filename> datafile
```

```
xtclsh ../../../project_1.srcs/sources_1/ip/sem_v3_4_1/sem_v3_4_1/implement/
makedata.tcl -ebc sem_v3_4_1_sem_example.ebc datafile
```

If classification is enabled:

```
xtclsh ../../../project_1.srcs/sources_1/ip/<component name>/<component name>/
implement/makedata.tcl -ebd <ebd filename> datafile
```

```
xtclsh ../../../project_1.srcs/sources_1/ip/sem_v3_4_1/sem_v3_4_1/implement/
makedata.tcl -ebd sem_v3_4_1_sem_example.ebd datafile
```

The command creates the VMF, BIN, and MCS files.

#### **Creating the External Memory Programming File for SSI Devices**

If the solution requires external data storage to support error classification or error correction by replace, an additional TCL script is called to post-process special bitgen output files into a SPI Flash programming file. Select **Window > Design Runs**, then select the implementation design run, impl\_1. The Implementation Run Properties window specifies the directory where the implementation results were captured.

At a terminal prompt, go to the implementation results directory containing the EBC and EBD files created during bitstream generation. A separate EBC and EBD file is generated for each SLR in the target device. Depending on which options are enabled, the following command generates the necessary files. These examples show the general path and the specific instances used in this example flow. The number of files specified after the -ebc or -ebd switch will correspond to the number of SLRs in the target device.

If classification and correction by replace are enabled (used in the example outlined in these steps):

```
xtclsh ../../../project_1.srcs/sources_1/ip/<component name>/<component name>/
implement/makedata.tcl -ebc <file0> <file1> <file2> <file3> -ebd <file0> <file1>
<file2> <file3> datafile
```

```
xtclsh ../../../project_1.srcs/sources_1/ip/sem_v3_4_1/sem_v3_4_1/implement/
makedata.tcl -ebc sem_v3_4_1_sem_example_0.ebc sem_v3_4_1_sem_example_1.ebc
sem_v3_4_1_sem_example_2.ebc sem_v3_4_1_sem_example_3.ebc -ebd
```

```
sem_v3_4_1_sem_example_0.ebd sem_v3_4_1_sem_example_1.ebd
sem_v3_4_1_sem_example_2.ebd sem_v3_4_1_sem_example_3.ebd datafile
```

#### If correction by replace is enabled:

```
xtclsh ../../../project_1.srcs/sources_1/ip/<component name>/<component name>/
implement/makedata.tcl -ebc <file0> <file1> <file2> <file3> datafile
```

xtclsh ../../../project\_1.srcs/sources\_1/ip/sem\_v3\_4\_1/sem\_v3\_4\_1/implement/ makedata.tcl -ebc sem\_v3\_4\_1\_sem\_example\_0.ebc sem\_v3\_4\_1\_sem\_example\_1.ebc sem\_v3\_4\_1\_sem\_example\_2.ebc sem\_v3\_4\_1\_sem\_example\_3.ebc datafile

#### If classification is enabled:

```
xtclsh ../../../project_1.srcs/sources_1/ip/<component name>/<component name>/
implement/makedata.tcl -ebd <file0> <file1> <file2> <file3> datafile
```

```
xtclsh ../../../project_1.srcs/sources_1/ip/sem_v3_4_1/sem_v3_4_1/implement/
makedata.tcl -ebd sem_v3_4_1_sem_example_0.ebd sem_v3_4_1_sem_example_1.ebd
sem_v3_4_1_sem_example_2.ebd sem_v3_4_1_sem_example_3.ebd datafile
```

The command creates the VMF, BIN, and MCS files.

### **External Memory Programming File**

When error correction by replace is enabled, an image of the configuration data is required. When error classification is enabled, an image of the essential bit lookup data is required. As a result, one or both of these data sets may be required. The data sets are identical in size, with their size a function of the target device. The data sets are generated by the bitgen application.

The format of the data is required to be binary, using the full data set(s) generated by bitgen. The external storage must be byte addressable. A small table is required at the address specified to the SEM Controller through fetch\_tbladdr[31:0]. By default, fetch\_tbladdr[31:0] is zero.

For non-SSI devices, the table format is:

- Byte 0: 32-bit pointer to start of replacement data, byte 0 (least significant byte)
- Byte 1: 32-bit pointer to start of replacement data, byte 1
- Byte 2: 32-bit pointer to start of replacement data, byte 2
- Byte 3: 32-bit pointer to start of replacement data, byte 3 (most significant byte)
- Byte 4: 32-bit pointer to start of essential bit data, byte 0 (least significant byte)
- Byte 5: 32-bit pointer to start of essential bit data, byte 1
- Byte 6: 32-bit pointer to start of essential bit data, byte 2

- Byte 7: 32-bit pointer to start of essential bit data, byte 3 (most significant byte)
- Remaining bytes are reserved, filled with ones

For SSI devices, the table format is:

- Byte 0: 32-bit pointer to start of hardware SLR0 (master) replacement data, byte 0 (least significant byte)
- Byte 1: 32-bit pointer to start of hardware SLR0 (master) replacement data, byte 1
- Byte 2: 32-bit pointer to start of hardware SLR0 (master) replacement data, byte 2
- Byte 3: 32-bit pointer to start of hardware SLR0 (master) replacement data, byte 3 (most significant byte)
- Byte 4: 32-bit pointer to start of hardware SLR0 (master) essential bit data, byte 0 (least significant byte)
- Byte 5: 32-bit pointer to start of hardware SLR0 (master) essential bit data, byte 1
- Byte 6: 32-bit pointer to start of hardware SLR0 (master) essential bit data, byte 2
- Byte 7: 32-bit pointer to start of hardware SLR0 (master) essential bit data, byte 3 (most significant byte)
- Byte 8: 32-bit pointer to start of hardware SLR1 (optional slave) replacement data, byte 0 (least significant byte)
- Byte 9: 32-bit pointer to start of hardware SLR1 (optional slave) replacement data, byte
   1
- Byte 10: 32-bit pointer to start of hardware SLR1 (optional slave) replacement data, byte 2
- Byte 11: 32-bit pointer to start of hardware SLR1 (optional slave) replacement data, byte 3 (most significant byte)
- Byte 12: 32-bit pointer to start of hardware SLR1 (optional slave) essential bit data, byte 0 (least significant byte)
- Byte 13: 32-bit pointer to start of hardware SLR1 (optional slave) essential bit data, byte 1
- Byte 14: 32-bit pointer to start of hardware SLR1 (optional slave) essential bit data, byte 2
- Byte 15: 32-bit pointer to start of hardware SLR1 (optional slave) essential bit data, byte 3 (most significant byte)
- Byte 16: 32-bit pointer to start of hardware SLR2 (optional slave) replacement data, byte 0 (least significant byte)
- Byte 17: 32-bit pointer to start of hardware SLR2 (optional slave) replacement data, byte 1

- Byte 18: 32-bit pointer to start of hardware SLR2 (optional slave) replacement data, byte 2
- Byte 19: 32-bit pointer to start of hardware SLR2 (optional slave) replacement data, byte 3 (most significant byte)
- Byte 20: 32-bit pointer to start of hardware SLR2 (optional slave) essential bit data, byte 0 (least significant byte)
- Byte 21: 32-bit pointer to start of hardware SLR2 (optional slave) essential bit data, byte 1
- Byte 22: 32-bit pointer to start of hardware SLR2 (optional slave) essential bit data, byte
   2
- Byte 23: 32-bit pointer to start of hardware SLR2 (optional slave) essential bit data, byte 3 (most significant byte)
- Byte 24: 32-bit pointer to start of hardware SLR3 (optional slave) replacement data, byte 0 (least significant byte)
- Byte 25: 32-bit pointer to start of hardware SLR3 (optional slave) replacement data, byte 1
- Byte 26: 32-bit pointer to start of hardware SLR3 (optional slave) replacement data, byte 2
- Byte 27: 32-bit pointer to start of hardware SLR3 (optional slave) replacement data, byte 3 (most significant byte)
- Byte 28: 32-bit pointer to start of hardware SLR3 (optional slave) essential bit data, byte 0 (least significant byte)
- Byte 29: 32-bit pointer to start of hardware SLR3 (optional slave) essential bit data, byte
   1
- Byte 30: 32-bit pointer to start of hardware SLR3 (optional slave) essential bit data, byte
   2
- Byte 31: 32-bit pointer to start of hardware SLR3 (optional slave) essential bit data, byte 3 (most significant byte)
- Remaining bytes are reserved, filled with ones

A pointer value of 0xFFFFFFFF is used if a particular block of data is not present. The essential bit data and replacement data can be located at any addresses provided each data block is contiguous and it is possible to perform a read burst through each data block. For SPI Flash that does not support read burst across device boundaries, data blocks must be located so that they do not straddle any of these device boundaries. For example, many SPI Flash of a density greater than 256 Mbit do not allow read burst across 256 Mbit boundaries.

The TCL script, which post processes the bitgen output files, generates three outputs:

- An Intel hex data file (MCS) for programming SPI Flash devices
- A raw binary data file (BIN) for programming SPI Flash devices
- An initialization file (VMF) for loading SPI Flash simulation models

### Simulation

Simulation of designs that instantiate the controller is supported. In other words, including the controller in a larger project does not adversely affect ability to run simulations of functionality unrelated to the controller. However, it is not possible to observe the controller behaviors in simulation. Simulation of a design including the controller will compile, but the controller will not exit the initialization state.

Hardware-based evaluation of the controller behaviors is required.



# SECTION III: ISE DESIGN SUITE

Customizing and Generating the Core Constraining the Core Detailed Example Design



# Customizing and Generating the Core

This chapter includes information about using Xilinx tools to customize and generate the core in the ISE® Design Suite environment.

### **Creating a Project**

First, create a project using the Xilinx CORE Generator software. For detailed information on starting and using the CORE Generator software, see the Xilinx CORE Generator User Guide. Perform the following steps:

- 1. Start the CORE Generator software.
- 2. Choose File > New Project from the menu.
- 3. Using the file requestor dialog box:
  - a. Navigate to the desired project directory.
  - b. Modify the project file name, if desired.
  - c. Click Save.
- 4. Set the Part Options in the Project Options dialog box:
  - a. Select the target family, device, package, and speed grade.

Example: Kintex-7, xc7k325t-ffg900-1

*Note:* If an unsupported family is selected, the IP core will not appear in the IP Catalog.

- b. Click Apply.
- 5. Set the Generation Options in the Project Options dialog box:
  - a. For Flow, select Design Entry in either VHDL or Verilog.
  - b. For Flow Settings, select either ISE (for XST) or Synplicity (for Synplify Pro).
  - c. Click **Ok**.

After creating the project, the IP core will be available for selection in the IP Catalog, located at **FPGA Features and Design > Soft Error Mitigation > Soft Error Mitigation**.

### **Customizing and Generating the Core**

Locate the IP core in the IP Catalog and click it once to select it. Important information regarding the solution is displayed in the main window. Review this information before proceeding.

In the Actions section of the main window, click the Customize and Generate link. This launches page one of the solution customization dialog box, shown in Figure 7-1.

| w Documents                                                                                                                                                                                                                 |                                                                                                                                                                                                     |                                                                                                      |                    |            |                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------|------------|-------------------|
| IP Sym                                                                                                                                                                                                                      | bol                                                                                                                                                                                                 | logicere Soft                                                                                        | Error M            | litigation | xilinx.com:ip:sem |
|                                                                                                                                                                                                                             |                                                                                                                                                                                                     | Component Name sem_                                                                                  |                    |            |                   |
| INJECT_STROBE $\rightarrow$<br>INJECT_ADDRESS[39:0] $\rightarrow$<br>ICAP_0[31:0] $\rightarrow$<br>ICAP_CSIB<br>ICAP_CSIB<br>ICAP_CSIB<br>ICAP_GRANT $\rightarrow$<br>ICAP_GRANT $\rightarrow$<br>ICAP_GRQUEST $\leftarrow$ | STATUS_HEARTBEAT  STATUS_INITIALIZATION  STATUS_OBSERVATION  STATUS_CORRECTION  STATUS_CLASSIFICATION  STATUS_INJECTION  STATUS_UNCORRECTABLE  MONITOR_TXDATA[7:0]  MONITOR_TXWRITE  MONITOR_TXFULL | Controller Options<br>E Enable Error Injecti<br>E Enable Error Correction Met<br>e Repair<br>Replace | on<br>:tion<br>hod |            |                   |
| $fecc_crcerr \longrightarrow$<br>$fecc_eccerr \longrightarrow$                                                                                                                                                              | $ \longrightarrow MONITOR_RXDATA[7:0] $                                                                                                                                                             | Controller Clock Frequ                                                                               | ency 8             |            | MHz               |
| FECC_ECCERRSINGLE                                                                                                                                                                                                           | ← MONITOR_RXEMPTY<br>→ FETCH_TXDATA[7:0]<br>→ FETCH_TXWRITE                                                                                                                                         | System Level Design<br>Error Injection Shim                                                          | Example Options    | pins       |                   |
| FECC_FAR[25:0] →<br>FECC_SYNBIT[4:0] →<br>FECC_SYNWORD[8:0] →                                                                                                                                                               | - FETCH_TXFULL<br>FETCH_RXDATA[7:0]<br>FETCH_RXREAD<br>FETCH_RXEMPTY<br>FETCH_TBLADDR[31:0]                                                                                                         | Data Retrieval Shim                                                                                  |                    | none       | <b>•</b>          |
|                                                                                                                                                                                                                             |                                                                                                                                                                                                     |                                                                                                      |                    |            |                   |

Figure 7-1: Solution Customization Dialog Box Page 1

Review each of the available options, and modify them as desired so that the SEM Controller solution meets the requirements of the larger project into which it will be integrated. The following sub-sections discuss the options in detail to serve as a guide.

#### **Component Name and Symbol**

The name of the generated component is set by the Component Name field. The name "sem\_v3\_4" is used in this example.

The Component Symbol occupies the left half of the dialog box and provides a visual indication of the ports that will exist on the component, given the current option settings. Ports that will be generated are drawn in black. This diagram is automatically updated when the option settings are modified.

### **Controller Options: Enable Error Injection**

The Enable Error Injection checkbox is used to enable or disable the error injection feature. Error injection is a design verification function that provides a mechanism for users to create errors in Configuration Memory that model a soft error event. This is useful during integration or system level testing to verify that the controller has been properly interfaced with system supervisory logic and that the system responds as desired when a soft error event occurs.

If error injection is enabled, the Error Injection Interface is generated (as indicated by the Component Symbol) and the controller performs error injections in response to commands from the user. These commands can be applied to the Error Injection Interface or to the Monitor Interface.

If error injection is disabled, the Error Injection Interface is removed (as indicated by the Component Symbol) and the controller will not perform any error injections. Note that the Monitor Interface continues to exist even if the Error Injection Interface is removed. If error injection commands are applied to the Monitor Interface, the controller parses the commands but otherwise ignore them.

### **Controller Options: Enable Error Correction**

The Enable Error Correction checkbox is used to enable or disable the error correction feature. No matter what setting is used, the controller monitors the error detection circuits and reports error conditions.

If error correction is enabled, the controller attempts to correct errors that are detected. The method by which corrections are performed is selectable. Most errors are correctable, and upon successful correction, the controller signals that a correctable error has occurred and was corrected. For errors that are not correctable, the controller signals that an uncorrectable error has occurred.

If error correction is disabled, the controller does not attempt to correct errors. At the first error event, the controller stops scanning after reporting the error condition. Further, when error correction is disabled, the error classification feature is also disabled.

### **Controller Options: Error Correction Method**

With error correction enabled, the error correction method is selectable. The available methods are correction by repair, correction by enhanced repair, and correction by replace.

The controller corrects errors using the method selected by the user. The correction possibilities are:

Correction by Repair

• Correction by repair for one-bit errors. The ECC syndrome is used to identify the exact location of the error in a frame. The frame containing the error is read, the relevant bit inverted, and the frame is written back. This is signaled as correctable.

#### Correction by Enhanced Repair

• Correction by repair for one-bit and two-bit adjacent errors. For one-bit errors, the behavior is identical to correction by repair. For two-bit errors, an enhanced CRC-based algorithm capable of correcting two-bit adjacent errors is used. The frame containing the error is read, the relevant bits inverted, and the frame is written back. This is signaled as correctable.

#### Correction by Replace

• Correction by replace for one-bit and multi-bit errors. The frame containing the error is read. The controller requests replacement data for the entire frame from the Fetch Interface. When the replacement data is available, the controller compares the damaged frame with the replacement frame to identify the location of the errors. Then, the replacement data is written back. This is signaled as correctable.

The difference between repair, enhanced repair, and replace methods becomes clear when considering what happens in the uncommon case of errors involving more bits than can be corrected by the repair or enhanced repair methods. In these cases, the repair or enhanced repair methods will not yield a successful correction. However, if such errors are corrected by the replace method, the error is correctable regardless of how many bits were affected.

The fundamental trade-off between the methods is error correction success rate versus the cost of adding or increasing data storage requirements. Using correction by repair as the baseline for comparison:

- Correction by enhanced repair provides superior correction capability through use of additional Block RAM to store frame-level CRCs.
- Correction by replace provides ultimate correction capability through the addition of external SPI Flash to store "golden" frame replacement data.

EasyPath devices are not compatible with the error correction by replace method.

### **Controller Options: Enable Error Classification**

The Enable Error Classification checkbox is used to enable or disable the error classification feature. Error classification is automatically disabled if error correction is disabled.

www.xilinx.com



132

 $\bigcirc$ 

The error classification feature uses the Xilinx Essential Bits technology to determine whether a detected and corrected soft error has affected the function of a user design. Essential Bits are those bits that have an association with the circuitry of the design. If an Essential Bit changes, it changes the design circuitry. However it may not necessarily affect the function of the design.

Without knowing which bits are essential, the system must assume any detected soft error has compromised the correctness of the design. The system level mitigation behavior often results in disruption or degradation of service until the FPGA configuration is repaired and the design is reset or restarted.

For example, if bitgen reports that 20% of the Configuration Memory is essential to an operation of a design, then only 2 out of every 10 soft errors (on average) actually merits a system-level mitigation response. The error classification feature is a table lookup to determine if a soft error event has affected essential Configuration Memory locations. Use of this feature reduces the effective FIT of the design. The cost of enabling this feature is the external storage required to hold the lookup table. When error classification is enabled, the Fetch Interface is generated (as indicated by the Component Symbol) so that the controller has an interface through which it can retrieve external data.

If error classification is enabled, and a detected error has been corrected, the controller will look up the error location. Depending on the information in the table, the controller will either report the error as essential or non-essential. If a detected error cannot be corrected, this is because the error cannot be located. Therefore, the controller conservatively reports the error as essential because it has no way to look up data to indicate otherwise.

If error classification is disabled, the controller unconditionally reports all errors as essential because it has no data to indicate otherwise.

**TIP:** Note that error classification need not be performed by the controller. It is possible to disable error classification by the controller, and implement it elsewhere in the system using the essential bit data provided by the implementation tools and the error report messages issued by the controller through the Monitor Interface.

### **Controller Options: Controller Clock Frequency**

The controller clock frequency is set by the Clock Frequency field. The error mitigation time decreases as the controller clock frequency increases. Therefore, the frequency should be as high as practical. The dialog box warns if the desired frequency exceeds the capability of the target device.

For designs that require a data retrieval interface to fetch external data for error classification or error correction by replace, an additional consideration exists. The example design implements an external memory interface that is synchronous to the controller. The controller clock frequency therefore also determines the external memory cycle time.

The external memory system must be analyzed to determine its minimum cycle time, as it can limit the maximum controller clock frequency.

Instructions on how to perform this analysis are located in Interfaces in Chapter 3. However, this analysis requires timing data from implementation results. Therefore, Xilinx recommends the following:

- 1. Generate the solution using the desired frequency setting.
- 2. Extract the required timing data from the implementation results.
- 3. Complete the timing budget analysis to determine maximum frequency.
- 4. Re-generate the solution with a frequency at or below the calculated maximum frequency of operation.

#### Controller Options: Enable Scanning of GT Row(s) (Spartan-6 LXT Devices)

When targeting a Spartan-6 LXT device, an additional set of controller options is available to enable or disable SEU scanning of the configuration memory rows that include GT. The solution customization dialog box for these devices is shown in Figure 7-2.

| ew Documents<br>IP Symt                                                                                                                                              | bol                                                                                                                                                                                                                                                                                                                                               | logicie Soft Error                                                                                                                                                                                                                                                                     | Mitigation                                             |     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-----|
| INJECT_STROBE →<br>INJECT_ADDRESS[35:0] →<br>ICAP_BUSY →<br>ICAP_CISC] →<br>ICAP_CLK →<br>ICAP_CSB ←<br>ICAP_CSB ←<br>ICAP_GRANT →<br>ICAP_GRANT →<br>ICAP_REQUEST ← | → STATUS_HEARTBEAT<br>→ STATUS_INITIALIZATION<br>→ STATUS_OBSERVATION<br>→ STATUS_CORRECTION<br>→ STATUS_CLASSIFICATION<br>→ STATUS_UNCORRECTABLE<br>→ MONITOR_TXDATA[7:0]<br>→ MONITOR_TXDATA[7:0]<br>→ MONITOR_RXREAD<br>← MONITOR_RXREAD<br>← MONITOR_RXREAD<br>← FETCH_TXDATA[7:0]<br>→ FETCH_TXDATA[7:0]<br>→ FETCH_RXREAD<br>← FETCH_RXREAD | Component Name sem_v3_4 Soft Error Mitigation IP Solution Option Controller Options Enable Error Correction Error Correction Method Repair Replace Enable Error Classification Controller Clock Frequency 8 Enable Scanning of GT Row(s) Top GT Row System Level Design Example Option | Refer to the SEM Product Guide<br>for more information | MHz |
|                                                                                                                                                                      | FETCH_TBLADDR[310]                                                                                                                                                                                                                                                                                                                                | Error Injection Shim<br>Data Retrieval Shim                                                                                                                                                                                                                                            | pins<br>none                                           | •   |

Figure 7-2: Solution Customization Dialog Box Page 1 (Spartan-6 LXT Devices)



**IMPORTANT:** Scanning the GT rows in these devices is disabled by default. Xilinx highly recommends that this feature remain disabled if the GTs in these rows are actively used. For more information, see <u>Answer Record 52716</u> and Spartan-6 Configuration User Guide (UG380) [Ref 4].

#### **Example Design Options: Error Injection Shim**

For customizations that include error injection, the example design provides two options for a shim to external control of the Error Injection Interface:

- Direct control through physical pins
- Indirect control through JTAG using Xilinx ChipScope tool

When selecting ChipScope analyzer to control the Error Injection Interface, the ChipScope tool ICON and ChipScope tool VIO cores are not included. They must be generated (separately) with their output products placed in the example design directory. The necessary ChipScope tool core settings are described at the end of this chapter.

### **Example Design Options: Data Retrieval Shim**

For customizations that require a data retrieval interface to fetch external data for error classification or error correction by replace, the controller Fetch Interface must be bridged to an external storage device. The example design provides a shim to an external SPI Flash device as the only option. If the data retrieval interface is not required, no shim is generated.

#### **Reviewing the Customizations**

Proceed to page two of the of the solution customization dialog box by clicking Next. This page is shown in Figure 7-3 and Figure 7-4.

| ew Documents        |                                             |                          |                                    |                           |
|---------------------|---------------------------------------------|--------------------------|------------------------------------|---------------------------|
| IP Sym              | bol                                         | LogiCRE                  | Soft Error Mitig                   | ation xilinx.com:ip:sem:  |
|                     |                                             | Component                | Name                               | sem_v3_                   |
|                     |                                             | _Soft Error M            | litigation IP Solution Summary ——— |                           |
|                     | → STATUS_HEARTBEAT                          | Controller<br>Error Inje | - Summary                          | Enabled                   |
| <br>ICAP_0[31:0] →  | → STATUS_OBSERVATION<br>→ STATUS_CORRECTION | Error Cor                | rection                            | Enabled:<br>Repair Errors |
| ICAP_CLK            |                                             | Error Clas               | sification                         | Disabled                  |
| ICAP_CSIB           | STATUS_INJECTION                            | Data Retri               | ieval Port                         | Disabled                  |
| ICAP_RDWRB          |                                             | Controller               | r Clock Frequency                  | 8 MHz                     |
| ICAP_I[31:0] ←      | MONITOR_TXDATA[7:0]                         |                          |                                    |                           |
| ICAP_GRANT          |                                             | -System L                | evel Design Example Summary        |                           |
| ICAP_REQUEST        |                                             |                          |                                    |                           |
| FECC_ECCERR         | MONITOR_RXREAD                              |                          | ction Shim                         | Pins                      |
|                     | - MONITOR_RXEMPTY                           | Data Retri               | ieval Shim                         | None                      |
| FECC_SYNDROMEVALID  | FETCH_TXDATA[7:0]                           | Data Retri               | eval Frequency                     | Not Applicable            |
| FECC_SYNDROME[12:0] | FETCH_TXWRITE                               |                          |                                    |                           |
| FECC_FAR[25:0]      | - FETCH_TXFULL                              |                          |                                    |                           |
| FECC_SYNBIT[4:0]    | FETCH_RXDATA[7:0]                           |                          |                                    |                           |
| FECC_SYNWORD[6:0]   | FETCH_RXREAD     FETCH_RXEMPTY              |                          |                                    |                           |
|                     | FETCH_TBLADDR[31:0]                         |                          |                                    |                           |
|                     |                                             |                          |                                    |                           |
|                     |                                             |                          |                                    |                           |
|                     |                                             |                          |                                    |                           |
|                     |                                             |                          |                                    |                           |

*Figure 7-3:* Solution Customization Dialog Box Page 2

| 💐 Soft Error Mitigation |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                |                   | _ ×                                                                                                                                                                     |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>V</u> iew Documents  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                |                   |                                                                                                                                                                         |
|                         | STATUS_HEARTBEAT  STATUS_INITALIZATION  STATUS_OBSERVATION  STATUS_CORRECTION  STATUS_CLASSIFICATION  STATUS_LLASSIFICATION  STATUS_UNCORRECTABLE  MONITOR_TXADATA[7:0]  MONITOR_TXFULL  MONITOR_TXRUTE  MONITOR_RXREAD  MONI | Component Nam<br>Soft Error Mitig<br>Controller Sur<br>Error Injection<br>Error Correct<br>Error Classific<br>Data Retrieva<br>Controller Clo<br>Scan GT Row( | ne<br>ation IP Solution Summ<br>mmary<br>n<br>ion<br>cation<br>I Port<br>ock Frequency<br>(s)<br>Design Example Summ<br>n Shim |                   | xilinx.com:ip:sem:3.4<br>sem_v3_4<br>Enabled<br>Enabled:<br>Repair Errors<br>Disabled<br>Disabled<br>8 MHz<br>Disabled: Top Row<br>Disabled: Bottom Row<br>Pins<br>None |
|                         | FETCH_TXWRITE      FETCH_TXFULL      FETCH_RXDATA[7:0]      FETCH_RXDATA[7:0]      FETCH_RXREAD      FETCH_RXREAFFY      FETCH_TBLADDR[310]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Data Retrieva                                                                                                                                                 |                                                                                                                                | of 2 Next > Gener | Not Applicable                                                                                                                                                          |

Figure 7-4: Solution Customization Dialog Box Page 2 (Spartan-6 LXT Devices)

Review the summary to confirm each option is correct. Return to the previous page, if necessary, to correct or change options prior to generation. After the options are reviewed and correct, proceed to generate the solution.

#### **Generating the Solution**

Click **Generate** to begin the generation process. The CORE Generator software will generate and deliver a customized solution based on the provided option settings. When this process has completed, a final dialog box with important information regarding the solution will appear. Review this information before exiting the CORE Generator software to review the delivered files.

### **Output Generation**

The directory contents are the same as the files shown in Directory and File Contents in Chapter 9.

### **Generating and Using ChipScope Tool Files**

This section describes requirements for ChipScope tool files necessary to support the optional error injection feature in the specific customizations where the ChipScope tool is selected as the error injection shim.

#### **ChipScope Tool Files for 7 Series FPGAs**

The ChipScope tool ICON core must be generated for the target device, using the default core name "chipscope\_icon", with the following parameters:

```
ENABLE_JTAG_BUFG = TRUE
NUMBER_CONTROL_PORTS = 1
USE_EXT_BSCAN = FALSE
USE_SOFTBSCAN= FALSE
USE_UNUSED_BSCAN = FALSE
```

The USER\_SCAN\_CHAIN can be set as desired. After the ICON core is generated, the chipscope\_icon.ngc and chipscope\_icon. {v|vhd} files must be copied to the example design directory.

For non-SSI devices, the ChipScope tool VIO core must be generated for the target device, using the default core name "chipscope\_vio", with the following parameters:

```
ENABLE_ASYNCHRONOUS_INPUT_PORT = FALSE
ENABLE_ASYNCHRONOUS_OUTPUT_PORT = FALSE
ENABLE_SYNCHRONOUS_INPUT_PORT = TRUE
ENABLE_SYNCHRONOUS_OUTPUT_PORT = TRUE
INVERT_CLOCK_INPUT = FALSE
SYNCHRONOUS_INPUT_PORT_WIDTH = 8
SYNCHRONOUS_OUTPUT_PORT_WIDTH = 41
```

After the VIO core is generated, chipscope\_vio.ngc and chipscope\_vio.{v|vhd} files must be copied to the example design directory. The instantiation and interconnection of the ICON and VIO components inside the HID shim can be inspected, if desired. The mapping of the VIO synchronous input and synchronous output ports is:

```
sync_in[7] receives status_heartbeat
sync_in[6] receives status_uncorrectable
sync_in[5] receives status_essential
sync_in[4] receives status_injection
sync_in[3] receives status_classification
sync_in[1] receives status_observation
sync_in[0] receives status_initialization
sync_out[40] drives inject_strobe
sync_out[39:0] drives inject_address[39:0]
```

#### ChipScope Tool Files for Virtex-6 and Spartan-6 FPGAs

The ChipScope ICON core must be generated for the target device, using the default core name "chipscope\_icon", with the following parameters:

```
ENABLE_JTAG_BUFG = TRUE
NUMBER_CONTROL_PORTS = 1
USE_EXT_BSCAN = FALSE
USE_SOFTBSCAN= FALSE
USE_UNUSED_BSCAN = FALSE
```

The USER\_SCAN\_CHAIN can be set as desired. After the ICON core is generated, the  $chipscope_icon.ngc$  and  $chipscope_icon.{v|vhd}$  files must be copied to the example design directory.

The ChipScope tool VIO core must be generated for the target device, using the default core name "chipscope\_vio", with the following parameters:

ENABLE\_ASYNCHRONOUS\_INPUT\_PORT = FALSE ENABLE\_ASYNCHRONOUS\_OUTPUT\_PORT = FALSE ENABLE\_SYNCHRONOUS\_INPUT\_PORT = TRUE ENABLE\_SYNCHRONOUS\_OUTPUT\_PORT = TRUE INVERT\_CLOCK\_INPUT = FALSE SYNCHRONOUS\_INPUT\_PORT\_WIDTH = 9 SYNCHRONOUS\_OUTPUT\_PORT\_WIDTH = 37

After the VIO core is generated, chipscope\_vio.ngc and chipscope\_vio.{v|vhd} files must be copied to the example design directory.

The instantiation and interconnection of the ICON and VIO components inside the HID shim can be inspected, if desired. The mapping of the VIO synchronous input and synchronous output ports is:

```
sync_in[8] is reserved, and is tied low
sync_in[7] receives status_heartbeat
sync_in[6] receives status_uncorrectable
sync_in[5] receives status_essential
sync_in[4] receives status_injection
sync_in[3] receives status_classification
sync_in[2] receives status_correction
sync_in[1] receives status_observation
sync_in[0] receives status_initialization
sync_out[36] drives inject_strobe
sync_out[35:0] drives inject_address[35:0]
```

### Using ChipScope Analyzer

A project must be created in the ChipScope Analyzer software. The status signals received by the synchronous input port should be represented with LEDs. The inject\_address output value should be represented as HEX for data entry. The inject\_strobe control output must be represented as a three-cycle PULSE output for proper operation.

## **Integration and Validation**

In the development of a complex system, early integration and continual validation of major functional blocks and interfaces is an important best practice. Significant design changes near the end of the development cycle (late integration) or postponing system performance measurements (late validation) increase risk.

Include integration and validation milestones in your project planning and support them with a plan to confirm system functionality and performance throughout the development cycle. Starting as early as possible and incrementally including as much functionality as practical provides the most time for system evaluation under representative workloads. This recommendation complements the commonly used bottom-up design approach, facilitating design reuse and IP-based design.<sup>(1)</sup>

### Integration of the SEM IP Core

The SEM IP core has a small programmable logic footprint, but activates the programmable logic configuration memory system. The configuration memory system works much like a conventional SRAM, except that it is physically distributed throughout the programmable logic array. Just like all other digital switching activity in the device, activity in the configuration memory system generates power noise.

In all device families supported by the SEM IP core, the power noise contribution from the configuration memory system is minor, provided all implementation requirements and design guidance is observed.

**RECOMMENDED:** Xilinx strongly recommends system designers integrating the SEM IP core to use the current version and to keep current with the SEM IP core design advisories and known issues through Xilinx Answer Records for Soft Error Mitigation IP Solutions.

Integrate the SEM IP core as early as possible, ideally at the start of the project. Because the SEM IP core can automatically initialize, the first pass integration of this core can be as simple as instantiating it, connecting a clock, and adding tie-offs to other input ports. As part of this early infrastructure, Xilinx recommends implementing the SEM IP core provisioning controls to allow the system to enable/disable the SEM IP core clock and enable/disable the SEM IP core provides deployment flexibility and also facilitates debug of the SEM IP core integration.

At a later point, the integration can be expanded through definition and implementation of an interface for command/status exchange between the system and the SEM IP core. The preferred method for this uses ASCII communication over the SEM IP core Monitor

<sup>1.</sup> See Comprehensive Full-Chip Methodology to Verify EM and Dynamic Voltage Drop on High Performance FPGA Designs in the 20nm Technology presented at DesignCon 2014 [Ref 7].

Interface, either with the UART helper block for a serial connection, or without the UART helper block for a parallel connection using communication FIFOs.

Although the status exchange alone is adequate for the system to log and parse events reported by the SEM IP core, the command exchange is critical to support error injection. Without error injection, there is no practical way to completely test the integration of the SEM IP core and the system response to the SEM IP core event reports, outside of an accelerated particle test at a radiation effects facility. Error injection can also be useful for a minor aspect of continual validation.

### Validation with the SEM IP Core

In a deployed system containing the SEM IP core, the configuration memory system activity is a mix of reads and writes during the SEM IP core initialization state. Afterward the activity is 100% reads during the observation state to perpetually scan the configuration memory for single event upsets. Given the exceptionally low upset rate of the Xilinx configuration memory in a terrestrial environment (that is, mean time between upset is decades at sea level in NYC), the SEM IP core rarely transitions out of the Observation state into the Correction state during which writes can take place.

Continual validation of a system containing the SEM IP core should use a representative SEM IP core workload to ensure validation results will be representative of the system in deployment. Provided the system provisions the SEM IP core to complete the Initialization and enter the Observation state, the default workload of configuration memory scanning with no upsets is not only the easiest, but also representative for validation.

If desired, the SEM IP core error injection feature can be used to incorporate an occasional error detection and correction into the workload.



**IMPORTANT:** Xilinx does not recommend "stress testing" with high rate error injection to generate a large number of error detection and correction events, as this stimulus is unnatural and can yield validation results that are irrelevant to reliable operation of the system.

Continual validation of the system should extend beyond the research and development phase into production testing. With the SEM IP core, this requires little to no additional effort, as the system provisioning during production testing need to only enable the SEM IP core.



# Constraining the Core

### **Required Constraints**

The SEM Controller and the system-level design example require the specification of physical implementation constraints to yield a functional result that meets performance requirements. These constraints are provided with the system-level design example in a user constraints file (UCF).

To achieve consistent implementation results, the UCF provided with the solution must be used. For additional details on the definition and use of a UCF or specific constraints, see the Constraints Guide available through the <u>documentation page for the ISE Design Suite</u>.

Constraints may require modification to integrate the solution into a larger project, or as a result of changes made to the system-level design example. Modifications should only be made with a thorough understanding of the effect of each constraint. Additionally, support is not provided for designs that deviate from the provided constraints.

### **Contents of the User Constraints File**

Although the UCF delivered with each generated solution shares the same overall structure and sequence of constraints, the contents may vary based on options set at generation. The sections that follow define the structure and sequence of constraints using a Virtex-6 device implementation as an example.

#### **Device Selection Constraint**

The first section of the UCF specifies the device for the implementation tools to target, including the part, package, and speed grade. The device in the UCF reflects the device chosen in the CORE Generator software project. An example device selection constraint is:

```
CONFIG PART = XC6VLX240T-FF1156-1 ;
```

Although the controller itself is designed to function in any of the supported devices, some details of the system-level example design depend on the selected part. For this reason, this

constraint should not be modified. To target a different device, return to the CORE Generator software project, change the device, and re-generate the solution.

#### **Controller Constraints**

The controller, considered in isolation and regardless of options at generation, is a fully synchronous design. Fundamentally, it only requires a clock period constraint on the master clock input. In the generic UCF, this constraint is placed on the system-level design example clock input and propagated into the controller. The constraint is discussed in Example Design Constraints.

The signal paths between the controller and the FPGA configuration system primitives must be considered as synchronous paths. By default, the paths between the ICAP primitive and the controller are analyzed as part of a clock period constraint on the master clock, because the ICAP clock pin is required to be connected to the same master clock signal.

However, the situation is different for the FRAME\_ECC primitive (when present), as it does not have a clock pin. Based on the specific use of the FRAME\_ECC primitive with the ICAP primitive, it is known that FRAME\_ECC primitive pins are synchronous to the master clock signal. Therefore, additional constraints with values derived from the clock period constraint are added:

```
INST "example_cfg/example_frame_ecc" TPSYNC = FECC_SPECIAL;
TIMESPEC "TS_FECC_SYNC" = FROM "FECC_SPECIAL" TO FFS(*) 7000 ps;
TIMESPEC "TS_FECC_PADS" = FROM "FECC_SPECIAL" TO PADS(*) 20000 ps;
```

### **Example Design Constraints**

The example design constraints are organized by interface, rather than constraint type. The first group is for the master clock input to the entire design. It applies an I/O standard and a period constraint. The period constraint value is based on options set at generation:

```
NET "clk" IOSTANDARD=LVCMOS25 | PERIOD=10000 ps;
```

The second group is for the Status Interface, applying an I/O standard and time name, so that an output timing constraint can be applied to the interface. The output timing constraint is set at two times the period constraint.

```
NET "status_initialization" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_observation" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_correction" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_classification" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_injection" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_uncorrectable" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_essential" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_essential" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
NET "status_heartbeat" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=STAPINS;
```

```
TIMEGRP "STAPINS" OFFSET = OUT 20000 ps AFTER "clk";
```

The third group is for the MON shim, applying an I/O standard and time name, so that input and output timing constraints can be applied to the interface. The input and output timing constraints are set at two times the period constraint.

```
INST "example_mon/example_mon_sipo/sync_reg" IOB = TRUE;
INST "example_mon/example_mon_piso/pipeline_serial" IOB = TRUE;
NET "monitor_tx" IOSTANDARD=LVCMOS25 | DRIVE=4 | SLEW=SLOW | TNM=SERPINS;
NET "monitor_rx" IOSTANDARD=LVCMOS25 | TNM=SERPINS;
TIMEGRP "SERPINS" OFFSET = IN 20000 ps VALID 40000 ps BEFORE "clk";
TIMEGRP "SERPINS" OFFSET = OUT 20000 ps AFTER "clk";
```

The following group is for the EXT shim, and is only present when the EXT shim is generated based on options set at generation. It applies an I/O standard and time name, so that input and output timing constraints can be applied to the interface. The input and output timing is of considerable importance, as the actual timing must be used in the analysis of the SPI bus timing budget. However, there is no hard requirement for the input and output timing of the FPGA implementation. It varies based on the selected device and speed grade.

As such, the input and output timing constraints are arbitrarily set at two times the period constraint. The additional constraint to use IOB flip-flops yields substantially better input and output timing than the constraint values suggest. It is the actual timing obtained from the timing report that should be used in the analysis of the SPI bus timing budget, not the constraint value.

```
INST "example_ext/example_ext_byte/ext_c_ofd" IOB = TRUE;
INST "example_ext/example_ext_byte/ext_d_ofd" IOB = TRUE;
INST "example_ext/example_ext_byte/ext_q_ifd" IOB = TRUE;
INST "example_ext/ext_s_ofd" IOB = TRUE;
NET "external_c" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_d" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_s_n" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_s_n" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_g" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_q" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_q" IOSTANDARD=LVCMOS25 | DRIVE=8 | SLEW=FAST | TNM=SPIPINS;
NET "external_q" IOSTANDARD=LVCMOS25 | TNM=SPIPINS ;
TIMEGRP "SPIPINS" OFFSET = IN 20000 ps VALID 40000 ps BEFORE "clk";
TIMEGRP "SPIPINS" OFFSET = OUT 20000 ps AFTER "clk";
```

The following group is for the HID shim, and is only present when the HID shim is I/O Pins. It applies an I/O standard and time name, so that an input timing constraint can be applied to the interface. The input timing constraint is set at two times the period constraint.

```
NET "inject_strobe" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[0]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[1]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[2]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[3]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[4]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[5]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[6]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[6]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[6]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[7]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[8]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[8]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[9]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
```

```
NET "inject_address[10]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[11]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[12]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[13]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[14]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[15]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[16]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[17]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[18]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[19]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[20]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[21]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[22]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[23]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[24] " IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[25]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[26]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[27]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[28]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[29]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[30]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[31]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[32]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[33]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[34]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
NET "inject_address[35]" IOSTANDARD=LVCMOS25 | TNM=INJPINS;
```

```
TIMEGRP "INJPINS" OFFSET = IN 20000 ps VALID 40000 ps BEFORE "clk";
```

The following constraints in the UCF implement an area group to place portions of the system-level design example into a bounded region of the selected device. The instances included in the area group depend on the options set at generation. The range values vary depending on device selection. The area group is defined so that component packing is closed to resources from outside the group, but the unused component locations are open to placement of unrelated logic.

The area group forces packing of the soft error mitigation logic into an area physically adjacent to the ICAP site in the device. Most importantly, this maintains reproducibility in timing results. It also improves resource usage; the area group forces tighter packing and generates a resource usage summary that is helpful in estimating the FIT of the system-level design example.

```
INST "example_wrapper/*" AREA_GROUP = "SEM_CONTROLLER" ;
INST "example_mon/*" AREA_GROUP = "SEM_CONTROLLER" ;
INST "example_ext/*" AREA_GROUP = "SEM_CONTROLLER" ;
AREA_GROUP "SEM_CONTROLLER" RANGE = SLICE_X84Y115:SLICE_X99Y124 ;
AREA_GROUP "SEM_CONTROLLER" RANGE = RAMB18_X4Y46:RAMB18_X4Y49 ;
AREA_GROUP "SEM_CONTROLLER" GROUP = CLOSED ;
AREA_GROUP "SEM_CONTROLLER" PLACE = OPEN ;
```

If targeting a Spartan-6 LXT device in which a GT row is excluded from the scan coverage, Xilinx advises that a PROHIBIT constraint should be placed on this region to achieve the best coverage. As an example, if a GT is used in the top row of a Spartan-6 LX45T device, the PROHIBIT constraint to minimize placement in this row is the following:

```
PROHIBIT = SITE "SLICE_X0Y125:SLICE_X159Y112";
```

The final constraints in the UCF are a template for assigning I/O pin locations to the top-level ports of the system-level example design. These assignments are necessarily board-specific and therefore cannot be automatically generated. To apply these constraints, uncomment them and fill in valid I/O pin locations for the target board.

```
## NET "clk" LOC = " ";
## NET "external_c" LOC = " " ;
## NET "external_d" LOC = " ";
## NET "external_q" LOC = " ";
## NET "external_s_n" LOC = " ";
## NET "monitor_tx" LOC = " ";
## NET "monitor_rx" LOC = " ";
## NET "status_initialization" LOC = " ";
## NET "status_observation" LOC = " ";
## NET "status_correction" LOC = " ";
## NET "status_classification" LOC = " ";
## NET "status_injection" LOC = " ";
## NET "status_uncorrectable" LOC = " ";
## NET "status_essential" LOC = " ";
## NET "status_heartbeat" LOC = " ";
## NET "inject_strobe" LOC = " ";
## NET "inject_address[0]" LOC = "";
## NET "inject_address[1]" LOC = "";
## NET "inject_address[2]" LOC = "";
## NET "inject_address[3]" LOC = "";
## NET ``inject_address[4]" LOC = `` ";
## NET "inject_address[5]" LOC = "";
## NET "inject_address[6]" LOC = "";
## NET "inject_address[7]" LOC = "";
## NET "inject_address[8]" LOC = "";
## NET "inject_address[9]" LOC = "";
## NET "inject_address[10]" LOC = "";
## NET "inject_address[11]" LOC = "";
## NET "inject_address[12]" LOC = "";
## NET "inject_address[13]" LOC = "";
## NET "inject_address[14]" LOC = "";
## NET "inject_address[15]" LOC = " ";
## NET "inject_address[16]" LOC = " ";
## NET "inject_address[17]" LOC = "";
## NET "inject_address[18]" LOC = "";
## NET "inject_address[19]" LOC = "";
## NET "inject_address[20]" LOC = "";
## NET "inject_address[21]" LOC = "";
## NET "inject_address[22]" LOC = "";
## NET "inject_address[23]" LOC = "";
## NET "inject_address[24]" LOC = " ";
## NET "inject_address[25]" LOC = "";
## NET "inject_address[26]" LOC = " ";
## NET "inject_address[27]" LOC = " ";
## NET "inject_address[28]" LOC = "";
## NET "inject_address[29]" LOC = "";
## NET "inject_address[30]" LOC = " ";
```

| NET | "inject_address[31]" | LOC                                                                              | =                                                                                            | "                                                                                                       | ";                                                                                                                                                                              |
|-----|----------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NET | "inject_address[32]" | LOC                                                                              | =                                                                                            | w                                                                                                       | ";                                                                                                                                                                              |
| NET | "inject_address[33]" | LOC                                                                              | =                                                                                            | w                                                                                                       | ";                                                                                                                                                                              |
| NET | "inject_address[34]" | LOC                                                                              | =                                                                                            | w                                                                                                       | ";                                                                                                                                                                              |
| NET | "inject_address[35]" | LOC                                                                              | =                                                                                            | w                                                                                                       | ";                                                                                                                                                                              |
|     | NET<br>NET<br>NET    | NET "inject_address[32]"<br>NET "inject_address[33]"<br>NET "inject_address[34]" | NET "inject_address[32]" LOC<br>NET "inject_address[33]" LOC<br>NET "inject_address[34]" LOC | <pre>NET "inject_address[32]" LOC = NET "inject_address[33]" LOC = NET "inject_address[34]" LOC =</pre> | <pre>NET "inject_address[31]" LOC = " NET "inject_address[32]" LOC = " NET "inject_address[33]" LOC = " NET "inject_address[34]" LOC = " NET "inject_address[35]" LOC = "</pre> |

### Device, Package, and Speed Grade

There are no additional device, package or speed grade constraints.

## **Clock Frequency**

There are no additional clock frequency constraints.

### **Clock Management**

There are no additional clock management constraints.

### **Clock Placement**

There are no additional clock placement constraints.

# I/O Pins

This section contains details about I/O pins constraints.

#### I/O Standard

There are no additional I/O standard constraints.

#### I/O Banking

There are no additional I/O banking constraints.

**E** XILINX.

#### I/O Placement

There are no additional I/O placement constraints.



# **Detailed Example Design**

This section overviews the function of the SEM Controller system-level design example and the interfaces it exposes. The system-level design example encapsulates the controller and various shims that serve to interface the controller to other devices. These shims can include I/O Pins, ChipScope, I/O Interfaces, Memory Controllers, or application-specific system management interfaces.

The system-level design example is verified along with the controller. As delivered, the system-level design example is not a "reference design" but an integral part of the total solution. While users do have the flexibility to modify the system-level design example, the recommended approach is to use it as delivered.

### **Functions**

In addition to serving as an instantiation vehicle for the controller itself, the system-level design example incorporates five main functions:

- The FPGA configuration system primitives and their connection to the controller.
- The MON shim, a bridge between the controller and a standard RS-232 port. The resulting interface can be used to exchange commands and status with the controller. This interface is designed for connection to processors.
- The EXT shim, a bridge between the controller and a standard SPI bus. The resulting interface can be used to fetch data by the controller. This shim is only present in certain controller configurations and is designed for connection to standard SPI flash.
- The HID shim, a bridge between the controller and an interface device. The resulting interface can be used to exchange commands and status with the controller. This shim is only present in certain controller configurations.

Figure 9-1 shows a block diagram of the system-level design example. The blocks drawn in gray only exist in certain configurations.



Figure 9-1: Example Design Block Diagram

The system-level design example is provided to allow flexibility in system-level interfacing. To support this goal, the system-level design example is provided as RTL source code, unlike the controller itself.

### **Port Descriptions**

Figure 9-2 shows the example design ports. The ports are clustered into six groups. The groups shaded in gray only exist in certain configurations.



Figure 9-2: Example Design Ports

The system-level design example has no reset input or output. The controller automatically initializes itself. The controller then initializes the shims, as required.

The system-level design example is a fully synchronous design using clk as the single clock. All state elements are synchronous to the rising edge of this clock. As a result, the interfaces are generally synchronous to the rising edge of this clock.

#### **Status Interface**

The Status Interface is a direct pass-through from the controller. See Chapter 2, Status Interface for a description of this interface.

#### **Clock Interface**

The Clock Interface is used to provide a clock to the system-level design example. Internally, the clock signal is distributed on a global clock buffer to all synchronous logic elements.

Table 9-1: Clock Interface Details

| Name | Sense | Direction | Description                                                    |
|------|-------|-----------|----------------------------------------------------------------|
| clk  | EDGE  | In        | Receives the master clock for the system-level design example. |

#### **Monitor Interface**

The Monitor Interface is always present. The MON shim in the system-level design example is a UART. This shim serializes status information generated by the controller (a byte stream of ASCII codes) for serial transmission. Similarly, the shim de-serializes command information presented to the controller (a bitstream of ASCII codes) for parallel presentation to the controller.

The shim uses a standard serial communication protocol. The shim contains synchronization and over sampling logic to support asynchronous serial devices that operate at the same nominal baud rate. See Chapter 3, Designing with the Core for additional information.

The resulting interface is directly compatible with a wide array of devices ranging from embedded microcontrollers to desktop computers. External level translators may be necessary depending on system requirements.

| Table 9-2: | Monitor | Interface | Details |
|------------|---------|-----------|---------|
|------------|---------|-----------|---------|

| Name       | Sense | Direction | Description                                            |
|------------|-------|-----------|--------------------------------------------------------|
| monitor_tx | LOW   | Out       | Serial transmit data from system-level design example. |
| monitor_rx | LOW   | In        | Serial receive data to system-level design example.    |

#### **External Interface**

The External Interface is present when the controller requires access to external data. When present, the EXT shim in the system-level design example is a fixed-function SPI bus master. This shim accepts commands from the controller that consist of an address and a byte count. The shim generates SPI bus transactions to fetch the requested data from an external SPI flash. The shim formats the returned data for the controller to pick up.

The shim uses standard SPI bus protocol, implementing the most common mode (CPOL = 0, CPHA = 0, often referred to as "Mode 0"). The SPI bus clock frequency is locked to one half of the master clock for the system-level design example. See Chapter 3, Designing with the Core for information on external timing budgets.

The resulting interface is directly compatible with a wide array of standard SPI flash. External level translators may be necessary depending on system requirements.

| Name         | Sense | Direction | Description                                                      |
|--------------|-------|-----------|------------------------------------------------------------------|
| external_c   | EDGE  | Out       | SPI bus clock for an external SPI flash.                         |
| external_d   | HIGH  | Out       | SPI bus "master out, slave in" signal for an external SPI flash. |
| external_s_n | LOW   | Out       | SPI bus select signal for an external SPI flash.                 |
| external_q   | HIGH  | In        | SPI bus "master in, slave out" signal for an external SPI flash. |

Table 9-3: External Interface Details

#### **Error Injection Interface**

The Error Injection Interface is present when the controller supports error injection and the HID shim is set to I/O Pins. This interface is a direct pass-through from the controller. See Chapter 2, Error Injection Interface for a description of this interface.

When the controller supports error injection and the HID shim is set to ChipScope, or when error injection is disabled, this interface is absent.

### Simulation

Simulation of designs that instantiate the controller is supported. In other words, including the controller in a larger project does not adversely affect ability to run simulations of functionality unrelated to the controller. However, it is not possible to observe the controller behaviors in simulation. Simulation of a design including the controller will compile, but the controller will not exit the initialization state.

Hardware-based evaluation of the controller behaviors is required. Alternatively, customers can use ISim Hardware Co-simulation to evaluate their design.

### **Demonstration Test Bench**

No simulation test bench is provided with the example design.

### **Implementation in ISE Design Suite**

After generating the solution, the resulting controller netlist and example design files can be used with a standard design flow.

Synthesis of designs that instantiate the controller is supported for Synopsys Synplify Pro and Xilinx XST. The synthesis output can be processed using the Xilinx implementation tools. This chapter outlines the example design synthesis and implementation scripts.

Implementation of the controller, when configured to use the optional error classification function or the optional correction by replace function, requires a large amount of system RAM.



TIP: Xilinx recommends the use of a 64-bit operating system with 16 Gb or more of system RAM.

To synthesize and implement the example design, open a console window and type the following:

#### Windows

```
ms-dos> cd <project directory>\<component name>\implement
ms-dos> implement.bat
```

#### Linux

```
% cd <project directory>/<component name>/implement
% ./implement.sh
```

These commands change directory and execute an implementation script. The script synthesizes the design, performs physical implementation, and generates programming files. The result files are placed in the results directory. The following is an outline of the scripted processing sequence:

- 1. If the solution requires ChipScope analyzer files in the example design directory, the script verifies the files exist. If they do not exist, the script exits.
- 2. The script removes intermediate and result files from previous implementation runs.
- 3. The script synthesizes the project using Synopsys Synplify Pro or Xilinx XST based on the project option settings used when the solution was generated.
- 4. The script performs a physical implementation:
  - a. Xilinx ngdbuild application builds a design database
  - b. Xilinx map application maps the design to the target device
  - c. Xilinx par application places and routes the design
  - d. Xilinx trce application performs static timing analysis

- e. Xilinx netgen application generates a timing simulation model
- f. Xilinx bitgen application generates programming files
- 5. If the solution requires external data storage to support error classification or error correction by replace, an additional TCL script is called to post-process special bitgen output files into a SPI Flash programming file.
- 6. The script removes some intermediate files to clean up the results directory.

The script file starts from the example design source and the controller netlist and results in programming files. It is possible to use the Xilinx ISE Design Suite graphical design environment to implement the example design, provided the implementation tool options used in the script are preserved and the additional TCL script is invoked manually, if it is required.

### **External Memory Programming File**

When error correction by replace is enabled, an image of the configuration data is required. When error classification is enabled, an image of the essential bit lookup data is required. As a result, one or both of these data sets may be required. The data sets are identical in size, with their size a function of the target device. The data sets are generated by the bitgen application.

The format of the data is required to be binary, using the full data set(s) generated by bitgen. The external storage must be byte addressable. A small table is required at the address specified to the SEM Controller through fetch\_tbladdr[31:0]. By default, fetch\_tbladdr[31:0] is zero.

- Byte 0: 32-bit pointer to start of replacement data, byte 0 (least significant byte)
- Byte 1: 32-bit pointer to start of replacement data, byte 1
- Byte 2: 32-bit pointer to start of replacement data, byte 2
- Byte 3: 32-bit pointer to start of replacement data, byte 3 (most significant byte)
- Byte 4: 32-bit pointer to start of essential bit data, byte 0 (least significant byte)
- Byte 5: 32-bit pointer to start of essential bit data, byte 1
- Byte 6: 32-bit pointer to start of essential bit data, byte 2
- Byte 7: 32-bit pointer to start of essential bit data, byte 3 (most significant byte)
- The remaining bytes are reserved, filled with zero

A pointer value of 0xFFFFFFF is used if a particular block of data is not present. The essential bit data and replacement data can be located at any address provided each data set is contiguous and it is possible to perform a read burst through each data block.

For SPI Flash that does not support read burst across device boundaries, data blocks must be located so that they do not straddle any of these device boundaries. For example, many SPI Flash of a density > 256 Mbit do not allow read burst across 256 Mbit boundaries.

The TCL script, which post processes the bitgen output files, generates three outputs:

- An Intel hex data file (MCS) for programming SPI Flash devices
- A raw binary data file (BIN) for programming SPI Flash devices
- An initialization file (VMF) for loading SPI Flash simulation models

### **Directory and File Contents**

The SEM Controller deliverables are organized in the directory structure shown below. Click a directory name to go to the description of the directory and the files it contains.



#### <project directory>

The <project directory> contains all the CORE Generator project files.

Table 9-4: Project Directory

| Name                                        | Description                                |  |
|---------------------------------------------|--------------------------------------------|--|
| <project_dir></project_dir>                 |                                            |  |
| <component_name>.xco</component_name>       | Configuration options file.                |  |
| <component_name>.ngc</component_name>       | SEM Controller implementation netlist.     |  |
| <component_name>.{v vhd}</component_name>   | SEM Controller simulation netlist.         |  |
| <component_name>.{veo vho}</component_name> | SEM Controller instantiation template.     |  |
| <component_name>_flist.txt</component_name> | List of files delivered with the solution. |  |
|                                             | · · · ·                                    |  |

Back to Top

#### <project directory>/<component name>

The component name directory contains the release notes in the readme file provided with the core, which can include tool requirements, updates, and issue resolution.

Table 9-5: Component Name Directory

| Name                                                          | Description         |  |
|---------------------------------------------------------------|---------------------|--|
| <project_dir>/<component_name></component_name></project_dir> |                     |  |
| sem_v3_4_readme.txt                                           | Release notes file. |  |

Back to Top

#### <component name>/doc

The doc directory contains the PDF documentation provided with the core.

Table 9-6: Doc Directory

| Name                                                              | Description |  |
|-------------------------------------------------------------------|-------------|--|
| <project_dir>/<component_name>/doc</component_name></project_dir> |             |  |
| pg036_sem.pdf SEM Controller Product Guide                        |             |  |

Back to Top

#### <component name>/example design

The example design directory contains the example design files provided with the core.

| Table 9-7: Example Design Director | ible 9-7: | : Example | Design | Directory |
|------------------------------------|-----------|-----------|--------|-----------|
|------------------------------------|-----------|-----------|--------|-----------|

| Name                                                                                    | Description                                                                                                                                              |
|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <project_dir>/<comp< td=""><td>onent_name&gt;/example_design</td></comp<></project_dir> | onent_name>/example_design                                                                                                                               |
| <component_name>_sem_cfg.{v vhd}</component_name>                                       | Example design configuration logic.                                                                                                                      |
| <component_name>_sem_example.{v vhd}</component_name>                                   | Example design top level.                                                                                                                                |
| <component_name>_sem_example.ucf</component_name>                                       | Example design constraints file.                                                                                                                         |
| <component_name>_sem_mon.{v vhd}</component_name>                                       | Example design MON shim.                                                                                                                                 |
| <component_name>_sem_mon_fifo.{v vhd}</component_name>                                  | Example design MON shim FIFO sub-block.                                                                                                                  |
| <component_name>_sem_mon_piso.{v vhd}</component_name>                                  | Example design MON shim PISO sub-block.                                                                                                                  |
| <component_name>_sem_mon_sipo.{v vhd}</component_name>                                  | Example design MON shim SIPO sub-block.                                                                                                                  |
| <component_name>_sem_ext.{v vhd}</component_name>                                       | Example design EXT shim. This file is only generated if error classification or error correction by replace are enabled.                                 |
| <component_name>_sem_ext_byte.{v vhd}</component_name>                                  | Example design EXT shim byte transfer sub-block. This file is only generated if error classification or error correction by replace are enabled.         |
| <component_name>_sem_hid.{v vhd}</component_name>                                       | Example design HID shim. This file is only generated if error injection using the ChipScope tool is enabled.                                             |
| icon_bscan_bufg.{v vhd}                                                                 | Example design HID shim sub-block. This file is only generated for Virtex-6 or Spartan-6 devices if error injection using the ChipScope tool is enabled. |

Back to Top

#### <component name>/implement

The implement directory contains the core implementation script files.

| Name                        | Description                                                                                                                                                                                |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <project_dir></project_dir> | <pre>/<component_name>/implement</component_name></pre>                                                                                                                                    |
| implement.bat               | Windows batch file implementation script.                                                                                                                                                  |
| implement.sh                | Linux batch file implementation script.                                                                                                                                                    |
| makedata.tcl                | Bitgen data formatter for essential bit lookup table and<br>correction by replace data. This file is only generated if error<br>classification or error correction by replace are enabled. |
| synplify.prj                | Synplify Pro synthesis script, only generated if the project option flow setting is Synplicity.                                                                                            |
| xst.prj                     | XST synthesis project, only generated if the project option flow setting is ISE Design Suite.                                                                                              |

| Table 9-8: | Implement Directory | (Cont'd) |
|------------|---------------------|----------|
|------------|---------------------|----------|

| Name    | Description                                                                                  |
|---------|----------------------------------------------------------------------------------------------|
| xst.scr | XST synthesis script, only generated if the project option flow setting is ISE Design Suite. |

Back to Top

#### <component name>/implement/results

The results directory is created by the implement script. The implementation results are placed in the results directory.

#### <component name>/implement/synplify

The synplify directory is created by the implementation script. The synthesis results are placed in the synplify directory.

#### <component name>/implement/xst

The xst directory is created by the implementation script. The synthesis results are placed in the xst directory.



# SECTION IV: APPENDICES

Verification, Compliance, and Interoperability Migrating Debugging Additional Resources



### Appendix A

# Verification, Compliance, and Interoperability

The controller and example design are verified together, using several methods including an automated hardware test bench and hardware co-simulation tools. The controller and example design are validated together, in an accelerated particle beam, to ensure the solution responds correctly to naturally injected, random error events.

Xilinx completely verifies this LogiCORE IP product for production use in production Virtex-6 FPGA devices.

For the ISE Design Suite v14.4 release, this LogiCORE IP product targeting Spartan-6 devices is in pre-production. The Spartan-6 solution has been redesigned in this release based on new guidance for configuration readback.

For the Vivado Design Suite v2012.4 and ISE Design Suite v14.4 release, this LogiCORE IP product targeting 7 series devices is in pre-production. Verification and validation activities are on-going and will be completed in a future release.

### Verification

The SEM verification objectives are derived from the functional specification of the product. Verification is performed to ensure a high-quality product with a methodology that uses a hybrid approach. Testing included an emphasis on hardware verification and was complemented by a co-simulation test bench. The techniques and tools used were:

- Dynamic checks, through a hardware test bench
  - Functional Coverage: Compares design behavior against expected behavior
- Dynamic checks, through a co-simulation test bench
  - Functional Coverage: Compares design behavior against expected behavior
  - Code Coverage: Records execution trace of controller FSM for analysis
- Static checks, through a checking tool suite
  - Linting
  - Clock Domain Crossing

## Validation

Hardware validation is a key final test and gates the release of the product. Hardware validation adds value by conducting the following tests:

- External Interface Evaluation
  - Timing budget evaluation for external memory system
- Integration and Implementation
  - Hardware testing of all possible generated core netlists
- Operating Environment Robustness
  - Sample testing across the supported device list (Virtex-6 devices)
  - Complete testing across the supported device list (Spartan-6 devices)
  - Sample testing across the supported device list for all sub-families (7 series devices)

### **Conformance Testing**

No industry standard certification testing is defined. The generated core netlists must be put through testing while exposed to a beam of accelerated particles. This testing:

- Validates that detection, correction, and classification take place separate from injection. The verification methodology relies on error injection by the solution itself, and does not test detection, correction, and classification processes separate from injection. Errors during beam testing occur separate from injection by the solution itself.
- Validates that the solution exhibits normal and expected behaviors, including detection, correction, and classification of errors.



### Appendix B

# Migrating

This appendix describes migrating from the previous version of the IP to the current version.

*Note:* For details on migration from the ISE Design Suite to the Vivado Design Suite, see the *Vivado Design Suite Migration Methodology Guide* (UG911) [Ref 9].

#### **Customization and Generation Changes**

When targeting a Spartan-6 LXT device, additional customization options are available to enable or disable scanning in rows with GTs. For more information, see Controller Options: Enable Scanning of GT Row(s) (Spartan-6 LXT Devices) in Chapter 7, <u>Answer Record 52716</u>, and *Spartan-6 FPGA Configuration User Guide* (UG380) [Ref 4].

### **Port Changes**

There are no port changes for this version.

### **Functionality Changes**

There are no functionality changes for this version.



### Appendix C

## Debugging

This appendix provides information for using the resources available on the Xilinx Support website, debug tools, and other step-by-step processes for debugging designs that use the SEM core. It also contains a sample flow diagram and other design samples to guide you through the debug process.

The following topics are included in this appendix:

- Finding Help on Xilinx.com
- Debug Tools
- Hardware Debug
- Interface Debug
- Clocking

### Finding Help on Xilinx.com

To help in the design and debug process when using the SEM core, the <u>Xilinx Support web</u> <u>page</u> (www.xilinx.com/support) contains key resources such as product documentation, release notes, answer records, information about known issues, and links for opening a Technical Support Web Case.

#### Documentation

This product guide is the main document associated with the SEM core. This guide, along with documentation related to all products that aid in the design process, can be found on the Xilinx Support web page (<a href="http://www.xilinx.com/support">www.xilinx.com/support</a>) or by using the Xilinx Documentation Navigator.

Download the Xilinx Documentation Navigator from the Design Tools tab on the Downloads page (<u>www.xilinx.com/download</u>). For more information about this tool and the features available, open the online help after installation.

#### **Release Notes**

Known issues for all cores, including the SEM core are described in the <u>IP Release Notes</u> <u>Guide (XTP025)</u>.

#### **Known Issues**

Answer Records include information about commonly encountered problems, helpful information on how to resolve these problems, and any known issues with a Xilinx product. Answer Records are created and maintained daily ensuring that users have access to the most accurate information available.

Answer Records for this core are listed below, and can also be located by using the Search Support box on the main <u>Xilinx support web page</u>. To maximize your search results, use proper keywords such as:

- Product name
- Tool message(s)
- Summary of the issue encountered

A filter search is available after results are returned to further target the results.

#### Answer Records for the SEM Core

Release notes and known issues for all versions of the SEM core are included in <u>Answer</u> <u>Record 44541</u>.

If targeting a Spartan-6 LXT device, see <u>Answer Record 52716</u> for a Spartan-6 Configuration Readback Design Advisory.

#### **Contacting Technical Support**

Xilinx provides premier technical support for customers encountering issues that require additional assistance.

To contact Xilinx Technical Support:

- 1. Navigate to <u>www.xilinx.com/support</u>.
- 2. Open a WebCase by selecting the <u>WebCase</u> link located under Support Quick Links.

When opening a WebCase, include:

- Target FPGA including package and speed grade.
- All applicable Xilinx Design Tools and simulator software versions.

• Additional files based on the specific issue might also be required. See the relevant sections in this debug guide for guidelines about which file(s) to include with the WebCase.

## **Debug Tools**

There are many tools available to address SEM design issues. It is important to know which tools are useful for debugging various situations.

#### **Example Design**

The SEM core is delivered with an example design that can be synthesized, complete with functional test benches. Information about the example design can be found in Chapter 6, Detailed Example Design for the Vivado Design Suite and Chapter 9, Detailed Example Design for the ISE Design Suite.

#### ChipScope Pro Tool

The ChipScope<sup>™</sup> Pro tool inserts logic analyzer, bus analyzer, and virtual I/O cores directly into your design. The ChipScope Pro tool allows you to set trigger conditions to capture application and integrated block port signals in hardware. Captured signals can then be analyzed through the ChipScope Pro Logic Analyzer tool. For detailed information for using the ChipScope Pro tool, see <u>www.xilinx.com/tools/cspro.htm</u>.

#### Vivado Lab Tools

Vivado Lab Tools inserts logic analyzer, bus analyzer, and virtual I/O cores directly into your design. Vivado Lab Tools allows you to set trigger conditions to capture application and integrated block port signals in hardware. Captured signals can then be analyzed.

#### **Reference Boards**

Various Xilinx development boards support the SEM core. These boards can be used to prototype designs and establish that the core can communicate with the system.

- 7 series evaluation boards
  - AC701
  - KC705
  - VC707
  - ZC702
  - ZC706

Virtex-6 and Spartan-6 FPGA evaluation boards

- ML605
- SP605

#### **License Checkers**

If the IP requires a license key, the key must be verified. The ISE and Vivado tool flows have a number of license check points for gating licensed IP through the flow. If the license check succeeds, the IP may continue generation; otherwise generation halts with an error. License checkpoints are enforced by the following tools:

- ISE flow: XST, NgdBuild, Bitgen
- Vivado flow: Vivado Synthesis, Vivado Implementation, write\_bitstream (Tcl command)



**IMPORTANT:** *IP license level is ignored at checkpoints. The test confirms a valid license exists. It does not check IP license level.* 

### **Hardware Debug**

Hardware issues can range from link bring-up to problems seen after hours of testing. This section provides debug steps for common issues. The ChipScope tool is a valuable resource to use in hardware debug. The signal names mentioned in the following individual sections can be probed using the ChipScope tool for debugging the specific problems.

#### **General Checks**

Ensure that all the timing constraints for the core were properly incorporated from the example design and that all constraints were met during implementation.

If using any clock management blocks in the design, ensure they have obtained lock by monitoring their status.

**RECOMMENDED:** Xilinx recommends integrating the SEM IP core as early as possible, ideally at the start of the project. For more information, see Integration and Validation, page 103.

### **Interface Debug**

#### **Monitor Interface**

While using the monitor interface is optional, Xilinx strongly recommends having a method in place to connect the monitor interface. The monitor interface provides information that is crucial in debugging potential problems or answering questions that might arise. The MON shim in the system-level design example is a UART that can be connected to a standard RS232 port, or to USB through a USB-to-UART bridge.

To confirm the SEM controller is operational, observe the initialization report issued by the SEM controller over the monitor interface. It generally has the following form:

X7\_SEM\_V3\_4 SC 01 FS 02 ICAP OK RDBK OK INIT OK SC 02 O>

The first line lists the device and core version, and it varies depending on the target device used. For example, the Virtex-6 SEM controller would issue V6\_SEM\_V3\_4 while the Spartan-6 SEM controller would issue S6\_SEM\_V3\_4. The second line indicates the SEM controller feature set, which is a summary of the SEM controller core options selected when the core was generated.

If the MON shim is used, and the initialization report appears scrambled or garbage characters appear, verify that the terminal program communication settings match those listed in Monitor Interface in Chapter 3. Also verify that the frequency of the actual clock provided to the SEM controller, coupled with the MON shim V\_ENABLE\_TIME parameter value, yield a standard baud rate and that the terminal program communication settings match the bit rate. This is described in Equation 3-1 and Equation 3-2.

If the SEM controller cannot achieve communication with the FPGA configuration logic through the internal configuration access port (ICAP) primitive, the initialization report does not get past the ICAP line, and OK is not present because the controller cannot communicate with the FPGA configuration logic. In such a scenario, the initialization report will look like this:

```
X7_SEM_V3_4
SC 01
FS 02
ICAP
```

If this happens, it is necessary to determine why the ICAP is not responding. Some possible items to check:

- Ensure the instantiation of the ICAP is correct for the device being used.
  - Use the example design to get the correct instantiation.
  - For implementations in Zynq-7000 devices, review the hardware and software control of the SEM controller icap\_grant input.
- Ensure that no other process is blocking the ICAP.
  - Verify no JTAG access is occurring and that SelectMAP persist is not set.
- The connection between the SEM controller and the ICAP must be direct, unless the ICAP sharing method documented in XAPP517 is used. Never add pipelining between the SEM controller and the ICAP.

## Clocking

Xilinx recommends the clock to be sourced from an oscillator and brought in from a pin directly to the SEM controller. While the likelihood of an SEU event hitting the configuration cells associated with creating the clock internally from a PLL or DCM is very small, it is best to strive for the highest reliability possible. However, if a PLL or DCM output or other logic is used to generate the clock, ensure the clock never violates the SEM controller minimum period at any time, including during design start up or prior to PLL/DCM lock.

When clock management is used, suppress the clock toggling to the SEM controller until after the clock is stable. For example use a BUFGMUX or BUFGCE to keep the SEM controller clock from toggling until PLL/DCM lock is achieved.



### Appendix D

## **Additional Resources**

### **Xilinx Resources**

For support resources such as answers, documentation, downloads, and forums, see the Xilinx Support website at:

www.xilinx.com/support.

For a glossary of technical terms used in Xilinx documentation, see:

www.xilinx.com/company/terms.htm.

### **Solution Centers**

See the <u>Xilinx Solution Centers</u> for support on devices, software tools, and intellectual property at all stages of the design cycle. Topics include design assistance, advisories, and troubleshooting tips.

### References

These documents provide supplemental material useful with this user guide:

- 1. Xilinx Device Reliability Report (UG116)
- 2. 7 Series FPGAs Configuration User Guide (UG470)
- 3. Virtex-6 FPGA Configuration User Guide (UG360)
- 4. Spartan-6 FPGA Configuration User Guide (UG380)
- 5. Zynq-7000 EPP Software Developers Guide (UG821)
- 6. OS and Libraries Document Collection (UG643)
- 7. Udipi, Sujeeth. Comprehensive Full-Chip Methodology to Verify EM and Dynamic Voltage Drop on High Performance FPGA Designs in the 20nm Technology presented at

DesignCon 2014, accessed on June 19, 2015, <u>http://www.xilinx.com/events/designcon2014/</u> 1\_TH6Paper\_ComprehensiveFull\_ChipMethodologytoVerifyElectromigration\_v2.pdf.

- 8. Continuing Experiments of Atmospheric Neutron Effects on Deep Submicron Integrated Circuits (WP286)
- 9. Vivado Design Suite Documentation

## **Technical Support**

Xilinx provides technical support at <u>www.xilinx.com/support</u> for this LogiCORE<sup>™</sup> IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled DO NOT MODIFY.

See the IP Release Notes Guide (XTP025) for more information on this core. For each core, there is a master Answer Record that contains the Release Notes and Known Issues list for the core being used. The following information is listed for each version of the core:

- New Features
- Resolved Issues
- Known Issues

### **Revision History**

The following table shows the revision history for this document.

| Date       | Version | Revision                                                                                                                                                                                        |
|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 09/30/2015 | 3.4.1   | <ul> <li>Updated Start-Up Latency table.</li> <li>Added Integration and Validation section in both Customizing and<br/>Generating the Core sections.</li> </ul>                                 |
| 12/18/2012 | 3.0     | <ul> <li>Updated core to v3.4, ISE Design Suite to v14.4 and Vivado Design Suite to v2012.4.</li> <li>Added pre-production support for Zynq-7000, Artix-7, and Virtex-7 SSI devices.</li> </ul> |
|            |         | <ul> <li>Redesigned the Spartan-6 solution based on new guidance for<br/>configuration readback.</li> </ul>                                                                                     |

| Date       | Version | Revision                                                                                                                                                                   |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 07/25/2012 | 2.0     | Added support for Vivado Design Suite.                                                                                                                                     |
| 04/24/2012 | 1.0     | Initial Xilinx release. Replaces DS796, LogiCORE IP Soft Error Mitigation<br>Controller Data Sheet, and UG764, LogiCORE IP Soft Error Mitigation<br>Controller User Guide. |

### **Notice of Disclaimer**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at <a href="http://www.xilinx.com/warranty.htm">http://www.xilinx.com/warranty.htm</a>; IP cores may be subject to varranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in Critical Applications: <a href="http://www.xilinx.com/warranty.htm#critapps">http://www.xilinx.com/warranty.htm#critapps</a>.

© Copyright 2012–2015 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.