# Platform Flash XL Configuration and Storage Device

## **User Guide**

UG438 (v2.0) December 14, 2009



www.BDTIC.com/XILINX



Xilinx is disclosing this user guide, manual, release note, and/or specification (the "Documentation") to you solely for use in the development of designs to operate with Xilinx hardware devices. You may not reproduce, distribute, republish, download, display, post, or transmit the Documentation in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx. Xilinx expressly disclaims any liability arising out of your use of the Documentation. Xilinx reserves the right, at its sole discretion, to change the Documentation without notice at any time. Xilinx assumes no obligation to correct any errors contained in the Documentation, or to advise you of any corrections or updates. Xilinx expressly disclaims any liability in connection with technical support or assistance that may be provided to you in connection with the Information.

THE DOCUMENTATION IS DISCLOSED TO YOU "AS-IS" WITH NO WARRANTY OF ANY KIND. XILINX MAKES NO OTHER WARRANTIES, WHETHER EXPRESS, IMPLIED, OR STATUTORY, REGARDING THE DOCUMENTATION, INCLUDING ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NONINFRINGEMENT OF THIRD-PARTY RIGHTS. IN NO EVENT WILL XILINX BE LIABLE FOR ANY CONSEQUENTIAL, INDIRECT, EXEMPLARY, SPECIAL, OR INCIDENTAL DAMAGES, INCLUDING ANY LOSS OF DATA OR LOST PROFITS, ARISING FROM YOUR USE OF THE DOCUMENTATION.

© 2008–2009 Xilinx, Inc. XILINX, the Xilinx logo, Virtex, Spartan, ISE and other designated brands included herein are trademarks of Xilinx in the United States and other countries. PCI, PCI-SIG, PCI EXPRESS, PCIE, PCI-X, PCI HOT PLUG, MINI PCI, EXPRESSMODULE, and the PCI, PCI-X, PCI HOT PLUG, and MINI PC design marks are trademarks, registered trademarks, and/or service marks of PCI-SIG. All other trademarks are the property of their respective owners.

### **Revision History**

The following table shows the revision history for this document.

| Date     | Version | Revision                                                                                                                                                                                                                                                                                                       |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03/28/08 | 1.0     | Initial Xilinx release.                                                                                                                                                                                                                                                                                        |
| 05/14/08 | 1.1     | <ul> <li>Added Figure 2-1, page 16 and Figure 3-1, page 32 footnotes.</li> <li>Added "Master SelectMAP Configuration Mode" in Chapter 3.</li> <li>Changed Chapter 3 title to "Alternate Configuration Modes."</li> <li>Added updates highlighting recommended configuration mode (Slave SelectMAP).</li> </ul> |

| Date     | Version | Revision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12/10/08 | 1.2     | <ul> <li>Chapter 1:</li> <li>Added cross reference to <i>Virtex-5 FPGA Configuration User Guide</i>.</li> <li>Removed NC and DU signals from Table 1-2.</li> <li>Updated description of I/O power supply to include support of 2.5V.</li> <li>Chapter 2:</li> <li>Updated chapter title and "Slave SelectMAP Configuration Mode."</li> <li>Updated Figure 2-1, including note 7, and added notes 10 and 11.</li> <li>Added Table 2-1 and Figure 2-2.</li> <li>Chapter 3:</li> <li>Updated "Master BPI-Up Configuration Mode."</li> <li>Added notes 9 and 10 to and updated Figure 3-1.</li> <li>Updated "FPGA BPI-Up Configuration from Platform Flash XL."</li> <li>Updated Figure 3-3 title.</li> <li>Chapter 5:</li> <li>Deleted note from "Preparing a Programming File."</li> <li>Updated "Step 3: Select the XCF128X Device."</li> <li>Chapter 6:</li> <li>Updated Figure 6-1.</li> <li>Updated Figure 6-1.</li> <li>Updated MPACT software version.</li> <li>Added "Step 7: Select iMPACT Programming Properties" and "Step 6: Invoke the iMPACT Program Operation."</li> <li>Updated iMPACT software version.</li> <li>Interchanged "Step 7: Select iMPACT Programming Properties" and "Step 6: Invoke the iMPACT Program Operation."</li> <li>Updated "Expectations."</li> </ul> |
| 12/14/09 | 2.0     | Added support for Virtex-6 FPGAs.Updated iMPACT software version.Updated "Overview."Added Table 1-1, which contains configuration flash information for Virtex-5 and<br>Virtex-6 devices.Updated "Family Description," including Figure 1-1 and Table 1-2.Updated "Slave SelectMAP Configuration Mode" and "Slave SelectMAP Configuration<br>from Platform Flash XL."Updated Figure 2-1 and its associated notes.Added Figure 2-2 and its associated notes.Updated Table 2-1.Updated Figure 2-3 and its associated notes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Date                 | Version         | Revision                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|----------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 12/14/09<br>(Cont'd) | 2.0<br>(Cont'd) | Updated "Master BPI-Up Configuration Mode," Figure 3-1 and its associated notes,<br>Table 3-1, "FPGA BPI-Up Configuration from Platform Flash XL," Figure 3-2 and its<br>associated notes, "Master SelectMAP Configuration Mode," and notes relating to<br>Figure 3-3.                                                                                                                                                                                                         |  |
|                      |                 | Updated Chapter 4, "Calculating Configuration Time."<br>Updated "Using the iMPACT Graphical Software."<br>Updated Figure 6-1.<br>Deleted Frequency column from Table 6-1.                                                                                                                                                                                                                                                                                                      |  |
|                      |                 | <ul> <li>Updated "Minimum Requirements for Indirect In-System Programming."</li> <li>Updated "Xilinx Cable Connections" and "Effect of Indirect Programming on the Rest of the System."</li> </ul>                                                                                                                                                                                                                                                                             |  |
|                      |                 | <ul> <li>Removed Table 6-2; information is available in <u>DS593</u>, <i>Platform Cable USB II Data Sheet</i></li> <li>Updated steps and GUI screen shots in "iMPACT Programming Flow."</li> <li>Added Chapter 7, "System Considerations."</li> <li>Added "Re-Using Configuration Pins for Other Purposes."</li> <li>Updated "FPGA Designs Not Accessing Platform Flash XL after Configuration" and "FPGA Designs Accessing Platform Flash XL after Configuration."</li> </ul> |  |
|                      |                 | Updated Table 8-2.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |

## Table of Contents

| Revision History                                                                    |                         |
|-------------------------------------------------------------------------------------|-------------------------|
| Preface: About This Guide                                                           |                         |
| Summary                                                                             |                         |
| Guide Contents                                                                      |                         |
| Additional Resources                                                                |                         |
| General                                                                             |                         |
| Software<br>Hardware                                                                |                         |
| Additional Documentation                                                            |                         |
| Conventions                                                                         |                         |
| Typographical<br>Online Document                                                    |                         |
| Chapter 1: Overview                                                                 |                         |
| Family Description                                                                  |                         |
| Chapter 2: High-Speed Configuration                                                 |                         |
| Slave SelectMAP Configuration Mode                                                  |                         |
| Slave SelectMAP Configuration from Platform Fla                                     | <b>sh XL</b> 27         |
| Chapter 3: Alternate Configuration Modes                                            |                         |
| Master SelectMAP Configuration Mode                                                 |                         |
| Master BPI-Up Configuration Mode                                                    |                         |
| FPGA BPI-Up Configuration Signals                                                   |                         |
| FPGA BPI-Up Configuration from Platform Flash XI                                    |                         |
| Master Mode Considerations                                                          | 44                      |
| Chapter 4: Calculating Configuration Time                                           |                         |
| Determining the Maximum Configuration Clock F                                       | <b>requency</b> 45      |
| Slave SelectMAP Maximum Configuration Clock I                                       | Frequency 46            |
| Master SelectMAP/BPI Maximum Configuration C                                        | <b>Clock Setting</b> 46 |
| Determining Configuration Time                                                      | 47                      |
| Chapter 5: Platform Flash XL File Generati                                          | on                      |
| Preparing a Programming File                                                        |                         |
| Using the PROMGen Command-Line Software                                             |                         |
| Using the iMPACT Graphical Software                                                 |                         |
| Step 1: Prepare a PROM File<br>Step 2: Specify the BPI Flash Storage for the FPGA C |                         |



| Step 3: Select the XCF128X Device                     | 52 |
|-------------------------------------------------------|----|
| Step 4: Specify Output PROM File Name and Location    |    |
| Step 5: Notification to Add a Device to the PROM File |    |
| Step 6: Select the FPGA Bitstream File to Add         | 53 |
| Step 7: Generate File Operation                       |    |

### **Chapter 6: Programming Platform Flash XL**

| Programming Platform Flash XL During Prototyping                | 57 |
|-----------------------------------------------------------------|----|
| Minimum Requirements for Indirect In-System Programming         |    |
| Xilinx Cable Connections                                        |    |
| iMPACT Programming Flow                                         | 59 |
| Step 1: Create a New Project for Indirect In-System Programming | 59 |
| Step 2: Configure Devices Using the JTAG-to-BPI Method          | 60 |
| Step 3: Assign the FPGA Configuration File                      | 62 |
| Step 4: Add a PROM File for Indirect Programming                |    |
| Step 5: Select Xilinx XCF128X Device Part Number                | 63 |
| Step 6: Invoke the iMPACT Program Operation                     | 64 |
| Step 7: Select iMPACT Programming Properties                    | 65 |
| Expectations                                                    | 65 |
| iMPACT Operations and Programming Times                         |    |
| Effect of Indirect Programming on the Rest of the System        |    |
| Pull-Up and Pull-Down Consideration                             |    |
| Production Programming Solutions                                | 67 |
| Device Programmers                                              | 67 |

### **Chapter 7: System Considerations**

| Platform Flash XL VDDQ Power Budget |
|-------------------------------------|
|-------------------------------------|

### **Chapter 8: FPGA User Design Recommendations**

| FPGA Designs Not Accessing Platform Flash XL after Configuration | 71 |
|------------------------------------------------------------------|----|
| Re-Using Configuration Pins for Other Purposes                   | 72 |
| FPGA Designs Accessing Platform Flash XL after Configuration     | 72 |
| FPGA Design Preparation for Asynchronous Read Mode Access        | 72 |
| FPGA Design Preparation for FPGA Reconfiguration                 | 73 |



## Preface

## About This Guide

### Summary

This guide describes the Platform Flash XL feature set, demonstrates the common configuration mode setups supported, and provides the software flows necessary to generate the programming files and indirectly program the device in-system. More information on Platform Flash XL is available online in <u>DS617</u>, *Platform Flash XL High-Density Configuration and Storage Device*.

### **Guide Contents**

This manual contains the following chapters:

- Chapter 1, "Overview," provides a brief description of key features of Platform Flash XL.
- Chapter 2, "High-Speed Configuration," describes the most popular setup for highperformance applications.
- Chapter 3, "Alternate Configuration Modes," describes the BPI-Up configuration mode setup and the Master SelectMAP configuration mode considerations.
- Chapter 4, "Calculating Configuration Time," describes the considerations and parameters used to determine the minimum configuration time.
- Chapter 5, "Platform Flash XL File Generation," demonstrates the steps required to prepare programming files in popular PROM formats.
- Chapter 6, "Programming Platform Flash XL," describes the flow used to program the device indirectly using iMPACT software.
- Chapter 7, "System Considerations," provides V<sub>DDQ</sub> power budget estimates from a real example test board.
- Chapter 8, "FPGA User Design Recommendations," describes recommendations for FPGA designs that use Platform Flash XL for storage after configuration.

### **Additional Resources**

#### General

To find additional documentation, see the Xilinx<sup>®</sup> website at:

http://www.xilinx.com/literature.

To search the Answer Database of silicon, software, and IP questions and answers, or to create a technical support WebCase, see the Xilinx website at:



#### http://www.xilinx.com/support.

#### Software

The Xilinx PROMGen and iMPACT software are available with the main Xilinx ISE<sup>®</sup> Foundation<sup>TM</sup> software or with the downloadable Xilinx ISE WebPACK<sup>TM</sup> software packages.

- ISE Foundation software http://www.xilinx.com/ise/logic\_design\_prod/foundation.htm
- The Xilinx ISE software manuals are available at: http://www.xilinx.com/support/software\_manuals.htm

#### Hardware

Information regarding the Xilinx cables are found on the Xilinx Configuration Solutions website:

http://www.xilinx.com/products/design\_resources/config\_sol/

See the ISE iMPACT software manuals for supported Xilinx cables.

### **Additional Documentation**

• <u>DS152</u>, Virtex-6 FPGA Data Sheet: DC and Switching Characteristics

This data sheet contains the DC and switching characteristic specifications for the Virtex-6 family.

• <u>UG360</u>, Virtex-6 FPGA Configuration User Guide

This all-encompassing configuration guide includes chapters on configuration interfaces (serial and SelectMAP), bitstream encryption, Boundary-Scan and JTAG configuration, reconfiguration techniques, and readback through the SelectMAP and JTAG interfaces.

• <u>UG191</u>, Virtex-5 FPGA Configuration User Guide

This all-encompassing configuration guide includes chapters on configuration interfaces (serial and SelectMAP), bitstream encryption, Boundary-Scan and JTAG configuration, reconfiguration techniques, and readback through the SelectMAP and JTAG interfaces.

• DS202, Virtex-5 FPGA Data Sheet: DC and Switching Characteristics

This data sheet contains the DC and switching characteristic specifications for the Virtex-5 family.

• <u>DS617</u>, Platform Flash XL High-Density Configuration and Storage Device

This data sheet describes the Platform Flash XL configuration and storage device optimized for the Virtex-5 FPGA.

### Conventions

This document uses the following conventions. An example illustrates each convention.

### Typographical

The following typographical conventions are used in this document:

| Convention                  | Meaning or Use                                                                                                        | Example                                                                                                  |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Courier font                | Messages, prompts, and<br>program files that the system<br>displays                                                   | speed grade: - 100                                                                                       |
| Courier bold                | Literal commands that you enter in a syntactical statement                                                            | ngdbuild design_name                                                                                     |
| Helvetica bold              | Commands that you select from a menu                                                                                  | $File \to Open$                                                                                          |
|                             | Keyboard shortcuts                                                                                                    | Ctrl+C                                                                                                   |
|                             | Variables in a syntax statement<br>for which you must supply<br>values                                                | ngdbuild design_name                                                                                     |
| Italic font                 | References to other manuals                                                                                           | See the <i>Development System</i><br><i>Reference Guide</i> for more<br>information.                     |
|                             | Emphasis in text                                                                                                      | If a wire is drawn so that it<br>overlaps the pin of a symbol, the<br>two nets are <i>not</i> connected. |
| Square brackets []          | An optional entry or parameter.<br>However, in bus specifications,<br>such as <b>bus</b> [7:0], they are<br>required. | <b>ngdbuild</b> [option_name]<br>design_name                                                             |
| Braces { }                  | A list of items from which you must choose one or more                                                                | lowpwr ={on off}                                                                                         |
| Vertical bar                | Separates items in a list of choices                                                                                  | lowpwr ={on off}                                                                                         |
| Vertical ellipsis<br>•<br>• | Repetitive material that has been omitted                                                                             | IOB #1: Name = QOUT'<br>IOB #2: Name = CLKIN'                                                            |
| Horizontal ellipsis         | Repetitive material that has been omitted                                                                             | <b>allow block</b> block_name loc1 loc2 locn;                                                            |



### **Online Document**

| Convention            | Meaning or Use                                             | Example                                                                       |
|-----------------------|------------------------------------------------------------|-------------------------------------------------------------------------------|
| Blue text             | Cross-reference link to a location in the current document | See the section "Additional Resources" for details.                           |
|                       |                                                            | Refer to "Title Formats" in Chapter 1 for details.                            |
| Red text              | Cross-reference link to a location in another document     | See Figure 2-5 in the Virtex-5 FPGA User Guide.                               |
| Blue, underlined text | Hyperlink to a website (URL)                               | Go to <u>http://www.xilinx.com</u><br>for the latest speed<br>specifications. |

The following conventions are used in this document:



## Chapter 1

## Overview

This guide supplements <u>DS617</u>, *Platform Flash XL High-Density Storage and Configuration Device*, giving specific user information on device features and usage modes.

The Platform Flash XL (XCF128X) configuration and storage device is optimized for use with Virtex®-5 and Virtex-6 FPGAs (see Table 1-1). The Platform Flash XL does not support older Virtex families, Spartan® families, or AES encrypted bitstreams. See <u>UG161</u>, *Platform Flash PROM User Guide*, for alternative Platform Flash PROMs.

For bitstream length (bits), see <u>UG360</u>, *Virtex-6 FPGA Configuration User Guide* or <u>UG191</u>, *Virtex-5 FPGA Configuration User Guide*.

Single-chip Platform Flash XL provides a high-density non-volatile storage with the industry's highest performing configuration, ease-of-use and flexibility within a small footprint package.

With in-system configuration speeds up to 800 Mb/s, Platform Flash XL is ideally suited for high-performance PCI Express<sup>®</sup> technology applications used in optical and enterprise networking, WiMAX digital front-end and baseband processing, video broadcast equipment, and medical ultrasound and scanners.

| FPGA           | Configuration Flash                                                     |
|----------------|-------------------------------------------------------------------------|
| Virtex-6 FPGAs |                                                                         |
| XC6VLX75T      | XCF128X                                                                 |
| XC6VLX130T     | XCF128X                                                                 |
| XC6VLX195T     | XCF128X                                                                 |
| XC6VLX240T     | XCF128X                                                                 |
| XC6VHX250T     | XCF128X                                                                 |
| XC6VHX255T     | XCF128X                                                                 |
| XC6VHX380T     | XCF128X                                                                 |
| XC6VHX565T     | See <u>UG360</u> , Virtex-6 FPGA Configuration User Guide for BPI flash |
| XC6VSX315T     | XCF128X                                                                 |
| XC6VLX365T     | XCF128X                                                                 |
| XC6VSX475T     | See <u>UG360</u> , Virtex-6 FPGA Configuration User Guide for BPI flash |
| XC6VLX550T     |                                                                         |
| XC6VLX760      |                                                                         |



| FPGA           | Configuration Flash |
|----------------|---------------------|
| Virtex-5 FPGAs |                     |
| XC5VLX30       | XCF128X             |
| XC5VLX50       | XCF128X             |
| XC5VLX85       | XCF128X             |
| XC5VLX110      | XCF128X             |
| XC5VLX155      | XCF128X             |
| XC5VLX220      | XCF128X             |
| XC5VLX330      | XCF128X             |
| XC5VLX20T      | XCF128X             |
| XC5VLX30T      | XCF128X             |
| XC5VLX50T      | XCF128X             |
| XC5VLX85T      | XCF128X             |
| XC5VLX110T     | XCF128X             |
| XC5VLX155T     | XCF128X             |
| XC5VLX220T     | XCF128X             |
| XC5VLX330T     | XCF128X             |
| XC5VSX35T      | XCF128X             |
| XC5VSX50T      | XCF128X             |
| XC5VSX95T      | XCF128X             |
| XC5VSX240T     | XCF128X             |
| XC5VTX150T     | XCF128X             |
| XC5VTX240T     | XCF128X             |
| XC5VFX30T      | XCF128X             |
| XC5VFX70T      | XCF128X             |
| XC5VFX100T     | XCF128X             |
| XC5VFX130T     | XCF128X             |
| XC5VFX200T     | XCF128X             |

Table 1-1: Configuration Flash for Virtex-5 and Virtex-6 FPGAs (Cont'd)

### **Family Description**

To achieve high-performance configuration, Platform Flash XL supports the SelectMAP configuration port with power-on synchronization and an immediate bitstream burst capability. A wide, 16-bit data bus delivers the bitstream synchronous to the FPGA configuration clock (CCLK) at up to 50 MHz in the Slave SelectMAP configuration mode without wait states. The device provides a READY\_WAIT signal that synchronizes the start of the FPGA configuration process, both improving system reliability and simplifying

board design. When the device signals a ready status after power-on, the device can immediately burst the FPGA design bitstream (.bit) file to the FPGA. The configuration performance of Platform Flash XL is ideal for PCI Express end-points and other high-performance applications (see Chapter 2, "High-Speed Configuration"). Platform Flash XL is optimized for the FPGA Slave SelectMAP configuration mode, but it also supports Master SelectMAP and Master BPI-Up modes (see Chapter 3, "Alternate Configuration Modes"). When the highest-performance configuration is required, the Platform Flash XL must be used with the FPGA in Slave SelectMAP mode. The Master SelectMAP or Master BPI can be considered in cases where less configuration performance is needed and the FPGA Fallback feature is needed.

In addition to high-performance configuration, Platform Flash XL provides a 128 Mb (8M x 16 bits) nonvolatile single-chip flash memory configuration solution with a small footprint (FT64) and advanced system-level capabilities. A standard NOR flash interface (Figure 1-1) and support for common flash interface (CFI) queries provide industry-standard access to the device memory space. Platform Flash XL's 128 Mb capacity can hold one or more FPGA bitstreams, with any unused memory available for general-purpose data or embedded processor code storage. For bitstream requirements, see <u>UG191</u>, *Virtex-5 FPGA Configuration User Guide* or <u>UG360</u>, *Virtex-6 FPGA Configuration User Guide*.



Figure 1-1: Platform Flash XL Logic Diagram

The Platform Flash XL signals and functions are described in Table 1-2. See Chapter 2, "High-Speed Configuration" and Chapter 3, "Alternate Configuration Modes" for recommended connections to the FPGA.

Table 1-2: Platform Flash XL Signal Descriptions

| Signal Name | Function                           | Direction |
|-------------|------------------------------------|-----------|
| A[22:0]     | Address inputs                     | Inputs    |
| DQ[15:0]    | Data input/outputs, command inputs | I/O       |
| Ē           | Chip enable                        | Input     |



| Signal Name      | Function                                           | Direction |
|------------------|----------------------------------------------------|-----------|
| G                | Output enable                                      | Input     |
| W                | Write enable                                       | Input     |
| RP               | Reset                                              | Input     |
| WP               | Write protect                                      | Input     |
| К                | Clock                                              | Input     |
| Ē                | Latch enable                                       | Input     |
| READY_WAIT       | Ready wait                                         | I/O       |
| V <sub>DD</sub>  | Supply voltage                                     | -         |
| V <sub>DDQ</sub> | Supply voltage for input/output buffers            | -         |
| V <sub>PP</sub>  | Optional supply voltage for fast program and erase | _         |
| V <sub>SS</sub>  | Ground                                             | -         |
| V <sub>SSQ</sub> | Ground input/output supply                         | -         |

#### Table 1-2: Platform Flash XL Signal Descriptions (Cont'd)

For FPGA designs that require data storage, the Platform Flash XL has a multiple-bank architecture—an array of 131 individually erasable blocks that are divided into sixteen 8 Mb banks. Fifteen main banks contain uniform blocks of 64 Kwords, and one parameter bank contains seven main blocks of 64 Kwords, plus four parameter blocks of 16 Kwords (the parameter blocks are located at the top of the memory address space in Platform Flash XL). The device has a 23-bit address bus providing random read access to each 16-bit word. See <u>DS617</u>, *Platform Flash XL High-Density Configuration and Storage Device* for memory map information and application programming instructions.

The device is in-system programmable with a 1.8V core ( $V_{DD}$ ) power supply (electronically erasable at the block level and programmable on a word-by-word basis). A separate I/O ( $V_{DDQ}$ ) power supply enables I/O operation at 2.5V or 3.3V.

The ISE<sup>®</sup> iMPACT software supports indirect, in-system programming of Platform Flash XL via the IEEE Standard Test Access Port and Boundary-Scan Architecture (IEEE Std 1149.1) port (i.e., the JTAG port) on the FPGA (see Chapter 6, "Programming Platform Flash XL").

For FPGA configuration, the Platform Flash XL powers-on directly into synchronous read mode. After latching a starting read address, the synchronous read mode enables the flash to output its array data as a continuous stream of 16-bit words based on an internally incrementing address counter. In each clock cycle, a 16-bit word is delivered. The Platform Flash XL's interface can latch the starting address at the beginning of the FPGA's SelectMAP or BPI mode configuration sequence. The Platform Flash XL's synchronous read function is directly compatible with the FPGA's SelectMAP or BPI mode configuration interface.



## Chapter 2

## High-Speed Configuration

### Slave SelectMAP Configuration Mode

Applications including PCI Express<sup>®</sup> systems require fast FPGA configuration. Platform Flash XL provides the highest performance and power sequencing immunity in the Slave SelectMAP mode. Platform Flash XL achieves maximum configuration performance when a precise external clock source drives the FPGA Slave SelectMAP configuration mode up to the maximum 50 MHz burst read frequency limit (CCLK) of the device.

This chapter describes the configuration of an FPGA from Platform Flash XL in Slave SelectMAP configuration mode (M[2:0] = 110). The first section of this chapter describes the required setup for Slave SelectMAP configuration and indirect in-system Platform Flash XL programming (see Figure 2-1 and Figure 2-2). Next, the FPGA configuration flow for this mode is demonstrated (see Figure 2-3). Refer to the SelectMAP Configuration Interface section in <u>UG191</u>, *Virtex-5 FPGA Configuration User Guide* or <u>UG360</u>, *Virtex-6 FPGA Configuration User Guide*, for additional information on the Slave SelectMAP mode.

The Platform Flash XL has these system-level requirements for configuring an FPGA in the FPGA's SelectMAP mode:

- An external clock source drives the synchronous bitstream transfer resulting in a precise FPGA configuration time.
- On board pull-up or pull-down resistors set the configuration device control pins for output read mode.
- On board pull-up or pull-down resistors set the configuration device burst read start address.
- The FPGA does not support the Fallback feature in the Slave SelectMAP mode. However, an external configuration manager (for example <u>XAPP693</u>, A CPLD-Based Configuration and Revision Manager for Xilinx Platform Flash PROMs and FPGAs) can be implemented to achieve the equivalent fallback function.

See Figure 2-1, page 16 or Figure 2-2, page 18 for example Slave SelectMAP configuration mode connections with the Virtex-5 FPGA or Virtex-6 FPGA, respectively. Refer to "Slave SelectMAP Configuration from Platform Flash XL," page 27 for details on the Slave SelectMAP configuration sequence.





Figure 2-1: Virtex-5 FPGA Slave SelectMAP Configuration Mode from Platform Flash XL

Notes relating to Figure 2-1:

- 1. The JTAG connections are shown for a simple, single-device JTAG scan chain. When multiple devices are on the JTAG scan chain, use the proper IEEE Std 1149.1 daisy-chain technique to connect the JTAG signals. The TCK signal integrity is critical for JTAG operation. Route, terminate, and if necessary, buffer the TCK signal appropriately to ensure signal integrity for the devices in the JTAG scan chain.
- 2. The FPGA mode (M[2:0]) pins are shown set to Slave SelectMAP mode (110). The implementation of a board-level option that enables the user to change the FPGA mode pins to JTAG mode (101) is recommended to enable JTAG-based debug capability for the FPGA during design prototyping without interference from the Slave SelectMAP configuration activities.

- 3. CCLK signal integrity is critical. Route and terminate the CCLK signal appropriately to ensure good signal integrity at the XCF128X  $\overline{K}$  pin and at the FPGA CCLK pin.
- 4. The iMPACT software requires the Virtex-5 FPGA's IO\_L9P\_CC\_GC\_4 connection to the device's  $\overline{L}$  pin to support JTAG-based indirect programming.
- 5. The FPGA HSWAPEN pin is tied to ground in this sample schematic. HSWAPEN can alternatively be tied High. Review the FPGA configuration user guide for the effect of the alternate HSWAPEN setting.
- 6. The Virtex-5 FPGA does not support AES decryption in the 16-bit-wide configuration mode shown in this sample schematic. Thus, the V<sub>BATT</sub> decryptor key battery power supply is unused and is tied to GND.
- The FPGA RS[1:0] pins are not connected in this basic configuration schematic. See <u>XAPP1100</u>, *MultiBoot with Virtex-5 FPGAs and Platform Flash XL*, for an example XCF128X implementation with MultiBoot support. Fallback is not supported in Slave SelectMAP mode.
- 8. DONE LED lights when DONE is High. INIT\_B/CRC-Error LED lights when INIT\_B is Low. Adjust the LED circuits and pull-up values for desired lighting results.
- 9. Each Platform Flash XL address pin requires a separate pull-down resistor to GND to ensure the XCF128X flash latches the zero address at the start of configuration.
- 10.  $V_{DDQ}$ ,  $V_{CCO}$  supplies, pull-up resistors, and  $V_{REF}$  can alternately be connected to a 2.5V supply for I/O operation at 2.5V.
- 11. The required READY\_WAIT (INIT\_B) pull-up value is board dependent, but it must be strong enough to meet the READY\_WAIT rise time (T<sub>RWRT</sub>) requirement.
- 12. For the maximum clock frequency, see "Determining the Maximum Configuration Clock Frequency," page 45.





Figure 2-2 shows a Virtex-6 FPGA connected to Platform Flash XL for Slave SelectMAP configuration mode with indirect programming support.

#### Figure 2-2: Virtex-6 FPGA Slave SelectMAP Configuration Mode from Platform Flash XL

Notes relating to Figure 2-2:

- 1. The JTAG connections are shown for a simple, single-device JTAG scan chain. When multiple devices are on the JTAG scan chain, use the proper IEEE Std 1149.1 daisy-chain technique to connect the JTAG signals. The TCK signal integrity is critical for JTAG operation. Route, terminate, and if necessary, buffer the TCK signal appropriately to ensure signal integrity for the devices in the JTAG scan chain.
- 2. The FPGA mode (M[2:0]) pins are shown set to Slave SelectMAP mode (110). The implementation of a board-level option that enables the user to change the FPGA mode pins to JTAG mode (101) is recommended to enable JTAG-based debug capability for the FPGA during design prototyping without interference from the Slave SelectMAP configuration activities.
- 3. CCLK signal integrity is critical. Route and terminate the CCLK signal appropriately to ensure good signal integrity at the XCF128X K pin and at the FPGA CCLK pin.

- 4. The iMPACT software requires the Virtex-6 FPGA's IO\_L18P\_24 connection to the device's L pin to support JTAG-based indirect programming.
- 5. The FPGA HSWAPEN pin is tied to ground in this sample schematic. HSWAPEN can alternatively be tied High. Review the FPGA data sheet for the effect of the alternate HSWAPEN setting.
- 6. The Virtex-6 FPGA does not support AES decryption in the 16-bit-wide configuration mode shown in this sample schematic. Thus, the  $V_{BATT}$  decryptor key battery power supply is unused and is tied to GND.
- The FPGA RS[1:0] pins are not connected in this basic configuration schematic. See <u>XAPP1100</u>, *MultiBoot with Virtex-5 FPGAs and Platform Flash XL*, for an example XCF128X implementation with MultiBoot support. Fallback is not supported in Slave SelectMAP mode.
- 8. DONE LED lights when DONE is High. INIT\_B/CRC-Error LED lights when INIT\_B is Low. Adjust the LED circuits and pull-up values for desired lighting results.
- 9. Each Platform Flash XL address pin requires a separate pull-down resistor to GND to ensure the XCF128X flash latches the zero address at the start of configuration.
- 10. See DS152, Virtex-6 FPGA Data Sheet, for the V<sub>CCINT</sub> supply voltage.
- 11. The required READY\_WAIT (INIT\_B) pull-up value is board dependent, but it must be strong enough to meet the READY\_WAIT rise time (T<sub>RWRT</sub>) requirement.
- 12. For the maximum clock frequency, see "Determining the Maximum Configuration Clock Frequency," page 45.

The Slave SelectMAP configuration mode interface signals that influence the successful start and stop of data transfer are listed in Table 2-1.

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description                                                                                                                      | Function during<br>FPGA Configuration                                                                                      | Function after<br>FPGA<br>Configuration    | Function during<br>Indirect XCF128X<br>Programming                                                                                                 |
|----------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                              | TMS              | JTAG test mode select.<br>Connect from cable<br>header to TMS pin in all<br>devices in the JTAG<br>chain. Buffer as<br>necessary.                     | JTAG functionality is<br>always available. Do not<br>perform JTAG<br>operations during<br>SelectMAP<br>configuration. JTAG | JTAG functionality is<br>always available. | JTAG is the required<br>access path to the<br>FPGA for indirect<br>programming of the<br>XCF128X. An FPGA<br>design (i.e., indirect                |
| N/A                              | ТСК              | JTAG test clock. Connect<br>from cable header to TCK<br>pin in all devices in JTAG<br>chain. Signal integrity is<br>critical. Buffer as<br>necessary. | operations during<br>configuration can<br>interrupt the<br>configuration sequence.                                         |                                            | programming core) is<br>downloaded through<br>JTAG to the FPGA.<br>This bridges the<br>FPGA's JTAG port<br>with the FPGA's pin<br>interface to the |
| N/A                              | TDO              | JTAG test data output.<br>Daisy-chain to TDI pin of<br>next device in JTAG<br>chain. Last device returns<br>TDO to the cable header.                  |                                                                                                                            |                                            | XCF128X.<br>Commands and data<br>are sent and received<br>through JTAG to the<br>FPGA indirect<br>programming core to                              |
| N/A                              | TDI              | JTAG test data input.<br>Daisy-chain from TDO of<br>prior device in JTAG<br>chain. First device<br>receives TDI from cable<br>header.                 |                                                                                                                            |                                            | program and perform<br>other operations on<br>the XCF128X.                                                                                         |

Table 2-1: Platform Flash XL and FPGA SelectMAP Configuration Signals and Connections



| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Function during<br>FPGA Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Function after<br>FPGA<br>Configuration                                                                                                                                       | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                |
|----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                              | M[2:0]           | These are the FPGA<br>configuration mode<br>inputs. Set M[2:0]=110<br>for Slave SelectMAP<br>mode. Implementing<br>mode switches to enable<br>JTAG mode (M[2:0]=101)<br>allows JTAG debug<br>without interference from<br>the Slave SelectMAP<br>configuration activities.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | On the rising edge of<br>INIT_B, the FPGA<br>samples the M[2:0] pins<br>to determine the<br>configuration mode. See<br>the FPGA configuration<br>user guide for the full<br>list of modes.                                                                                                                                                                                                                                                                                                                          | Dedicated for<br>configuration.                                                                                                                                               | These pins are<br>dedicated for<br>configuration.                                                                                                                                                                 |
| RP#                              | PROGRAM_B        | These are the active-Low<br>FPGA configuration and<br>XCF128X reset inputs.<br>Connect XCF128X RP# to<br>FPGA PROGRAM_B.<br>Connect the signal to an<br>external pull-up. Connect<br>the signal to a<br>pushbutton to ground to<br>allow manual initiation<br>of the reconfiguration<br>process.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Driving PROGRAM_B<br>Low clears the FPGA<br>configuration and<br>initiates an FPGA<br>reconfiguration<br>sequence. The signal<br>must remain High<br>during the configuration<br>process.                                                                                                                                                                                                                                                                                                                           | PROGRAM_B must<br>remain High after<br>configuration.<br>Driving<br>PROGRAM_B Low<br>clears the FPGA<br>configuration and<br>initiates an FPGA<br>reconfiguration<br>process. | PROGRAM_B must<br>remain High during<br>indirect<br>programming. If<br>PROGRAM_B drives<br>Low during indirect<br>programming, the<br>programming<br>process will be<br>interrupted.                              |
| READY_WAIT                       | INIT_B           | This is the configuration<br>sequence initialization<br>handshake signal.<br>Connect XCF128X<br>READY_WAIT to FPGA<br>INIT_B. Connect the<br>signal to an external<br>pull-up resistor capable<br>of transitioning the signal<br>from Low to High in<br>T <sub>RWRT</sub> time as specified<br>in DS617, Platform Flash<br>XL High-Density<br>Configuration and Storage<br>Device. The FPGA and<br>XCF128X drive this signal<br>Low during their<br>respective power-on reset<br>(POR) processes. When<br>each device completes its<br>POR process, it releases<br>its pin to<br>high-impedance. The<br>external pull-up pulls the<br>signal High. The rising<br>edge causes the XCF128X<br>to latch the starting read<br>address to its internal<br>address counter and<br>causes the FPGA to start<br>its configuration process. | At the start of<br>configuration, the FPGA<br>drives INIT_B Low<br>during its initialization<br>process. At the end of<br>initialization, the FPGA<br>releases INIT_B to<br>high-impedance. The<br>external resistor pulls<br>INIT_B High. The rising<br>edge of INIT_B causes<br>the FPGA to sample the<br>configuration mode<br>from the M[2:0] pins and<br>start a corresponding<br>configuration sequence.<br>If a CRC error is detected<br>during the configuration<br>process, the FPGA<br>drives INIT_B Low. | This signal is<br>normally<br>high-impedance. It<br>can drive Low to<br>indicate CRC error<br>from configuration<br>process or from a<br>readback CRC<br>function.            | This signal can drive<br>Low or can be in<br>high-impedance. It<br>indicates<br>configuration<br>initialization or CRC<br>error for the FPGA<br>design download<br>during the indirect<br>programming<br>process. |

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name     | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Function during<br>FPGA Configuration                                                                                                                                                                                                                                                                        | Function after<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                                     | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                           |
|----------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| К                                | CCLK                 | This is the configuration<br>clock. The FPGA Slave<br>SelectMAP mode<br>requires an external<br>source to drive both the<br>XCF128X K and FPGA<br>CCLK. Configuration<br>clock signal integrity is<br>critical. Apply necessary<br>termination to ensure<br>signal integrity.                                                                                                                                                                                                                                                                             | This clock drives the<br>SelectMAP<br>configuration sequence.<br>For each clock cycle, the<br>XCF128X's internal<br>address counter is<br>incremented, the<br>corresponding 16 bits of<br>array data is output to<br>the data bus, and the<br>FPGA registers the data<br>on the next rising edge<br>of CCLK. | This is the dedicated<br>CCLK pin. The<br>external clock source<br>continues to drive the<br>CCLK input.<br>Typically, CCLK is<br>not used after<br>configuration.<br>However, the CCLK<br>pin can be accessed<br>through the<br>STARTUP primitive<br>when applicable. See<br>the FPGA libraries<br>guide for a<br>description of the<br>STARTUP primitive. | This clock is unused.                                                                                                                                                                                                                                                                        |
| A[22:0]                          | A[22:00]<br>A[25:23] | This is the XCF128X<br>address bus. Connect<br>each XCF128X address<br>pin (A[22:0]) to the<br>corresponding FPGA<br>address pin (A[22:00]).<br>Connect each address<br>line (A[22:0]) to an<br>external pull-down<br>resistor. The pull-down<br>resistors provide an<br>address value of<br>0x000000 when the<br>XCF128X latches its<br>starting read address at<br>the beginning of the<br>configuration sequence.<br>Do not connect the FPGA<br>A[25:23] pins. A[25:23]<br>pins can drive High or<br>Low during indirect<br>programming<br>operations. | During SelectMAP<br>configuration, the<br>A[25:00] pins are not<br>used and are<br>high-impedance.                                                                                                                                                                                                           | These pins are used<br>for user I/O. For<br>FPGA designs that do<br>not use the XCF128X,<br>the FPGA A[25:00]<br>pins are ignored by<br>the XCF128X A[22:0]<br>pins when E# is<br>disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect the<br>flash controller<br>address bus to the<br>FPGA A[22:00] pins.                                 | The indirect<br>programming core<br>drives a 26-bit<br>address to the FPGA<br>A[25:00] pins. The<br>lower 23 address bits<br>(A[22:00]) are applied<br>to the XCF128X. Thus,<br>the FPGA A[25:23]<br>are actively driven<br>during indirect<br>programming, but<br>unused by the<br>XCF128X. |

#### Table 2-1: Platform Flash XL and FPGA SelectMAP Configuration Signals and Connections (Cont'd)



| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Function during<br>FPGA Configuration                                                                                                                                            | Function after<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                       | Function during<br>Indirect XCF128X<br>Programming                                                                    |
|----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| DQ[15:0]                         | D[15:0]          | This is the SelectMAP<br>(x16) data bus. Connect<br>each XCF128X data pin<br>(DQ[15:0]) to the<br>corresponding FPGA<br>SelectMAP data pin<br>(D[15:0]). During the<br>configuration sequence,<br>the XCF128X outputs a<br>16-bit data word from its<br>array to the data bus after<br>the rising-edge in each<br>clock cycle The FPGA<br>SelectMAP data bus also<br>includes pins D[31:16].<br>However, the FPGA<br>detects the 16-bit bus<br>width from the initial<br>bitstream data pattern on<br>D[7:0]. Thus, the FPGA<br>ignores activity on<br>D[31:16]. | The FPGA registers the<br>data from the<br>SelectMAP (x16) data<br>bus on the rising edge of<br>CCLK.                                                                            | These pins can be<br>used for user I/O <sup>(1)</sup> .<br>For FPGA designs<br>that do not use the<br>XCF128X, the FPGA<br>D[15:0] pins are<br>ignored by the<br>XCF128X DQ[15:0]<br>pins when E# is<br>disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect the<br>flash controller data<br>bus to the FPGA<br>D[15:0] pins. | The indirect<br>programming core<br>uses the FPGA<br>D[15:0] pins to<br>drive/receive data<br>to/from the<br>XCF128X. |
| W#                               | FWE_B            | This is the XCF128X<br>active-Low, write enable<br>control input. Connect<br>the XCF128X W# pin to<br>the FPGA FWE_B pin.<br>Connect the signal to an<br>external pull-up resistor<br>to keep W# High<br>throughout the<br>configuration process.                                                                                                                                                                                                                                                                                                                | During SelectMAP<br>configuration, FWE_B is<br>not used and is<br>high-impedance. The<br>external resistor pulls<br>the W# pin High to<br>disable the XCF128X<br>write function. | This pin can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that do<br>not use the XCF128X,<br>the FPGA FWE_B<br>state is ignored by the<br>XCF128X W# pin<br>when E# is disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect the<br>flash controller<br>write-enable to the<br>FWE_B pin.                      | The indirect<br>programming core<br>drives FWE_B Low or<br>High as necessary for<br>programming the<br>XCF128X.       |
| G#                               | FOE_B            | This is the XCF128X<br>active-Low, output<br>enable control input.<br>Connect the XCF128X G#<br>pin to the FPGA FOE_B<br>pin. Connect this input to<br>an external pull-down<br>resistor to keep G# Low<br>throughout the<br>configuration process.                                                                                                                                                                                                                                                                                                              | During SelectMAP<br>configuration, FOE_B is<br>not used and is<br>high-impedance. The<br>external resistor pulls<br>the G# pin Low to enable<br>the XCF128X output.              | This pin can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that do<br>not use the XCF128X,<br>the FPGA FOE_B<br>state is ignored by the<br>XCF128X G# pin<br>when E# is disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect the<br>flash controller<br>output-enable to the<br>FOE_B pin.                     | The indirect<br>programming core<br>drives FOE_B Low or<br>High as necessary for<br>programming the<br>XCF128X.       |

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name                                                      | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Function during<br>FPGA Configuration                                                                                                                        | Function after<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                                                                               | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                         |
|----------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E#                               | FCS_B                                                                 | This is the XCF128X<br>active-Low, chip select<br>control input. Connect<br>the XCF128X E# pin to the<br>FPGA FCS_B pin.<br>Connect this input to an<br>external pull-down<br>resistor to keep E# Low<br>throughout the<br>configuration process.                                                                                                                                                                                                                                                                                                                           | During SelectMAP<br>configuration, FCS_B is<br>not used and is<br>high-impedance. The<br>external resistor pulls<br>the E# pin Low to enable<br>the XCF128X. | For FPGA designs<br>that do not use the<br>XCF128X, the FPGA<br>design must drive<br>FCS_B High to<br>disable the XCF128X<br>and put it into a<br>low-power, quiescent<br>state. Otherwise, the<br>XCF128X can<br>continue to drive<br>array data to the<br>FPGA data pins.<br>For FPGA designs<br>that access to the<br>XCF128X, connect the<br>flash controller<br>chip-select to the<br>FCS_B pin. | The indirect<br>programming core<br>drives FCS_B Low or<br>High as necessary for<br>programming the<br>XCF128X.                                                                                            |
| L#                               | IO_L9P_CC_GC_4<br>(Virtex-5 FPGA)<br>or IO_L18P_24<br>(Virtex-6 FPGA) | This is the XCF128X<br>active-Low, address latch<br>enable control input.<br>Connect this input to the<br>named FPGA pin. (See<br>FPGA Pin Name<br>column.) An external<br>pull-up resistor must be<br>connected to L# to keep<br>L# High throughout the<br>configuration process. A<br>starting read address is<br>latched into the<br>XCF128X's internal<br>address counter at the<br>beginning of the<br>configuration sequence.<br>Disabling L# prevents<br>other addresses from<br>corrupting the internal<br>address counter during<br>the configuration<br>sequence. | During configuration,<br>the named FPGA I/O is<br>unused and is<br>high-impedance. The<br>external resistor pulls<br>the L# pin High.                        | This pin can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that do<br>not use the XCF128X,<br>the activity on the<br>named FPGA pin is<br>ignored by the<br>XCF128X L# pin<br>when the E# is<br>disabled.<br>For FPGA designs<br>that access the<br>XCF128X, drive L# to<br>a constant Low to<br>enable the XCF128X<br>address latch in<br>asynchronous<br>read/write<br>operations.   | The indirect<br>programming core<br>drives the XCF128X<br>L# control input Low<br>through the named<br>FPGA pin to enable<br>the XCF128X address<br>latch for<br>asynchronous<br>read/write<br>operations. |
| N/A                              | BUSY                                                                  | This is the FPGA BUSY<br>output pin. Do not<br>connect this pin. Use it<br>only for SelectMAP<br>readback, which is not<br>supported in this setup.                                                                                                                                                                                                                                                                                                                                                                                                                         | This pin drives Low<br>during configuration.                                                                                                                 | This pin is dedicated for configuration.                                                                                                                                                                                                                                                                                                                                                              | This pin is dedicated for configuration.                                                                                                                                                                   |

#### Table 2-1: Platform Flash XL and FPGA SelectMAP Configuration Signals and Connections (Cont'd)



| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name                                       | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Function during<br>FPGA Configuration                                                                                                                                                                         | Function after<br>FPGA<br>Configuration                                       | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                        |
|----------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                              | DONE                                                   | This is the FPGA<br>open-drain DONE status<br>indicator. The open-drain<br>DONE must be<br>connected to a strong,<br>external pull-up to ensure<br>a fast rising-edge at the<br>end of the configuration<br>process. The sample<br>schematic also connects<br>DONE to an LED driver<br>for visible indication of<br>FPGA configuration<br>DONE status.                                                                                                                               | The FPGA drives DONE<br>Low during<br>configuration. At the<br>end of a successful<br>configuration sequence,<br>DONE switches to<br>high-impedance,<br>allowing an external<br>pull-up to pull DONE<br>High. | DONE maintains its<br>state from the end of<br>the configuration<br>sequence. | Because the indirect<br>programming<br>solution downloads a<br>design to the FPGA, a<br>strong external<br>pull-up is required to<br>pull DONE High and<br>enable the FPGA<br>indirect<br>programming design<br>to start. |
| N/A                              | CS_B<br>(Virtex-5 FPGA)<br>or CSI_B<br>(Virtex-6 FPGA) | This is the FPGA<br>SelectMAP chip select<br>control input. For a single<br>FPGA, and for the first<br>FPGA of a multi-FPGA<br>daisy-chain, connect<br>CS_B/CSI_B to ground to<br>select the FPGA for<br>configuration. For other<br>FPGAs in a multi-FPGA<br>parallel configuration<br>daisy-chain, see the<br>CSO_B signal description<br>for CS_B/CSI_B<br>connections. The<br>Virtex-5 FPGA chip select<br>pin is named CS_B. The<br>Virtex-6 FPGA select pin<br>is named CSI_B. | The CS_B/CSI_B input<br>must be held Low<br>throughout<br>configuration to keep<br>the FPGA selected.                                                                                                         | The sample<br>schematic grounds<br>CS_B/CSI_B, making<br>it unusable.         | This input is unused.<br>CS_B/CSI_B is<br>grounded in the<br>sample schematic.                                                                                                                                            |
| N/A                              | RDWR_B                                                 | FPGA SelectMAP<br>read/write control input.<br>Connect this input to<br>ground to put the<br>SelectMAP interface into<br>write mode for<br>configuration.                                                                                                                                                                                                                                                                                                                            | The RDWR_B input<br>must be held Low<br>throughout<br>configuration to keep<br>SelectMAP bus in write<br>mode.                                                                                                | The sample<br>schematic grounds<br>RDWR_B, making it<br>unusable.             | Unused. RDWR_B is grounded in the sample schematic.                                                                                                                                                                       |

| Table 2-1: | Platform Flash XL | and FPGA SelectMA | P Configuration Signals a | nd Connections (Cont'd) |
|------------|-------------------|-------------------|---------------------------|-------------------------|
|            |                   |                   |                           |                         |

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                     | Function during<br>FPGA Configuration                                                                                                                                                                                                                                                                           | Function after<br>FPGA<br>Configuration            | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                              | HSWAPEN          | This signal enables or<br>disables internal pull-ups<br>on FPGA I/O pins during<br>configuration. The<br>sample schematic<br>connects HSWAPEN to<br>ground in order to enable<br>internal pull-ups.<br>Optionally, HSWAPEN<br>can be pulled High to<br>disable the internal<br>pull-ups.                                                                                                                                                             | <ul> <li>The HSWAPEN input<br/>enables or disables<br/>internal pull-ups on<br/>non-dedicated FPGA<br/>I/O pins during<br/>configuration.</li> <li>HSWAPEN=0<br/>enables the internal<br/>pull-ups.</li> <li>HSWAPEN=1<br/>disables the internal<br/>pull-ups.</li> </ul>                                       | N/A                                                | Because the indirect<br>programming<br>sequence has periods<br>in which the FPGA is<br>unconfigured or<br>configured, the<br>HSWAPEN input<br>state can cause<br>internal pull-ups to<br>switch on or off<br>during the indirect<br>programming<br>sequence. The sample<br>schematic and<br>indirect<br>programming FPGA<br>core is designed to<br>maintain internal<br>pull-ups for most<br>pins. |
| N/A                              | CSO_B            | When configuring a<br>single FPGA, CSO_B is<br>unused.<br>For multiple-FPGA,<br>parallel configuration<br>daisy-chains, connect the<br>CSO_B pin of each FPGA<br>to the CS_B/CSI_B pin of<br>the next FPGA in the<br>parallel configuration<br>daisy-chain. Connect a<br>strong external pull-up to<br>each CSO_B signal used<br>in the daisy-chain. See<br>Parallel Daisy Chain in<br>the FPGA configuration<br>user guide for more<br>information. | CSO_B is not used for<br>single FPGA<br>configuration. CSO_B is<br>normally<br>high-impedance during<br>configuration. For a<br>multiple-FPGA parallel<br>configuration<br>daisy-chain, CSO_B can<br>drive Low to enable the<br>next FPGA in the<br>daisy-chain to receive a<br>bitstream from the data<br>bus. | This pin can be used for user I/O <sup>(1)</sup> . | This pin is<br>high-impedance with<br>an internal pull-up.                                                                                                                                                                                                                                                                                                                                         |

| Table 2-1: | Platform Flash XL | and FPGA SelectMAP | Configuration Si | ignals and Connections ( | (Cont'd) |
|------------|-------------------|--------------------|------------------|--------------------------|----------|
|            |                   |                    |                  |                          |          |



| Platform<br>Flash XL<br>Pin Name  | FPGA<br>Pin Name                                                                                                            | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                      | Function during<br>FPGA Configuration                                                                                   | Function after<br>FPGA<br>Configuration                 | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                               | RS[1:0]                                                                                                                     | These are the FPGA<br>revision select pins. For<br>the basic FPGA<br>configuration shown in<br>the sample schematic, do<br>not connect the RS[1:0]<br>pins (See <u>XAPP1100</u> ,<br><i>MultiBoot with</i><br><i>Virtex-5 FPGAs and</i><br><i>Platform Flash XL</i> , for<br>alternate<br>implementations that<br>support MultiBoot). | These pins are<br>high-impedance. They<br>can drive High or Low<br>due to MultiBoot<br>command during<br>configuration. | These pins can be<br>used for user I/O <sup>(1)</sup> . | When RS[1:0] pins are<br>deemed unused, the<br>indirect<br>programming core<br>sets the RS[1:0] pins<br>to high-impedance<br>with an internal<br>pull-up. When using<br>the MultiBoot scheme<br>from the MultiBoot scheme<br>from the MultiBoot<br>with Virtex-5 FPGAs<br>and Platform Flash XL<br>application note,<br>specify the XCF128X<br>address bit<br>assignments for the<br>RS[1:0] pins in the<br>iMPACT (11.3 or<br>later) programming<br>flow. |
| WP#                               | N/A                                                                                                                         | This is the XCF128X<br>active-Low, write-protect<br>pin. Connect WP# to an<br>external pull-up resistor<br>to enable in-system<br>programming.                                                                                                                                                                                        | N/A                                                                                                                     | The external resistor<br>pulls the WP# pin<br>High.     | WP# must be High to<br>enable XCF128X<br>programming.                                                                                                                                                                                                                                                                                                                                                                                                      |
| N/A                               | V <sub>BATT</sub>                                                                                                           | This is the battery-backed<br>AES key supply. Connect<br>this to ground. It is not<br>used because XCF128X is<br>not compatible with the<br>AES 8-bit parallel data<br>bus (or serial)<br>requirement.                                                                                                                                | N/A                                                                                                                     | N/A                                                     | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| N/A                               | V <sub>CCINT</sub>                                                                                                          | This is the FPGA V <sub>CCINT</sub> power supply.                                                                                                                                                                                                                                                                                     | This is the FPGA V <sub>CCINT</sub> power supply.                                                                       | This is the FPGA<br>V <sub>CCINT</sub> power<br>supply. | This is the FPGA<br>V <sub>CCINT</sub> power<br>supply.                                                                                                                                                                                                                                                                                                                                                                                                    |
| N/A                               | V <sub>CCAUX</sub>                                                                                                          | This is the 2.5V FPGA V <sub>CCAUX</sub> power supply.                                                                                                                                                                                                                                                                                | This is the FPGA V <sub>CCAUX</sub> power supply.                                                                       | This is the FPGA<br>V <sub>CCAUX</sub> power<br>supply. | This is the FPGA<br>V <sub>CCAUX</sub> power<br>supply.                                                                                                                                                                                                                                                                                                                                                                                                    |
| V <sub>DD</sub>                   | N/A                                                                                                                         | 1.8V XCF128X core<br>power supply                                                                                                                                                                                                                                                                                                     | XCF128X core power supply.                                                                                              | XCF128X core power supply.                              | XCF128X core power supply.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| V <sub>DDQ</sub> /V <sub>PP</sub> | VCCO_0<br>VCCO_1<br>VCCO_2<br>VCCO_4<br>(Virtex-5 FPGA)<br>or<br>VCCO_0<br>VCCO_24<br>VCCO_24<br>VCCO_34<br>(Virtex-6 FPGA) | <ul> <li>This is the I/O (bank) power supply:</li> <li>Virtex-5 FPGA V<sub>CCO</sub> = 3.3V (or 2.5V).</li> <li>Virtex-6 FPGA V<sub>CCO</sub> = 2.5V.</li> </ul>                                                                                                                                                                      | This is the I/O power<br>supply.                                                                                        | This is the I/O power<br>supply.                        | This is the I/O power<br>supply.                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description          | Function during<br>FPGA Configuration                                                                                 | Function after<br>FPGA<br>Configuration | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                          |
|----------------------------------|------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $V_{SS}/V_{SSQ}$                 | GND              | This is a ground.                         | This is a ground.                                                                                                     | This is a ground.                       | This is a ground.                                                                                                                                                                                           |
| N/A                              | User I/O         | This is FPGA user<br>(non-dedicated) I/O. | This I/O is<br>high-impedance.<br>Internal pull-up is<br>dictated by HSWAPEN<br>control input (see<br>HSWAPEN above). | This is user-defined I/O.               | All user I/O that are<br>not included in the set<br>of FPGA BPI<br>configuration pins are<br>high-impedance with<br>an internal pull-up.<br>This matches<br>unconfigured I/O<br>behavior with<br>HSWAPEN=0. |

| Table 2-1: | Platform Flash XL and FF | <b>'GA SelectMAP Configuration</b> | on Signals and Connections (Cont'd) |  |
|------------|--------------------------|------------------------------------|-------------------------------------|--|
|            |                          | er eeleen al eelingalaale          |                                     |  |

#### Notes:

1. After configuration, the default FPGA design configuration of an unused User I/O is high-impedance with an internal pull-down.

### Slave SelectMAP Configuration from Platform Flash XL

The FPGA Slave SelectMAP mode configuration process from a Platform Flash XL is described in Figure 2-3 and its notes.





Figure 2-3: FPGA Slave SelectMAP Configuration Flow

#### Notes:

- 1. External resistors hold many of the XCF128X and FPGA control/input signals High or Low to enable XCF128X array output and FPGA configuration. These settings include:
  - M[2:0], CS\_B/CSI\_B=0
  - RDWR\_B=0
  - W#=1
  - G#=0
  - E#=0
  - L#=1
  - A[22:0]=0x000000
  - A free-running clock drives the XCF128X K and FPGA CCLK.
- 2. Configuration starts with power-up (PROGRAM\_B is pulled and kept High) or with a High-Low-High pulse to PROGRAM\_B.
- 3. For power-up configuration, INIT\_B starts Low. For configuration initiated using PROGRAM\_B, INIT\_B drives Low when PROGRAM\_B is pulsed Low.
- 4. When CS\_B/CSI\_B is held Low, BUSY is driven Low at the start of configuration.

- 5. RS[1:0] are typically high-impedance. However, a MultiBoot (or Fallback event in Master Select MAP or Master BPI mode) can cause RS[1:0] to drive High or Low.
- 6. INIT\_B releases at the end of the FPGA's internal initialization process. An external resistor pulls INIT\_B High. On the rising-edge of INIT\_B, the FPGA samples its M[2:0] pins to determine the configuration mode.
- 7. Three K clock cycles after READY\_WAIT goes High, the XCF128X latches the starting read address from A[22:0] to its internal address counter for the ensuing synchronous array read operation.
- 8. After a few clock cycles of latency following the address latching event, the XCF128X outputs the first 16-bit data word from the starting address in its array. On every clock cycle thereafter, the XCF128X outputs the next 16-bit data word from the array. The FPGA registers the 16-bit data word on the rising-edge of CCLK.
- 9. For a multi-FPGA parallel configuration daisy-chain, CSO\_B can drive Low to select the next FPGA in the daisy-chain for bitstream loading from the data bus.
- 10. Near the last 16-bit word of the bitstream, the FPGA begins its startup sequence.
- 11. If the FPGA detects a CRC error during bitstream delivery, the FPGA drives its INIT\_B pin Low. DONE stays Low.
- 12. If the FPGA successfully receives the bitstream, the FPGA releases its DONE pin during the startup sequence, and an external resistor pulls DONE High.
- 13. During the startup sequence, the multi-purpose pins are activated with their configurations from the user's FPGA design.
- 14. The FPGA design must drive the FPGA FCS\_B pin High to disable the XCF128X (i.e., stop data output from the XCF128X).





## Chapter 3

## **Alternate Configuration Modes**

### Master SelectMAP Configuration Mode

Platform Flash XL is optimized for Slave SelectMAP configuration mode, but Master SelectMAP configuration mode can also be used. Platform Flash XL connectivity for Master SelectMAP mode is similar to the Slave SelectMAP mode, shown in Figure 2-1, page 16, except for the differences listed below.

The user should be aware of the differences between Master SelectMAP mode and Slave SelectMAP configuration mode:

- FPGA Mode pins (M[2:0]) must be properly set for Master SelectMAP configuration mode.
- The FPGA drives the configuration clock (CCLK) no external clock source is needed.
- BitGen **-g ConfigRate** sets the nominal CCLK configuration frequency. For appropriate settings, see "Determining the Maximum Configuration Clock Frequency," page 45.
- The FPGA supports the Fallback feature in Master SelectMAP mode. When a configuration error is detected, the Fallback feature causes the FPGA to drive its RS[1:0] pins Low and re-initiate configuration. If the FPGA detects a configuration error on the Fallback attempt, the FPGA drives INIT\_B Low and ends the configuration process.

### Master BPI-Up Configuration Mode

Platform Flash XL is optimized for Slave SelectMAP configuration mode, but the standard flash interface is also compatible with the Master BPI-Up configuration mode with these key requirements:

- Mode pins (M[2:0]) must be set for Master BPI-Up configuration mode.
- Special control of the power supply sequence or delay of the FPGA configuration process can be required to ensure power-on readiness of Platform Flash XL before the FPGA BPI address sequence. For details, refer to the "Power-On Sequence Precautions" section in <u>UG191</u>, *Virtex-5 FPGA Configuration User Guide* or <u>UG360</u>, *Virtex-6 FPGA Configuration User Guide*.
- The FPGA drives the configuration clock (CCLK) no external clock source is needed.
- BitGen **-g ConfigRate** sets the nominal CCLK configuration frequency. For appropriate settings, see "Determining the Maximum Configuration Clock Frequency," page 45.



- The FPGA drives the main flash control pins (E, G, W). The external resistor requirements for these pins in Master BPI mode are different than the requirements for Slave SelectMAP. External pull-up resistors are recommended for the XCF128X E, G, and W pins.
- The FPGA sets the flash burst read start address. No external pull-down resistors are required on the address lines in Master BPI mode.
- The FPGA CS\_B/CSI\_B and RDWR\_B pins are not used in Master BPI mode and do not require a connection to ground as shown in the Slave SelectMAP setup.

The FPGA Master BPI-Up configuration mode enables MultiBoot and Fallback. See the FPGA configuration user guide for details on the Master BPI-Up mode and the ISE<sup>®</sup> software manuals for details on the BitGen software utility. See Figure 3-1 or Figure 3-2 for example Master BPI-Up configuration mode connections with the Virtex-5 FPGA or Virtex-6 FPGA, respectively. Refer to "FPGA BPI-Up Configuration Signals," page 35 for details on the Master BPI-Up configuration sequence.

*Caution!* Platform Flash XL does not support the FPGA Master BPI-Down mode in which the bitstream is stored in a descending fashion from a higher to a lower address.



*Figure 3-1:* Virtex-5 FPGA Master BPI-Up Configuration Mode from Platform Flash XL with Indirect Programming Support

Notes relating to Figure 3-1:

- 1. The JTAG connections are shown for a simple, single-device JTAG scan chain. When multiple devices are on the JTAG scan chain, use the proper IEEE Std. 1149.1 daisy-chain technique to connect the JTAG signals. The TCK signal integrity is critical for JTAG operation. Route, terminate, and if necessary, buffer the TCK signal appropriately to ensure signal integrity for the devices in the JTAG scan chain.
- 2. The FPGA mode (M[2:0]) pins are shown set to Master BPI-Up mode (010). The implementation of a board-level option that enables the user to change the FPGA mode pins to JTAG mode (101) is recommended to enable JTAG-based debug capability for the FPGA during design prototyping—without interference from the Master BPI configuration activities.
- 3. CCLK signal integrity is critical. Route and terminate the CCLK signal appropriately to ensure good signal integrity at the device K pin and at the FPGA CCLK pin.
- 4. The iMPACT software requires the Virtex-5 FPGA's IO\_L9P\_CC\_GC\_4 connection to the XCF128X Flash device L pin to support JTAG based indirect programming.
- 5. The FPGA HSWAPEN pin is tied to ground in this sample schematic. HSWAPEN can alternatively be tied High. Review the data sheet for the effect of the alternate HSWAPEN setting.
- 6. The Virtex-5 FPGA does not support AES decryption in the 16-bit-wide configuration mode shown in this sample schematic. Thus, the V<sub>BATT</sub> decryptor key battery power supply is unused and is tied to GND.
- 7. This sample schematic supports single bitstream configuration. Thus, the FPGA RS[1:0] pins are not connected in this sample schematic. See the FPGA configuration user guide for use of the RS[1:0] pins to enable Fallback feature support. iMPACT 11.2 (or earlier) does not support indirect programming with addresses routed through the RS[1:0] pins.
- 8. DONE LED lights when DONE is High. INIT\_B/CRC-Error LED lights when INIT\_B is Low. Adjust the LED circuits and pull-up values for desired lighting results.
- 9. V<sub>DDQ</sub>, V<sub>CCO</sub> supplies, pull-up resistors, and V<sub>REF</sub>, can alternately be connected to a 2.5V supply for I/O operation at 2.5V.
- 10. The required READY\_WAIT (INIT\_B) pull-up value is board dependent, but it must be strong enough to meet the READY\_WAIT rise time ( $T_{RWRT}$ ) requirement.



UG438\_c3\_04\_111809

XILINX®

*Figure 3-2:* Virtex-6 FPGA Master BPI-Up Configuration Mode from Platform Flash XL with Indirect Programming Support

Notes relating to Figure 3-2:

- 1. The JTAG connections are shown for a simple, single-device JTAG scan chain. When multiple devices are on the JTAG scan chain, use the proper IEEE Std 1149.1 daisy-chain technique to connect the JTAG signals. The TCK signal integrity is critical for JTAG operation. Route, terminate, and if necessary, buffer the TCK signal appropriately to ensure signal integrity for the devices in the JTAG scan chain.
- 2. The FPGA mode (M[2:0]) pins are shown set to Master BPI-Up mode (010). The implementation of a board-level option that enables the user to change the FPGA mode pins to JTAG mode (101) is recommended to enable JTAG-based debug capability for the FPGA during design prototyping—without interference from the Master BPI-Up configuration activities.
- 3. CCLK signal integrity is critical. Route and terminate the CCLK signal appropriately to ensure good signal integrity at the XCF128X K pin and at the FPGA CCLK pin.
- 4. The iMPACT software requires the Virtex-6 FPGA's IO\_L18P\_24 connection to the device's L pin to support JTAG-based indirect programming.
- 5. The FPGA HSWAPEN pin is tied to ground in this sample schematic. HSWAPEN can alternatively be tied High. Review the FPGA data sheet for the effect of the alternate HSWAPEN setting.
- 6. The Virtex-6 FPGA does not support AES decryption in the 16-bit wide configuration mode shown in this sample schematic. Thus, the  $V_{BATT}$  decryptor key battery power supply is unused and is tied to GND.
- 7. This sample schematic supports single bitstream configuration. Thus, FPGA RS[1:0] pins are not connected in this sample schematic. See the FPGA configuration user guide for use of the RS[1:0] pins. Use iMPACT 11.3 (or later) to indirectly program the XCF128X when a few address bits are routed through the RS[1:0] pins to the XCF128X.
- 8. DONE LED lights when DONE is High. INIT\_B/CRC-Error LED lights when INIT\_B is Low. Adjust the LED circuits and pull-up values for desired lighting results.
- 9. See <u>DS152</u>, *Virtex-6 FPGA Data Sheet: DC and Switching Characteristics*, for the V<sub>CCINT</sub> supply voltage.
- 10. The required READY\_WAIT (INIT\_B) pull-up value is board dependent, but it must be strong enough to meet the READY\_WAIT rise time ( $T_{RWRT}$ ) requirement.

### FPGA BPI-Up Configuration Signals

The BPI-Up configuration mode interface signals that influence the successful start and stop of data transfer are listed in Table 3-1. Details on the Virtex-5 FPGA configuration sequence and power-up considerations are discussed in Chapter 3, "FPGA BPI-Up Configuration from Platform Flash XL."



| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name                                                                                                                   | Signal/Connection<br>Description                                                                                                                                                                                                                                                              | Function during<br>FPGA<br>Configuration                                                                                                                                                      | Function after<br>FPGA<br>Configuration                                                                                                                                       | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                                                                              |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                              | TMS JTAG test mode select.<br>Connect from cable<br>header to TMS pin in all<br>devices in the JTAG chain.<br>Buffer as necessary. |                                                                                                                                                                                                                                                                                               | JTAG functionality is<br>always available. Do<br>not perform JTAG<br>operations during BPI<br>configuration. JTAG                                                                             | JTAG functionality is always available.                                                                                                                                       | JTAG is the required<br>access path to the<br>FPGA for indirect<br>programming of the<br>XCF128X. An FPGA                                                                                                                                                                                                                                                       |
| N/A                              | TCK                                                                                                                                | JTAG test clock. Connect<br>from cable header to TCK<br>pin in all devices in JTAG<br>chain. Signal integrity is<br>critical. Buffer as<br>necessary.                                                                                                                                         | operations during<br>configuration can<br>interrupt the<br>configuration sequence.                                                                                                            |                                                                                                                                                                               | design (i.e., indirect<br>programming core) is<br>downloaded through<br>JTAG to the FPGA.<br>This bridges the<br>FPGA's JTAG port<br>with the FPGA's pin<br>interface to the<br>XCF128X. Commands<br>and data are<br>sent/received<br>through JTAG to the<br>FPGA indirect<br>programming core to<br>program and perform<br>other operations on<br>the XCF128X. |
| N/A                              | TDO                                                                                                                                | JTAG test data output.<br>Daisy-chain to TDI pin of<br>next device in JTAG chain.<br>Last device returns TDO<br>to the cable header.                                                                                                                                                          | _                                                                                                                                                                                             |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                 |
| N/A                              | TDI                                                                                                                                | JTAG test data input.<br>Daisy-chain from TDO of<br>prior device in JTAG<br>chain. First device<br>receives TDI from cable<br>header.                                                                                                                                                         |                                                                                                                                                                                               |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                 |
| N/A                              | M[2:0]                                                                                                                             | These are the FPGA<br>configuration mode<br>inputs. Set M[2:0]=010 for<br>Master BPI-Up mode.<br>Implementing mode<br>switches to enable JTAG<br>mode (M[2:0]=101)<br>allows JTAG debug<br>without interference from<br>the Master BPI<br>configuration activities.                           | On the rising edge of<br>INIT_B, the FPGA<br>samples the M[2:0] pins<br>to determine the<br>configuration mode.<br>See the FPGA<br>configuration user<br>guide for the full list of<br>modes. | Dedicated for<br>configuration.                                                                                                                                               | Dedicated for<br>configuration.                                                                                                                                                                                                                                                                                                                                 |
| RP#                              | PROGRAM_B                                                                                                                          | These are the active-Low<br>FPGA configuration and<br>XCF128X reset inputs.<br>Connect XCF128X RP# to<br>FPGA PROGRAM_B.<br>Connect the signal to an<br>external pull-up. Connect<br>the signal to a pushbutton<br>to ground to allow<br>manual initiation of the<br>reconfiguration process. | Driving PROGRAM_B<br>Low clears the FPGA<br>configuration and<br>initiates an FPGA<br>reconfiguration<br>sequence. The signal<br>must remain High<br>during the<br>configuration process.     | PROGRAM_B must<br>remain High after<br>configuration.<br>Driving<br>PROGRAM_B Low<br>clears the FPGA<br>configuration and<br>initiates an FPGA<br>reconfiguration<br>process. | These inputs are<br>unused.<br>PROGRAM_B must<br>remain High during<br>indirect<br>programming. If<br>PROGRAM_B drives<br>Low during indirect<br>programming, the<br>programming process<br>will be interrupted.                                                                                                                                                |

| Table 3-1: | FPGA BPI-Up | Configuration | Mode Signals a | and Descriptions |
|------------|-------------|---------------|----------------|------------------|
|------------|-------------|---------------|----------------|------------------|

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Function during<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Function after<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                                                                                                                    | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                                                                        |
|----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| READY_WAIT                       | INIT_B           | This is the configuration<br>sequence initialization<br>handshake signal.<br>Connect XCF128X<br>READY_WAIT to FPGA<br>INIT_B. Connect this<br>signal to an external<br>pull-up resistor capable of<br>transitioning the signal<br>from Low to High in<br>$T_{RWRT}$ time as specified in<br>DS617, Platform Flash XL<br>High-Density Configuration<br>and Storage Device. The<br>FPGA and XCF128X drive<br>this signal Low during<br>their respective<br>power-on-reset (POR)<br>processes. When each<br>device completes its POR<br>process, it releases its pin<br>to high-impedance. The<br>external pull-up pulls the<br>signal High. The rising<br>edge causes the XCF128X<br>to latch the starting read<br>address to its internal<br>address to its internal<br>address counter and<br>causes the FPGA to start<br>its configuration process. | At the start of<br>configuration, the<br>FPGA drives INIT_B<br>Low during its<br>initialization process.<br>At the end of<br>initialization, the FPGA<br>releases INIT_B to<br>high-impedance. The<br>external resistor pulls<br>INIT_B High. The rising<br>edge of INIT_B causes<br>the FPGA to sample the<br>configuration mode<br>from the M[2:0] pins<br>and start a<br>corresponding<br>configuration sequence.<br>If a CRC error is<br>detected during the<br>configuration process,<br>the FPGA drives<br>INIT_B Low. | This signal is<br>normally<br>high-impedance.<br>This signal can drive<br>Low to indicate CRC<br>error from<br>configuration<br>process or from a<br>Readback CRC<br>function.                                                                                                                                                                                                                                                             | This signal must be<br>allowed to be pulled<br>High by the external<br>pull-up resistor. The<br>FPGA can drive<br>INIT_B Low or can<br>put INIT_B in<br>high-impedance. The<br>FPGA drives INIT_B<br>Low during the<br>indirect<br>programming process<br>to indicate<br>configuration<br>initialization or CRC<br>error for the FPGA<br>design download. |
| К                                | CCLK             | This is the configuration<br>clock. Connect the<br>XCF128X K pin to the<br>FPGA CCLK pin. The<br>FPGA drives the CCLK<br>pin with a clock signal in<br>Master BPI-Up mode.<br>Configuration clock<br>signal integrity is critical.<br>Apply necessary<br>termination to ensure<br>signal integrity at both the<br>XCF128X K pin and FPGA<br>CCLK pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | After INIT_B goes High<br>and the FPGA detects<br>the Master BPI-Up<br>mode setting, the FPGA<br>drives a clock signal out<br>of the CCLK pin. The<br>CCLK signal is also<br>used to drive the<br>FPGA's internal<br>configuration logic. For<br>each clock cycle, the<br>XCF128X's internal<br>address counter is<br>incremented, the<br>corresponding 16 bits of<br>array data is output to<br>the data bus, and the<br>FPGA registers the data<br>on the next rising edge<br>of CCLK.                                     | This is a dedicated<br>CCLK pin. After<br>successful<br>configuration, the<br>FPGA puts the CCLK<br>pin in a<br>high-impedance<br>state. If the CCLK<br>termination scheme<br>(e.g., parallel<br>Thevenin<br>termination)<br>maintains a<br>high-impedance<br>CCLK at an<br>intermediate voltage<br>level, then drive the<br>CCLK to a valid High<br>or Low state through<br>the STARTUP<br>primitive. See the<br>FPGA libraries<br>guide. | Unused.                                                                                                                                                                                                                                                                                                                                                   |

#### Table 3-1: FPGA BPI-Up Configuration Mode Signals and Descriptions (Cont'd)



| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name     | Signal/Connection<br>Description                                                                                                                                                                                                                                                                             | Function during<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Function after<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                         | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                   |
|----------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A[22:0]                          | A[22:00]<br>A[25:23] | This is the XCF128X<br>address bus. Connect each<br>XCF128X address pin<br>(A[22:0]) to the<br>corresponding FPGA<br>address pin (A[22:00]). In<br>Master BPI-Up mode, the<br>FPGA drives addresses<br>onto the address bus<br>(A[25:00]).<br>Do not connect the FPGA<br>A[25:23] pins.                      | In Master BPI-Up<br>mode, the FPGA drives<br>addresses onto the<br>address bus. After the<br>rising edge of each<br>CCLK cycle, the FPGA<br>drives the next address<br>onto the address bus.<br>The XCF128X latches<br>the initial BPI address<br>from the FPGA as the<br>starting read address<br>for the XCF128X's<br>internal address<br>counter. After the<br>XCF128X latches the<br>initial BPI address, the<br>XCF128X uses its<br>internal address<br>counter for reading<br>array data and ignores<br>the address from the<br>FPGA on the address<br>bus. | This bus can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that<br>do not use the<br>XCF128X, the FPGA<br>A[25:00] pins are<br>ignored by the<br>XCF128X A[22:0]<br>pins when E# is<br>disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect<br>the flash controller<br>address bus to the<br>FPGA A[22:00] pins. | The indirect<br>programming core<br>drives a 26-bit<br>address to the FPGA<br>A[25:00] pins. The<br>lower 23 address bits<br>(A[22:00]) are applied<br>to the XCF128X. Thus,<br>the A[25:23] FPGA<br>pins are actively<br>driven during<br>indirect<br>programming, but<br>unused by the<br>XCF128X. |
| DQ[15:0]                         | D[15:0]              | This is the BPIx16 data<br>bus. Connect each<br>XCF128X data pin<br>(DQ[15:0]) to the<br>corresponding FPGA BPI<br>data pin (D[15:0]). During<br>the configuration<br>sequence, the XCF128X<br>outputs a 16-bit data word<br>from its array to the data<br>bus after the rising-edge<br>in each clock cycle. | The FPGA registers the<br>data from the BPIx16<br>data bus on the rising<br>edge of CCLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | This bus can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that<br>do not use the<br>XCF128X, the FPGA<br>D[15:0] pins are<br>ignored by the<br>XCF128X DQ[15:0]<br>pins when E# is<br>disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect<br>the flash controller<br>data bus to the FPGA<br>D[15:0] pins.     | The indirect<br>programming core<br>uses the FPGA<br>D[15:0] pins to drive<br>and receive data to<br>and from the<br>XCF128X.                                                                                                                                                                        |
| W#                               | FWE_B                | This is the XCF128X<br>active-Low, write enable<br>control input. Connect the<br>XCF128X W# pin to the<br>FPGA FWE_B pin.<br>Connect this signal to an<br>external pull-up resistor<br>to keep W# High when the<br>XCF128X is not used.                                                                      | During Master BPI-Up<br>configuration, the<br>FPGA drives the<br>FWE_B pin High.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | This pin can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that<br>do not use the<br>XCF128X, the FPGA<br>FWE_B state is<br>ignored by the<br>XCF128X W# pin<br>when E# is disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect<br>the flash controller<br>write-enable to the<br>FWE_B pin.                     | The indirect<br>programming core<br>drives FWE_B Low or<br>High as necessary for<br>programming the<br>XCF128X.                                                                                                                                                                                      |

| <b>-</b> / / / |             | • • •           |              |               |                |
|----------------|-------------|-----------------|--------------|---------------|----------------|
| Table 3-1:     | FPGA BPI-Up | Configuration   | Mode Signals | s and Descrip | tions (Cont'd) |
|                |             | •••············ |              |               |                |

| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name                                                      | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Function during<br>FPGA<br>Configuration                                        | Function after<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                                                                                                      | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                         |
|----------------------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| G#                               | FOE_B                                                                 | This is the XCF128X<br>active-Low, output enable<br>control input. Connect the<br>XCF128X G# pin to the<br>FPGA FOE_B pin.<br>Connect this input to an<br>external pull-up resistor<br>to keep G# High when not<br>used.                                                                                                                                                                                                                                                                                                                                                   | During Master BPI-Up<br>configuration, the<br>FPGA drives the FOE_B<br>pin Low. | This pin can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that<br>do not use the<br>XCF128X, the FPGA<br>FOE_B state is<br>ignored by the<br>XCF128X G# pin<br>when E# is disabled.<br>For FPGA designs<br>that access the<br>XCF128X, connect<br>the flash controller<br>output-enable to the<br>FOE_B pin.                                                                 | The indirect<br>programming core<br>drives FOE_B Low or<br>High as necessary for<br>programming the<br>XCF128X.                                                                                            |
| E#                               | FCS_B                                                                 | This is the XCF128X<br>active-Low, chip select<br>control input. Connect the<br>XCF128X E# pin to the<br>FPGA FCS_B pin.<br>Connect this input to an<br>external pull-up resistor<br>to keep E# High when not<br>used.                                                                                                                                                                                                                                                                                                                                                     | During Master BPI-Up<br>configuration, the<br>FPGA drives the FCS_B<br>pin Low. | For FPGA designs<br>that do not use the<br>XCF128X, the FPGA<br>design must drive<br>FCS_B High to<br>disable the XCF128X<br>and put it into a<br>low-power, quiescent<br>state.<br>For FPGA designs<br>that access to the<br>XCF128X, connect<br>the flash controller<br>chip-select to the<br>FCS_B pin.                                                                                   | The indirect<br>programming core<br>drives FCS_B Low or<br>High as necessary for<br>programming the<br>XCF128X.                                                                                            |
| L#                               | IO_L9P_CC_GC_4<br>(Virtex-5 FPGA)<br>or IO_L18P_24<br>(Virtex-6 FPGA) | This is the XCF128X<br>active-Low, address latch<br>enable control input.<br>Connect this input to the<br>named FPGA pin (see<br>FPGA pin name column).<br>An external pull-up<br>resistor must be<br>connected to L# to keep L#<br>High throughout the<br>configuration process. A<br>starting read address is<br>latched into the<br>XCF128X's internal<br>address counter at the<br>beginning of the<br>configuration sequence.<br>Disabling L# prevents<br>other addresses from<br>corrupting the internal<br>address counter during<br>the configuration<br>sequence. | During configuration,<br>the named I/O is<br>unused and is<br>high-impedance.   | This pin can be used<br>for user I/O <sup>(1)</sup> . For<br>FPGA designs that<br>do not use the<br>XCF128X, the activity<br>on the named FPGA<br>pin is ignored by the<br>XCF128X L# pin<br>when E# is disabled.<br>For FPGA designs<br>that access the<br>XCF128X, drive L# to<br>a constant Low to<br>enable the XCF128X<br>address latch in<br>asynchronous<br>read/write<br>operations. | The indirect<br>programming core<br>drives the XCF128X<br>L# control input Low<br>through the named<br>FPGA pin to enable<br>the XCF128X address<br>latch for<br>asynchronous<br>read/write<br>operations. |

#### Table 3-1: FPGA BPI-Up Configuration Mode Signals and Descriptions (Cont'd)



| Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                             | Function during<br>FPGA<br>Configuration                                                                                                                                                                                                                                                                        | Function after<br>FPGA<br>Configuration                                       | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                              | DONE             | This is the FPGA<br>open-drain DONE status<br>indicator. The open-drain<br>DONE must be connected<br>to a strong, external<br>pull-up to ensure a fast<br>rising-edge at the end of<br>the configuration process.<br>The sample schematic also<br>connects DONE to an LED<br>driver for visible<br>indication of FPGA<br>configuration DONE<br>status.                                                                                                       | The FPGA drives<br>DONE Low during<br>configuration. At the<br>end of a successful<br>configuration sequence,<br>DONE switches to<br>high-impedance,<br>allowing an external<br>pull-up to pull DONE<br>High.                                                                                                   | DONE maintains its<br>state from the end of<br>the configuration<br>sequence. | Because the indirect<br>programming<br>solution downloads a<br>design to the FPGA, a<br>strong external<br>pull-up is required to<br>pull DONE High and<br>enable the FPGA<br>indirect<br>programming design<br>to start.                                                                                                                                                                          |
| N/A                              | HSWAPEN          | This input enables or<br>disables internal pull-ups<br>on FPGA I/O pins during<br>configuration. The sample<br>schematic connects<br>HSWAPEN to ground in<br>order to enable internal<br>pull-ups. Optionally,<br>HSWAPEN can be pulled<br>High to disable the<br>internal pull-ups.                                                                                                                                                                         | The HSWAPEN input<br>enables or disables<br>internal pull-ups on<br>FPGA non-dedicated<br>I/O pins during<br>configuration.<br>• HSWAPEN=0<br>enables the internal<br>pull-ups.<br>• HSWAPEN=1<br>disables the internal<br>pull-ups.                                                                            | N/A                                                                           | Because the indirect<br>programming<br>sequence has periods<br>in which the FPGA is<br>unconfigured or<br>configured, the<br>HSWAPEN input<br>state can cause<br>internal pull-ups to<br>switch on or off<br>during the indirect<br>programming<br>sequence. The sample<br>schematic and<br>indirect<br>programming FPGA<br>core is designed to<br>maintain internal<br>pull-ups for most<br>pins. |
| N/A                              | CSO_B            | For configuring a single<br>FPGA, CSO_B is unused.<br>For multiple-FPGA,<br>parallel configuration<br>daisy-chains, connect the<br>CSO_B pin of each FPGA<br>to the CS_B/CSI_B pin of<br>the next FPGA in the<br>parallel configuration<br>daisy-chain. Connect a<br>strong external pull-up to<br>each CSO_B signal used in<br>the daisy-chain. See the<br>Parallel Daisy-Chain<br>section in the FPGA<br>configuration user guide<br>for more information. | CSO_B is not used for<br>configuring a single<br>FPGA. CSO_B is<br>normally<br>high-impedance during<br>configuration. For a<br>multiple-FPGA parallel<br>configuration<br>daisy-chain, CSO_B can<br>drive Low to enable the<br>next FPGA in the<br>daisy-chain to receive a<br>bitstream from the data<br>bus. | This pin can be used<br>for user I/O <sup>(1)</sup> .                         | This pin is<br>high-impedance with<br>an internal pull-up.                                                                                                                                                                                                                                                                                                                                         |

| Table 2-1. | FPGA BPI-Up Configuration Mode Signals and Descriptions (0 | Cont'd) |
|------------|------------------------------------------------------------|---------|
|            | I FOA DEI-OP COnfiguration Mode Signals and Descriptions ( | Som u)  |

| Platform<br>Flash XL<br>Pin Name  | FPGA<br>Pin Name                                                                                                         | Signal/Connection<br>Description                                                                                                                                                                                                                                                          | Function during<br>FPGA<br>Configuration                                                                                                                                                                                         | Function after<br>FPGA<br>Configuration                 | Function during<br>Indirect XCF128X<br>Programming                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A                               | RS[1:0]                                                                                                                  | These are the FPGA<br>revision select pins. For<br>the basic FPGA<br>configuration shown in<br>the sample schematic, do<br>not connect the RS[1:0]<br>pins (see the FPGA<br>configuration user guide<br>for details on using the<br>RS[1:0] pins to enable the<br>FPGA Fallback feature). | These pins are<br>high-impedance. These<br>pins can drive High or<br>Low due to the<br>MultiBoot command<br>during configuration.<br>In Master BPI mode, the<br>configuration fallback<br>feature can drive<br>RS[1:0] pins Low. | This pin can be used<br>for user I/O <sup>(1)</sup> .   | When RS[1:0] pins are<br>deemed unused, the<br>indirect<br>programming core<br>sets the RS[1:0] pins to<br>high impedance with<br>an internal pull-up. If<br>using a modified<br>design that uses the<br>RS[1:0] pins to control<br>a few XCF128X<br>address pins, then use<br>iMPACT 11.3 (or later)<br>to indirectly program<br>the XCF128X with<br>addressing support<br>through the RS[1:0]<br>pins. |
| WP#                               | N/A                                                                                                                      | This is the XCF128X<br>active-Low, write-protect.<br>Connect WP# to an<br>external pull-up resistor<br>to enable in-system<br>programming.                                                                                                                                                | N/A                                                                                                                                                                                                                              | The external resistor<br>pulls the WP# pin<br>High.     | WP# must be High to<br>enable XCF128X<br>programming.                                                                                                                                                                                                                                                                                                                                                    |
| N/A                               | V <sub>BATT</sub>                                                                                                        | This is the battery-backed<br>AES key supply. Connect<br>this to ground. This<br>supply is not used<br>because XCF128X is not<br>compatible with the AES<br>8-bit parallel data bus (or<br>serial) requirement.                                                                           | N/A                                                                                                                                                                                                                              | N/A                                                     | N/A                                                                                                                                                                                                                                                                                                                                                                                                      |
| N/A                               | V <sub>CCINT</sub>                                                                                                       | This is the FPGA V <sub>CCINT</sub> power supply.                                                                                                                                                                                                                                         | This is the FPGA V <sub>CCINT</sub> power supply.                                                                                                                                                                                | This is the FPGA<br>V <sub>CCINT</sub> power<br>supply. | This is the FPGA V <sub>CCINT</sub> power supply.                                                                                                                                                                                                                                                                                                                                                        |
| N/A                               | V <sub>CCAUX</sub>                                                                                                       | This is the 2.5V FPGA V <sub>CCAUX</sub> power supply.                                                                                                                                                                                                                                    | This is the FPGA V <sub>CCAUX</sub> power supply.                                                                                                                                                                                | This is the FPGA<br>V <sub>CCAUX</sub> power<br>supply. | This is the FPGA<br>V <sub>CCAUX</sub> power<br>supply.                                                                                                                                                                                                                                                                                                                                                  |
| V <sub>DD</sub>                   | N/A                                                                                                                      | This is the 1.8V XCF128X core power supply                                                                                                                                                                                                                                                | This is the XCF128X core power supply.                                                                                                                                                                                           | This is the XCF128X core power supply.                  | This is the XCF128X core power supply.                                                                                                                                                                                                                                                                                                                                                                   |
| V <sub>DDQ</sub> /V <sub>PP</sub> | VCCO_0<br>VCCO_1<br>VCCO_2<br>VCCO_4<br>(Virtex-5 FPGA)<br>or VCCO_0<br>VCCO_24<br>VCCO_24<br>VCCO_34<br>(Virtex-6 FPGA) | <ul> <li>This is the I/O (bank)<br/>power supply:</li> <li>Virtex-5 FPGA:<br/>V<sub>CCO</sub> = 3.3V (or 2.5V)</li> <li>Virtex-6 FPGA:<br/>V<sub>CCO</sub> = 2.5V</li> </ul>                                                                                                              | This is the I/O power<br>supply.                                                                                                                                                                                                 | This is the I/O power supply.                           | This is the I/O power supply.                                                                                                                                                                                                                                                                                                                                                                            |
| V <sub>SS</sub> /V <sub>SSO</sub> | GND                                                                                                                      | Ground                                                                                                                                                                                                                                                                                    | Ground                                                                                                                                                                                                                           | Ground                                                  | Ground                                                                                                                                                                                                                                                                                                                                                                                                   |

#### Table 3-1: FPGA BPI-Up Configuration Mode Signals and Descriptions (Cont'd)



| Internal pull-up is of FPGA BPI configuration pins are | Platform<br>Flash XL<br>Pin Name | FPGA<br>Pin Name | Signal/Connection<br>Description | Function during<br>FPGA<br>Configuration                                            | Function after<br>FPGA<br>Configuration | Function during<br>Indirect XCF128X<br>Programming                                                                                                                     |
|--------------------------------------------------------|----------------------------------|------------------|----------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                        | N/A                              | User I/O         |                                  | high-impedance.<br>Internal pull-up is<br>dictated by HSWAPEN<br>control input (see |                                         | not included in the set<br>of FPGA BPI<br>configuration pins are<br>high-impedance with<br>an internal pull-up.<br>This matches the<br>behavior of<br>unconfigured I/O |

Notes:

1. After configuration, the default FPGA design configuration of an unused User I/O is high-impedance with an internal pull-down.

#### FPGA BPI-Up Configuration from Platform Flash XL

The FPGA Master BPI-Up mode configuration process from a Platform Flash XL is described in Figure 3-3 and its notes.





Notes relating to Figure 3-3:

- 1. External resistors hold a few of the XCF128X and FPGA control/input signals High or Low including:
  - M[2:0]=101
  - L#=1.
- 2. Configuration starts with power-up (PROGRAM\_B is pulled and kept High) or with a High-Low-High pulse to PROGRAM\_B.
- 3. For power-up configuration, INIT\_B starts Low. For PROGRAM\_B-initiated configuration, INIT\_B drives Low when PROGRAM\_B is pulsed Low.
- 4. RS[1:0] are typically high-impedance. However, a MultiBoot (or Fallback event in Master SelectMAP or Master BPI mode) can cause RS[1:0] to drive High or Low.
- 5. INIT\_B releases at the end of the FPGA's internal initialization process. An external resistor pulls INIT\_B High. On the rising-edge of INIT\_B, the FPGA samples its M[2:0] pins to determine the configuration mode.
- 6. Upon determining the Master BPI-Up mode from the M[2:0] pins, the FPGA drives FWE\_B High, FOE\_B Low, and FCS\_B Low.
- 7. For the Master mode, the FPGA drives CCLK T<sub>ICCK</sub> time after the rising-edge of INIT\_B.
- 8. The FPGA drives the initial address (A0) through its A[25:0] pins and holds the initial address at T<sub>INITADDR</sub> CCLK cycles. For a power-on configuration, the initial address is 0x0000000. For a MultiBoot-triggered configuration, the address can be different.
- 9. Three K clock cycles after READY\_WAIT goes High, the XCF128X latches the starting read address from A[22:0] to its internal address counter for the ensuing synchronous array read operation. Although the FPGA drives new address values to the address bus, the XCF128X ignores the addresses from the FPGA after latching the initial address and instead uses its own internal address counter.
- 10. After a few clock cycles of latency following the address latching event, the XCF128X outputs the first 16-bit data word from the starting address in its array. On every clock cycle thereafter, the XCF128X outputs the next 16-bit data word from the array. The FPGA registers the 16-bit data word on the rising-edge of CCLK.
- 11. For a multi-FPGA parallel configuration daisy-chain, CSO\_B can drive Low to select the next FPGA in the daisy-chain for bitstream loading from the data bus.
- 12. Near the last 16-bit word of the bitstream, the FPGA begins its startup sequence.
- 13. If the FPGA detects a CRC error during bitstream delivery, the FPGA drives its INIT\_B pin Low. DONE stays Low.
- 14. If the FPGA successfully receives the bitstream, then the FPGA releases its DONE pin during the startup sequence, and an external resistor pulls DONE High.
- 15. During the startup sequence, the multi-purpose pins are activated with their configurations from the user's FPGA design. If not used in the FPGA design, the FCS\_B pin is high-impedance and is pulled High by the external resistor to disable the XCF128X.
- 16. At the end of configuration, the master CCLK is disabled into a high-impedance state by default.



### **Master Mode Considerations**

When the FPGA is set to the Master SelectMAP or Master BPI-Up mode, the FPGA supplies the configuration clock by driving an internal oscillator to its CCLK pin. As with any configuration mode, the configuration clock signal integrity is critical. It is recommended that the user perform IBIS simulations of the configuration clock board trace and the application of termination to ensure good signal integrity. Many references for termination strategies exist on the web. After a successful FPGA configuration, the FPGA puts the CCLK pin into a high-impedance state, by default.

To ensure good signal integrity for the master configuration clock, the structure of the master FPGA CCLK is important. Signal integrity must be ensured both at the XCF128X K (clock) pin and the FPGA CCLK pin. See Figure 3-4 for a description of the FPGA master CCLK structure.



UG438\_c3\_03\_081909

Figure 3-4: FPGA Master CCLK Structure



## Chapter 4

# **Calculating Configuration Time**

### **Determining the Maximum Configuration Clock Frequency**

The maximum clock frequency for configuring an FPGA from XCF128X configuration flash depends on the data transfer timing within a given configuration clock cycle (see Figure 4-1). After the initial rising-edge of a configuration clock cycle, the XCF128X's synchronous read operation outputs data to the data bus. The XCF128X flash has a data output valid time. The FPGA registers the data from the data bus on the following rising-edge of the configuration clock cycle. The FPGA requires a data setup time. Printed circuit board (PCB) propagation delays can impose addition time requirements.



UG438\_c4\_11\_082509



Note relating to Figure 4-1:

1. PCB propagation delay is not shown.

The minimum CCLK period is shown in Figure 4-1 and calculated by Equation 4-1.

$$T_{MINCCLK} = (T_{KHQV} + T_{SETUP} + T_{PCBPROP})$$
 Equation 4-1

. XILINX

where,

 $T_{KHQV}$  = XCF128X clock high to output valid time (see <u>DS617</u>, *Platform Flash XL High-Density Configuration and Storage Device*).

 $T_{SETUP}$  = SelectMAP data setup time ( $T_{SMDCCK}$ ) or BPI data setup time ( $T_{BPIDCC}$ ) (see the associated FPGA data sheet).

 $T_{PCBPROP} = PCB$  propagation delays.

The maximum configuration clock frequency can be calculated from the minimum clock period (see Equation 4-2). Equation 4-3 substitutes Equation 4-1 into Equation 4-2.

$$F_{MAXCCLK} = \frac{1}{T_{MINCCLK}}$$
Equation 4-2
$$F_{MAXCCLK} = \frac{1}{(T_{KHOV} + T_{SETUP} + T_{PCBPROP})}$$
Equation 4-3

When T<sub>PCBPROP</sub> is negligible, Equation 4-3 can be simplified to Equation 4-4.

$$F_{MAXCCLK} = \frac{1}{(T_{KHQV} + T_{SETUP})}$$
 Equation 4-4

#### Slave SelectMAP Maximum Configuration Clock Frequency

For Slave SelectMAP, the maximum frequency for the external configuration clock source is the maximum configuration clock frequency calculated in Equation 4-3 (or Equation 4-4 when PCB propagation delays are negligible).

#### Master SelectMAP/BPI Maximum Configuration Clock Setting

In Master SelectMAP and Master BPI-Up modes, the FPGA delivers the configuration clock. The FPGA's master configuration clock frequency is set through the BitGen **-g ConfigRate** option. The BitGen **-g ConfigRate** option sets the nominal configuration clock frequency. The FPGA's master configuration clock has a tolerance of  $T_{MCCKTOL}$ .

Due to the master configuration clock tolerance ( $T_{MCCKTOL}$ ), the BitGen **-g ConfigRate** must be selected so that the high end of the tolerance range does not exceed the maximum configuration clock frequency ( $T_{MAXFREQ}$ ). The BitGen **-g ConfigRate** is set as an integer in MHz. BitGen offers a limited set of valid ConfigRate settings. The maximum BitGen **-g ConfigRate** setting can be calculated using Equation 4-5.

$$MAXCONFIGRATE \leq \left(\frac{F_{MAXCCLK}}{\frac{1 MHz}{1 + T_{MAX} MCCKTOL}}\right)$$
 Equation 4-5

where,

 $T_{MAX\_MCCKTOL}$  = The maximum percent master configuration clock tolerance ( $F_{MCCKTOL}$ ) (see the associated FPGA data sheet).

 $F_{MAXCCLK}$  = The system maximum configuration frequency as calculated in Equation 4-3.

Due to the master configuration clock tolerance ( $T_{MCCKTOL}$ ), the master CCLK can run at frequencies slower than the nominal BitGen **-g ConfigRate** setting. The worst-case master

configuration clock frequency can be calculated for a given BitGen **-g ConfigRate** setting using Equation 4-6.

 $F_{WORSTMASTERCCLK} = CONFIGRATE \times 1 MHz \times T_{MIN_MCCKTOL}$  Equation 4-6

where,

CONFIGRATE = The BitGen -g ConfigRate setting.

 $T_{MIN\_MCCKTOL}$  = The minimum percent master configuration clock tolerance ( $T_{MCCKTOL}$ ) (see the associated FPGA data sheet).

The worst-case master configuration clock frequency is useful for determining the maximum FPGA configuration time.

### **Determining Configuration Time**

The basic FPGA configuration sequence when using Platform Flash XL is similar for all three modes (Slave SelectMAP, Master SelectMAP, and Master BPI-Up). This configuration sequence begins with a configuration reset that is initiated from a power-on-reset (POR) or other method of configuration reset. Within the configuration reset period, the FPGA clears its configuration memory. Then, the FPGA enables the selected configuration interface, loads the design data (bitstream), and starts running the loaded design. Refer to the FPGA configuration user guide for configuration sequence details.

Although the configuration sequence consists of several logical steps, many of the steps consume negligible time. Two factors overwhelmingly dominate the FPGA configuration time:

- T<sub>RDY</sub>: The delay required before the FPGA is ready for configuration. This can be due to:
  - The FPGA configuration memory clearing time from an FPGA configuration reset event.
  - The FPGA POR time. This includes FPGA configuration memory clearing time and other POR activities.
- T<sub>BIT</sub>: The FPGA configuration data load time. This is based on the size of the FPGA bitstream, the configuration bus width, and the clock rate.

The FPGA configuration time formula is given by Equation 4-7:

Configuration Time =  $T_{RDY} + T_{BIT}$ 

Equation 4-7

For power-on configuration, T<sub>RDY</sub> is specified in the FPGA data sheet as T<sub>POR</sub>.

For configuration initiated via a configuration reset event (pulse to PROGRAM\_B, issuance of a JPROGRAM JTAG instruction, or issuance of a IPROG ICAP/SelectMAP command), the  $T_{RDY}$  time is specified as  $T_{PL}$  in the FPGA data sheet.

The FPGA indicates the end of the FPGA POR or configuration reset event by releasing its INIT\_B pin. Typically, an external resistor pulls INIT\_B High upon release. When INIT\_B goes High, the FPGA is ready to begin bitstream loading.

 $T_{BIT}$  is the time required to load the FPGA bitstream. Ignoring the brief delay for the FPGA master CCLK to start ( $T_{ICCK}$ ) and a few cycles for the XCF128X to latch its first read address, the bitstream loading time can be modeled as shown in Equation 4-8.

$$T_{BIT} = \frac{\text{bitstream length in bits}}{16 \text{ bits per read}} \times \frac{1}{\text{configuration frequency}}$$
 Equation 4-8



See "Determining the Maximum Configuration Clock Frequency," page 45 for the effective clock frequency. For Slave SelectMAP mode, the effective frequency is typically the specified frequency of the external clock source within a few parts-per-million. For master modes, the worst-case CCLK frequency is typically the effective clock frequency for configuration time calculations.

Near the end of the bitstream loading process, the FPGA enters a logical start-up sequence to start the design. The start-up sequence consists of eight phases and can be optionally configured to perform various tasks. The few cycles required to complete the start-up sequence (with or without various options) are insignificant in the configuration time calculation because of the relative dominance of the T<sub>RDY</sub> and T<sub>BIT</sub> times.

In summary, many of the considerations for configuration time are trivial compared to the dominating  $T_{RDY}$  and  $T_{BIT}$  times. Ignoring trivial considerations, the time for configuration at power-up can be calculated using Equation 4-9.

$$T_{POWER\_ON\_CONFIG} = T_{POR} + \frac{\text{bitstream length in bits}}{\frac{((16 \text{ bits})/\text{cycle})}{\text{configuration frequency}}}$$
Equation 4-9

These are some further considerations for calculating configuration times:

- T<sub>POR</sub> can be found in the FPGA data sheet.
- The effective configuration frequency can be found in "Determining the Maximum Configuration Clock Frequency," page 45 and "Slave SelectMAP Maximum Configuration Clock Frequency," page 46.
- Re-configuration time from an FPGA reset event can be calculated using Equation 4-9 with T<sub>PL</sub> substituted for T<sub>POR</sub>.



## Chapter 5

## **Platform Flash XL File Generation**

### **Preparing a Programming File**

The FPGA design bitstream (.bit) file must be converted to a standard format PROM (.mcs) file for programming the Platform Flash XL. The iMPACT programming flow and third-party device programmers require the standard format PROM file as input. The .bit file is not a valid data input to the iMPACT programming flow or to the third-party device programmers.

This section details the software flow for creating standard format PROM files for programming the Platform Flash XL. The ISE<sup>®</sup> software tools, PROMGen (command line) or iMPACT (GUI), generate programming files from the FPGA bitstream.

Before converting an FPGA bitstream to a PROM file format, the designer must verify that the bitstream was generated with the proper start-up clock. The **bitgen -g StartupClk:Cclk** option ensures proper FPGA configuration and functionality by synchronizing the start-up sequence to the FPGA configuration clock (CCLK).

### Using the PROMGen Command-Line Software

The PROMGen software takes an FPGA bitstream (.bit) file as input and, with the appropriate options, generates a memory image file to program the data array of Platform Flash XL. The output memory image file format is Intel Hex (.mcs).

The ISE PROMGen software utility is easily executed from a command-line. A PROMGen software command-line example to generate an MCS-formatted file for a 16 MB (or 128 Mb) Platform Flash XL is shown below:

### promgen -p mcs -o design.mcs -x xcf128x -data\_width 16 -u 0 bitfile.bit

The **-p** mcs option specifies Intel Hex (.mcs) output file format. The **-o** design.mcs specifies the output file name to design.mcs. The **-x** xcf128x specifies the file is to be created for a 128 Mb Platform Flash XL. The **-u 0** option specifies the data to start at address zero and fill the data array in the up direction. The bitfile.bit is the input FPGA bitstream file used to create the PROM-formatted file.

### Using the iMPACT Graphical Software

The iMPACT software integrates PROM file formatting and in-system programming features behind an intuitive graphical user interface. The PROMGen file formatting functionality is provided through a step-by-step wizard in the iMPACT software. The wizard steps through the output PROM file options and input bitstream selections. After selecting all of the parameters using the wizard, the final step creates the Platform Flash XL programming file.



When iMPACT is launched, the iMPACT project dialog box is displayed (Figure 5-1). Choose the **create a new project (.ipf)** option and specify a project location using the **Browse...** button. Then, click **OK** to continue the PROM file generation process with "Step 1: Prepare a PROM File."

| 😻 iMPACT Project                                |             |                                              |                  |
|-------------------------------------------------|-------------|----------------------------------------------|------------------|
| I want to                                       |             |                                              |                  |
| O load most recent project                      |             | v                                            | Rowse            |
|                                                 |             | Load most recent project file when IMPACT at | arts             |
| <ul> <li>create a new project (.ipf)</li> </ul> | detault.ipl |                                              | Browse           |
|                                                 |             |                                              |                  |
|                                                 |             |                                              |                  |
|                                                 |             |                                              |                  |
|                                                 |             |                                              |                  |
|                                                 | <u>D</u> K  | Gancel                                       |                  |
|                                                 |             | UG                                           | 438_C04_01_03270 |

Figure 5-1: Project Creation in iMPACT

#### Step 1: Prepare a PROM File

The first dialog box of the wizard displays the available actions that can be performed (Figure 5-2).

Select **Prepare a PROM File**, and click **OK** to proceed to "Step 2: Specify the BPI Flash Storage for the FPGA Configuration Type" of the process.

| 😵 Welcome t   | to iMPACT                                                           |
|---------------|---------------------------------------------------------------------|
| Please select | t an action from the list below                                     |
| 🔘 Configur    | ure devices using Boundary-Scan (JTAG)                              |
|               | Automatically connect to a cable and identify Boundary-Scan chain 🔗 |
| O Prepare     | e a PROM File                                                       |
| 🔘 Prepare     | e a System ACE File                                                 |
| 🔘 Prepare     | e a Boundary-Scan File                                              |
|               | SVF 🗸                                                               |
| 🔘 Configur    | ure devices                                                         |
|               | using Slave Serial mode 🛛 👻                                         |
|               |                                                                     |
|               |                                                                     |
|               |                                                                     |
|               |                                                                     |
|               |                                                                     |
|               | OK Cancel                                                           |
|               |                                                                     |
|               | UG438_c5_02_08                                                      |

Figure 5-2: **iMPACT Prepares a PROM File Flow** 

#### Step 2: Specify the BPI Flash Storage for the FPGA Configuration Type

For the second step of the process, iMPACT displays the PROM File Formatter dialog box (Figure 5-3). In the Storage Device Type section of the PROM File Formatter dialog box, select the **Configure Single FPGA** item under the **BPI Flash** branch. Press the green arrow button between Step 1 and Step 2 within the dialog box to proceed to "Step 3: Select the XCF128X Device."



| Step 1. Select Storage Targe                                                   |             | Step 2. Add                 | d Storage Devi        | cc(3)     |   | Step 3.                 |                  | Enter | Duta |
|--------------------------------------------------------------------------------|-------------|-----------------------------|-----------------------|-----------|---|-------------------------|------------------|-------|------|
| Storage Device Type :                                                          |             | Target FPGA                 | Virtex5               | ~         |   | General File Detail     |                  | Value |      |
| → Xilin× Flash/PROM<br>→ Non-Volatile FPGA                                     |             | Storage Device (Bytes)      | xcf128x [16M]         | ~         |   | Checksum Fill<br>Value  | FF               |       |      |
| Spartan3AN<br>SPI Flash                                                        |             | Add Storage Device          | Remove Storage D      | evice     |   | Output File Name        | design           |       |      |
| Configure Single FPGA<br>Configure MultiBoot FPGA<br>BPI Flash                 |             | xcf128x [16M]               |                       |           |   | Output File<br>Location | C:\project       |       | P    |
| - Configure Single FPGA<br>- Configure MultiBoot FPGA                          |             |                             |                       | 1         |   | Flash/PROM Fi           | le Property      | Value |      |
| Configure from Paralleled PROMs<br>Generic Parallel PROM                       |             |                             |                       | 27        | • | File Format             |                  | MCS   | 1    |
| achone r ar allor r Korr                                                       |             |                             |                       |           |   | Add Non-Configura       | stion Data Files | No    |      |
|                                                                                |             |                             |                       |           |   | Add Nor-Configura       | duon Data Tiles  |       |      |
|                                                                                |             |                             |                       |           |   | Add Noti-Coningure      | JUUT Data Files  |       |      |
| 25cription:                                                                    |             |                             |                       |           |   |                         |                  |       |      |
| <b>scription:</b><br>this step, you will enter information to assist in settir | ng up and g | enerating a PROM file for t | he targeted storage d | evice and |   |                         |                  |       |      |

UG438\_c5\_03\_081809



#### Step 3: Select the XCF128X Device

In the Add Storage Device(s) section of the PROM File Formatter dialog box, select the **Virtex-5** FPGA as the Target FPGA. Then, select the **xcf128x** as the Storage Device. Press the **Add Storage Device** button to add the XCF128X to the storage device list. Press the green arrow button between Step 2 and Step 3 within the dialog box to proceed to "Step 4: Specify Output PROM File Name and Location."

#### Step 4: Specify Output PROM File Name and Location

In the Enter Data section of the PROM File Formatter dialog box, specify the output **PROM File Name** and select the output **File Location**. Keep the default File Format of MCS. When the PROM File Formatter entries are satisfactory, press the **OK** button to confirm the PROM type and output file name and location, and proceed to "Step 5: Notification to Add a Device to the PROM File."

#### Step 5: Notification to Add a Device to the PROM File

After pressing **OK** in the PROM File Formatter dialog box, the iMPACT PROM generation project is set to generate a specific PROM file with the specified parameters.

At this stage in the process, the PROM file memory image is empty. The fifth step in the process is to add an FPGA bitstream to the PROM file memory image. This step begins immediately after completion of the iMPACT PROM File Formatter with an automatic notification that the next step is to add a device file to the Xilinx PROM memory image.

Click **OK** in the Add Device notification dialog box (Figure 5-4) to proceed to "Step 6: Select the FPGA Bitstream File to Add."



Figure 5-4: Add Device Notification Dialog Box

#### Step 6: Select the FPGA Bitstream File to Add

After the Add Device notification, iMPACT opens a file browser to select the FPGA bitstream (.bit) file to add to the Platform Flash XL memory image (Figure 5-5).

Select the FPGA bitstream file to be written to the Platform Flash XL image. Click **Open** in the browser to add the target FPGA bitstream. If a single bitstream is to be stored in the device, click **NO** when asked if another design file is to be added (Figure 5-6). Next, click **OK** to complete the automated iMPACT process for preparing XCF128X file to be generated. Upon completion of the process, iMPACT displays a tabular summary of the XCF128X memory map in the MultiBoot BPI Flash Data Stream and Data File Assignment dialog box (Figure 5-7). Press **OK** to accept the default memory map for the given FPGA bitstream. Proceed to "Step 7: Generate File Operation" to generate the Platform Flash XL programming file.



Figure 5-5: Add Device File Browser





Figure 5-6: Add Another Device File to Data Stream

| 🗞 MultiBoot BPI Revision and Data File Assignment 🛛 🛛 🔀 |                                                                                            |                   |  |  |  |  |
|---------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------------|--|--|--|--|
| MultiBoot BPI Flash Revision                            | MultiBoot BPI Flash Revision Assignment: (Only Revision 0 Start Address cannot be changed) |                   |  |  |  |  |
| Revision                                                | Start Address [Hex]                                                                        | End Address [Hex] |  |  |  |  |
| 0                                                       | 0                                                                                          | BFA34             |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
|                                                         |                                                                                            |                   |  |  |  |  |
| Update Address                                          |                                                                                            |                   |  |  |  |  |
| <u> </u>                                                |                                                                                            | <u>C</u> ancel    |  |  |  |  |

UG438\_xx\_081809

Figure 5-7: XCF128X Memory Map Summary in Tabular Format

#### Step 7: Generate File Operation

The seventh and final step in the process is to generate the PROM file.

Double-click on the **Generate File** item in the iMPACT Processes window (Figure 5-8) to generate the specified Platform Flash XL programming file. iMPACT reports a "PROM File Generation Succeeded" message after successful generation of the PROM file. After the Generate File operation completes, the generated design.mcs file is available in the user-specified location. The design.mcs file can be used in any of the supported programming solutions to program Platform Flash XL with the specified FPGA bitstream contained within the PROM file.

Save the iMPACT PROM generation project for quick regeneration of the PROM file whenever the FPGA bitstream design is revised. To regenerate a Platform Flash XL programming file, re-open the saved iMPACT project, and invoke the **Generate File** operation. iMPACT generates a revised PROM file from the new version of the FPGA bitstream file, assuming the revised bitstream file is located in the same location as the original bitstream file.

If a project is not loaded when using the iMPACT GUI interface, a user is guided through the wizard steps each time to create a new PROM file. The designer is prompted to name the project and select the option **Prepare a PROM File**, following the steps 1-7 outlined above to generate a new PROM File.





UG438\_c5\_10\_081809

Figure 5-8: Double-Click on Generate File in iMPACT Processes



## Chapter 6

## **Programming Platform Flash XL**

Programming solutions satisfying the requirements for each product phase are available for Platform Flash XL. ISE<sup>®</sup> software provides integrated programming support for the FPGA design engineer in the prototyping environment. EDK Flashwriter does not support Platform Flash XL programming. Third-party programmer support is also available for the demands of manufacturing environments.

### **Programming Platform Flash XL During Prototyping**

ISE software has integral support for in-system programming, enabling rapid developprogram-and-test cycles for prototyping FPGA designs. The software compiles an FPGA design into a configuration bitstream, converts the bitstream into a PROM file, and then programs the PROM file into Platform Flash XL in-system using a Xilinx® download cable. During the programming process, the iMPACT software downloads a pre-built bitstream containing an in-system programming engine into the FPGA via the JTAG port. Platform Flash XL can then be indirectly programmed by the connected FPGA.

The basic hardware setup required for the iMPACT 11.3 (or later) indirect Platform Flash XL programming method is shown in Figure 6-1.



Figure 6-1: iMPACT Indirect Platform Flash XL Programming with a Virtex-5 FPGA

#### Minimum Requirements for Indirect In-System Programming

- Virtex®-5 or Virtex-6 FPGA with JTAG connector for the programming cable
- Platform Flash XL (XCF128X)
- A Xilinx cable
- ISE iMPACT software (ISE 11.3, or later)

The FPGA must be connected to Platform Flash XL following the recommendations in this user guide. Refer to Chapter 2, "High-Speed Configuration" or Chapter 3, "Alternate Configuration Modes" for recommended connections.

#### Xilinx Cable Connections

Xilinx cables are used with iMPACT to indirectly program Platform Flash XL through the traditional 1149.1 JTAG interface available on the FPGAs. Table 6-1 lists the Xilinx cables that can be used for indirect Platform Flash XL programming using iMPACT.

#### Table 6-1: Xilinx Cables Supporting Indirect Platform Flash XL Programming<sup>(1)</sup>

| Xilinx Cables                                | Interface |
|----------------------------------------------|-----------|
| Platform Cable USB,<br>Platform Cable USB-II | USB       |
| Parallel Cable IV                            | Parallel  |

#### Notes:

1. Refer to the specific Xilinx Cable data sheet for additional information.

Before starting the software sequence to program the XCF128X, there are few key hardware checks to perform:

Proper Xilinx cable connection:

The Xilinx cable must be properly connected to the computer and to the JTAG bus of the FPGA connected to the target Platform Flash XL (see Figure 6-1 for hardware connections from the Xilinx cable to the JTAG bus of the FPGA).

• Cable power:

If using the Xilinx Parallel Cable IV, then power must be applied to the cable.

• Target system power:

Power must also be supplied to the target system containing the FPGA and Platform Flash XL.

• Isolate BPI bus signals from other devices other than the FPGA during the programming process:

The target FPGA must be allowed to program Platform Flash XL without contention from other devices that might access the memory device (in other words, any other potential master device on the address or data bus or control signals should be isolated).

#### **iMPACT Programming Flow**

In prototyping applications, the iMPACT software can be used to program Platform Flash XL in-system with a memory image from a given PROM file (see Chapter 5, "Platform Flash XL File Generation" for instructions on the generation of the PROM file).

The following section demonstrates the iMPACT 11.3 (or later) software process for indirectly in-system programming Platform Flash XL through a Virtex-5 FPGA. The iMPACT software process for a Platform Flash XL with a Virtex-6 FPGA is similar. The process takes the design.mcs file (generated in Chapter 5, "Platform Flash XL File Generation") as input, erases the device, programs the file contents into Platform Flash XL, and verifies the device contents against the given PROM file contents.

#### Step 1: Create a New Project for Indirect In-System Programming

When launching the iMPACT software, the iMPACT Project dialog box is displayed (Figure 6-2). Select the **create a new project (.ipf)** option and (optionally) specify a project location using the **Browse...** button. Then, click **OK** to continue to "Step 2: Configure Devices Using the JTAG-to-BPI Method" in the process.



| 🐌 iMPACT Project                                |             |                                         |           | X |
|-------------------------------------------------|-------------|-----------------------------------------|-----------|---|
| I want to                                       |             |                                         |           |   |
| load most recent project                        |             | Ŷ                                       | Bromse    |   |
|                                                 |             | Load most recent project file when iMPA | CT starts |   |
| <ul> <li>create a new project ( ipf)</li> </ul> | default.ipf |                                         | Browse    |   |
|                                                 |             |                                         |           |   |
|                                                 |             |                                         |           |   |
|                                                 |             |                                         |           |   |
|                                                 |             |                                         |           |   |
|                                                 | 0K          | Cancel                                  |           |   |
|                                                 |             |                                         |           |   |

Figure 6-2: Create a New Project

#### Step 2: Configure Devices Using the JTAG-to-BPI Method

The second step of the process begins with the iMPACT project wizard. The first dialog box of the wizard displays the available kinds of projects that can be created (Figure 6-3). Select **Configure devices using Boundary-Scan (JTAG)** and the **Automatically connect to a cable and identify Boundary Scan chain** from the associated drop-down list. Click **Finish** to complete the new project setup process. At the completion of this process, iMPACT is set into a mode for in-system programming using a direct cable connection to the FPGA JTAG bus.

| 🐉 Welcome to iMPACT 🛛 🔀                                             |
|---------------------------------------------------------------------|
| Please select an action from the list below                         |
| <ul> <li>Configure devices using Boundary-Scan (JTAG)</li> </ul>    |
| Automatically connect to a cable and identify Boundary-Scan chain 💌 |
| O Prepare a PROM File                                               |
| O Prepare a System ACE File                                         |
| O Prepare a Boundary-Scan File                                      |
| SVF 👻                                                               |
| O Configure devices                                                 |
| using Slave Serial mode 💙                                           |
|                                                                     |
|                                                                     |
|                                                                     |
|                                                                     |
|                                                                     |
| OK Cancel                                                           |
|                                                                     |
|                                                                     |
| UG438_c6_04_081805                                                  |

Figure 6-3: Configure Devices Using Boundary Scan

After clicking **Finish**, the JTAG chain appears in the iMPACT GUI (Figure 6-4). For this demonstration a single Virtex-5 FPGA exists in the JTAG chain. This Virtex-5 FPGA device is connected to Platform Flash XL via the BPI configuration interface.



| 🐌 iMPACT - [Boundary Scan]                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Be Edit Yew Operations Output Debug Window                                                                                                                                                                                                                                                                                                                                                                    | 96 L                                                                            |
| 🔁 🖥 🖉 🖉 🖉 🕷 🗱 🖬 🖬 🖬 🖬                                                                                                                                                                                                                                                                                                                                                                                         | 황 향 D 4/ M2                                                                     |
| Rows         X           Image: Scan         Image: Scan           Image: Scan Scanses         Image: Scanses           Image: Scanses         Image: Scanses | Right click device to select operations TON TON x054c50 TD0 TD0                 |
| Modes MENCT Processes Xvalable Operations are:                                                                                                                                                                                                                                                                                                                                                                |                                                                                 |
| Operations                                                                                                                                                                                                                                                                                                                                                                                                    | 🙀 Bounday Scan                                                                  |
| PPOGPESS_START - Starting Operati<br>Identifying chain contents'I<br>INFO:IMPACT:77 -<br>Peading C:/Xilinx91i/virtex5/date<br>INFO:IMPACT:501 - '1': Added Devi<br>Opput Enc. Warning                                                                                                                                                                                                                         | <pre>/': : Manufacturer's ID =Zilinx xcSvlx50, Version : 0 //xcSvlx50.bsd</pre> |
|                                                                                                                                                                                                                                                                                                                                                                                                               | Configuration Platform Cable USB 6 MHz usb-hs                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                               | UG438 C05 05 032708                                                             |

Figure 6-4: Chain Initialization

#### Step 3: Assign the FPGA Configuration File

Select the FPGA bitstream and press the **Open** button (Figure 6-5).



Figure 6-5: Add a New Configuration File

#### Step 4: Add a PROM File for Indirect Programming

After assigning the Virtex-5 FPGA bitstream, the iMPACT Boundary-Scan window shows a Xilinx device icon. The icon represents the Virtex-5 FPGA with an "SPI/BPI" bubble above the icon. Right-click on the "**SPI/BPI**" bubble and select the **Add SPI/BPI Flash** menu item to specify a PROM file. This assigns an XCF128X that is attached to the Virtex-5 FPGA. Browse and select the PROM file for programming into the XCF128X device (Figure 6-6). Choose design.mcs, and click **Open**.

| Add PROM File                     | 8              |                   |   |           | ? 🔀              |
|-----------------------------------|----------------|-------------------|---|-----------|------------------|
| Look in:                          | Project        |                   | • | + 🗈 💣 🎟 - |                  |
| My Recent<br>Documents<br>Desktop | Ddesign        |                   |   |           |                  |
| My Documents                      |                |                   |   |           |                  |
| My Computer<br>(XSJST app2)       |                |                   |   |           |                  |
| My Network<br>Places              | File name:     | design            |   | <b>.</b>  | Open             |
| 1 10005                           | Files of type: | MCS Files (*.mcs) |   | •         | Cancel           |
|                                   |                |                   |   |           | UG438_C05_07_032 |

Figure 6-6: Add a PROM File

#### Step 5: Select Xilinx XCF128X Device Part Number

After selecting the PROM file to load, iMPACT displays the Select Attached SPI/BPI dialog box (Figure 6-7). The fifth step of the process requires the target PROM type to be specified in this dialog box. Select **BPI PROM and XCF128X** for the target PROM type used in this demonstration. Click **OK** to complete the PROM programming setup.



| Select Attached SPI/BPI           |          |   |  |  |  |
|-----------------------------------|----------|---|--|--|--|
| Select the PROM attached to FPGA: |          |   |  |  |  |
| BPI PROM 👻                        | XCF128X  | * |  |  |  |
| Data Width:                       | 16       | * |  |  |  |
| Select RS[1:0]b Pin Address Bits: | NOT USED | * |  |  |  |
| ОК                                | Cancel   |   |  |  |  |

UG438\_c6\_08\_081809

Figure 6-7: Select a Device Part Name

#### Step 6: Invoke the iMPACT Program Operation

The sixth step of the process programs the target device with the selected PROM file contents. Ensure the **PROM icon** in the **iMPACT** window is selected by left-clicking on the **PROM icon** (the PROM icon is highlighted in green when selected). **Select Operations**  $\rightarrow$  **Program** to begin programming (Figure 6-8).



Figure 6-8: Operations Menu

#### Step 7: Select iMPACT Programming Properties

In response to the invocation of the Program operation, iMPACT presents the Programming Properties dialog box (Figure 6-9). The seventh step of the process ensures the selection of proper programming properties. Ensure that **Erase Before Programming** value is checked and the **Verify** value is checked. Click **OK** to begin the erase, program, and verify operations.

| Device Programming Properties - Device 1 Programming Properties |   |                                             |                                                                     |  |  |
|-----------------------------------------------------------------|---|---------------------------------------------|---------------------------------------------------------------------|--|--|
| Category                                                        |   |                                             |                                                                     |  |  |
| Boundary-Scan<br>Device 1 ( FPGA xc5vlx50 )                     |   | Property Name                               | Yalue                                                               |  |  |
| Device 1 ( Attached FLASH, XCF128X )                            | 1 | Verify                                      |                                                                     |  |  |
|                                                                 |   | General CPLD And PROM Properties            |                                                                     |  |  |
|                                                                 |   | Erase Before Programming                    |                                                                     |  |  |
|                                                                 |   | FPGA Device Specific Programming Properties |                                                                     |  |  |
|                                                                 |   | After programming Flash                     | automatically load FPGA with Flash contents <default> 🛛 😒</default> |  |  |
| < >                                                             |   |                                             |                                                                     |  |  |
|                                                                 |   |                                             |                                                                     |  |  |
|                                                                 |   | [                                           | OK Cancel Apply Help                                                |  |  |

UG438\_c6\_09\_081809

Figure 6-9: PROM Programming Properties Dialog Box

Save the iMPACT project for quick reprogramming of the device whenever the PROM file is revised. To reprogram the device, reopen the saved iMPACT project, and invoke the **Program** operation, ensure the selection of the **Erase Programming Property**, and click **OK**. iMPACT reprograms the device, assuming the revised PROM file is located in the same location as the original PROM file.

### **Expectations**

#### iMPACT Operations and Programming Times

Since Platform Flash XL can combine user data and configuration storage, iMPACT only performs operations on the area bounded by the target device file. This restriction is to prevent other user data from being modified unintentionally. The erase operation for example does not erase the entire device contents, but rather erases only the user area required to store the selected PROM file. In addition, program, verify, and blankcheck all target only the area addressed by the PROM file.

With iMPACT 11.3 (or later) and the Xilinx Platform Cable USB at the default 6 MHz, the user can expect a programming time of approximately 30 seconds per 8 Mb of memory, and a verify time of approximately 15 seconds per 8 Mb of memory. These times are only guidelines because Platform Flash XL operations vary slightly from device to device. In addition, the cable and cable TCK speed selection can be changed in iMPACT, increasing or decreasing this time slightly.

#### Effect of Indirect Programming on the Rest of the System

When using the JTAG interface to program Platform Flash XL through a Virtex-5 FPGA, the user must understand the behavior of the FPGA during this process and how it can affect other devices in the system. To access Platform Flash XL through the JTAG interface, a Xilinx proprietary JTAG-to-BPI bitstream must be loaded into the FPGA. Loading the JTAG-to-BPI bitstream requires the FPGA to be configured and results in existing logic being lost.

The programming engine core is automatically selected and loaded by iMPACT when an operation is performed on the device. The core processes are preformed in the background and are transparent to the user. However, the DONE status signal is activated whenever the core programming design is loaded for a device operation.

#### Caution!

- This user guide demonstrates a single FPGA-to-BPI-PROM use case. For daisy-chained FPGA applications, a special procedure can be necessary to enable the JTAG-to-BPI programming engine bitstream in the lead FPGA. In a multiple-FPGA parallel daisy-chain, the DONE pins are tied together across FPGAs. If unconfigured downstream FPGAs are holding DONE Low, first use iMPACT to configure all FPGAs in the daisy-chain with configuration bitstreams via JTAG. After the FPGAs are configured, the downstream FPGAs are not holding DONE Low. iMPACT can then, during the programming process, download and start the indirect JTAG-to-BPI programming engine in the lead FPGA.
- If the user application utilizes the DONE signal status as a flag, the signal is released both when the core design is loaded and then again when the application design is configured into the FPGA from the programmed device.
- For indirect programming iMPACT requires all Platform Flash XL address lines (A[22:0]) to be accessible. If the SelectMAP configuration modes are used then the additional address lines must still be connected to the FPGA although they are unused for configuration. Connecting all address lines allows iMPACT to indirectly program Platform Flash XL via the BPI-UP bus.
- For the Virtex-5 FPGA, the IO\_L9P\_CC\_GC\_4 pin must be tied to the Platform Flash XL signal, *L*, for indirect programming.
- For the Virtex-6 FPGA, the IO\_L18P\_24 pin must be tied to the Platform Flash XL's L# pin for indirect programming.
- iMPACT versions prior to 11.3 do not support indirect programming with XCF128X address control through the FPGA RS[1:0] pins.

#### Pull-Up and Pull-Down Consideration

The designer should ensure that the board's device control signals, such as reset or enable, are tied appropriately on the board and do not rely on the FPGA's internal I/O pull-up or pull-down settings. As well as being good design practice, it is also important because the JTAG-to-BPI programming core's I/O settings can differ from the board's target application I/O requirements. When using the indirect programming method, the FPGA is configured with a JTAG-to-BPI programming core with all unused I/Os set to PULLUP. (All non-dedicated pins that are not included in the set of BPI configuration pins are unused I/Os in the JTAG-to-BPI programming core design.) This I/O setting activates the internal pull-up on all I/Os while the core is loaded. If dictated by system requirements, the user can pull down any I/O, using a 1.1 k $\Omega$  resistor. In addition, before the FPGA is configured, FPGA I/Os can be controlled by the HSWAPEN pin. When this pin is held

Low, internal pull-ups on all the I/Os are active. Designers must ensure that the correct HSWAPEN settings are used if any of the FPGA pins are connected to a control signal of any other device.

*Caution!* Software releases prior to 10.1.01 have the JTAG-to-BPI programming unused I/Os set to PULLDOWN.

### **Production Programming Solutions**

For the requirements of manufacturing environments, solutions exist for programming Platform Flash XL. Check with the third-party vendor for the availability of Platform Flash XL programmer support.

#### **Device Programmers**

Device programmers can gang program a high volume of Platform Flash XL devices in a minimal amount of time. Third-party device programmer vendors, such as BPM Microsystems, support programming of Platform Flash XL. See <a href="http://www.xilinx.com/support/programr/dev\_sup.htm">http://www.xilinx.com/support/programmer vendors</a>, such as BPM programmer vendors that support Platform Flash XL. See

A third-party programmer requires the PROM data in the form of a standard formatted PROM file, such as an MCS data file. See Chapter 5, "Platform Flash XL File Generation," for instructions on generating a standard PROM file that is properly formatted for a third-party programmer.





## Chapter 7

## System Considerations

### Platform Flash XL VDDQ Power Budget

The Platform Flash XL data sheet specifies maximum current draw for the V<sub>DD</sub> core voltage supply and V<sub>PP</sub> programming voltage supply under various internal operating conditions. The data sheet does not specify maximum current draw for the V<sub>DDQ</sub> I/O voltage supply because the current draw for the I/O voltage supply is dependent on factors external to the Platform Flash XL. The I/O voltage supply is strongly dependent on the I/O switching frequency and on the output (DQ[15:0]) loads. The output loads are unique to each board due to board design, board construction, and schematic connectivity.

Table 7-1 provides V<sub>DDQ</sub> power budget estimates from a real example test board. The test board contains one Platform Flash XL connected to one Virtex-5 FPGA as shown in the Slave SelectMAP (x16) schematic in Figure 2-1, page 16. Current measurements are taken from an isolated supply to the Platform Flash XL VDDQ at room temperature. To provide margin for the accuracy of the current measurement, part variation, and temperature variation, the entries in Table 7-1 are at least twice the actual measurements.

|             | VDDQ Power Supply Budge for Different K (Clock) Frequencies |                |                |                |                |                |                |                                                              |
|-------------|-------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------------------------------------------------------|
| VDDQ<br>(V) | 5 MHz<br>(mA)                                               | 10 MHz<br>(mA) | 20 MHz<br>(mA) | 30 MHz<br>(mA) | 33 MHz<br>(mA) | 40 MHz<br>(mA) | 50 MHz<br>(mA) | Simple Recommendation for<br>Each VDDQ Voltage Level<br>(mA) |
| 3.3V        | 19                                                          | 41             | 80             | 123            | 137            | 160            | 200            | 200                                                          |
| 2.5V        | 9                                                           | 26             | 51             | 81             | 88             | 102            | 137            | 140                                                          |

#### Table 7-1: Platform Flash XL Power Supply Budget Estimates for VDDQ





## Chapter 8

## FPGA User Design Recommendations

On a typical board design, most of the Platform Flash XL pins are connected to dual-purpose or standard user I/O pins of the FPGA. During FPGA configuration, the FPGA can drive many of the dual-purpose pins to read the configuration bitstream. After FPGA configuration, the dual-purpose pins become user-configured I/Os. The FPGA design determines the configuration of the dual-purpose or standard user I/Os that are connected to Platform Flash XL. The user's design configuration of these FPGA pins can affect the behavior of Platform Flash XL.

Appropriate FPGA design constraints are required to ensure a well-behaved Platform Flash XL after the FPGA is configured. The appropriate constraints depend on the FPGA design's usage of Platform Flash XL.

#### FPGA Designs Not Accessing Platform Flash XL after Configuration

When the FPGA design does not need to access Platform Flash XL for reading or writing, FPGA design constraints are recommended that keep Platform Flash XL in a disabled state. Disabling Platform Flash XL puts it in a standby mode that minimizes power consumption, avoids unexpected signal activity and corresponding noise, and allows for potential reuse of a few dual-purpose pins.

The recommended design constraints for FPGA pins connected to Platform Flash XL pins are shown in Table 8-1. Driving the FPGA FCS\_B pin High to disable the Platform Flash XL  $\overline{E}$  (chip enable) pin is critical. The remaining constraints are recommendations for disabling secondary Platform Flash XL control pins or for ensuring valid logic levels in different internal and external resistor scenarios. For example, FWE\_B is typically tied to an external pull-up resistor, and the external pull-up resistor can compete with the FPGA's internal pull-down resistor. If FWE\_B is not defined in the FPGA design, FWE\_B is an unused I/O. BitGen, by default, enables the FPGA pin's internal pull-down resistor on unused I/Os.

| Table 8-1: | <b>FPGA Pin Constraints</b> | When the FPGA I | Design Does Not | Access Platform Flash XL |
|------------|-----------------------------|-----------------|-----------------|--------------------------|
|------------|-----------------------------|-----------------|-----------------|--------------------------|

| Platform Flash XL Pin | FPGA Pin | FPGA Pin Constraints        | Description                                                           |
|-----------------------|----------|-----------------------------|-----------------------------------------------------------------------|
| Ē                     | FCS_B    | Drive High<br>(Required)    | Active-Low chip enable. Disables Platform Flash XL.                   |
| G                     | FOE_B    | Drive High<br>(Recommended) | Active-Low output enable. Disables the Platform Flash XL data output. |

| Platform Flash XL Pin | FPGA Pin                                                              | FPGA Pin Constraints        | Description                                                                    |
|-----------------------|-----------------------------------------------------------------------|-----------------------------|--------------------------------------------------------------------------------|
| W                     | FWE_B                                                                 | Drive High<br>(Recommended) | Active-Low write enable. Disables the<br>Platform Flash XL write function.     |
| Ī                     | IO_L9P_CC_GC_4<br>(Virtex-5 FPGA)<br>or IO_L18P_24<br>(Virtex-6 FPGA) | Drive High<br>(Recommended) | Active-Low address latch enable. Disables the Platform Flash XL address latch. |

#### Table 8-1: FPGA Pin Constraints When the FPGA Design Does Not Access Platform Flash XL (Cont'd)

Review the pin descriptions in Table 2-1, page 19 or Table 3-1, page 36 for additional FPGA design considerations that can apply to the specific use of the FPGA with the Platform Flash XL.

#### **Re-Using Configuration Pins for Other Purposes**

When the FPGA design does not access the Platform Flash XL, some of the configuration pins can be reused to communicate with other devices on the board. For example, FPGA pins D[15:0] or A[25:0] might be available for multi-purpose. To avoid conflicts when reusing the pins, check the reference schematic figures and pin tables in Chapter 2, "High-Speed Configuration" or Chapter 3, "Alternate Configuration Modes" to determine the behavior of the FPGA pins during configuration and indirect programming. Also see Table 8-1 for pin requirements of the FPGA design.

### FPGA Designs Accessing Platform Flash XL after Configuration

When the FPGA design needs read or write access to Platform Flash XL, FPGA design considerations are recommended that enable Platform Flash XL for asynchronous read and write access.

Platform Flash XL operates in one of two possible read modes: synchronous and asynchronous. At power-on or upon a reset through the RP pin, Platform Flash XL is put into synchronous read mode. This mode enables optimal performance for downloading a bitstream and configuring the FPGA. For FPGA configuration, Platform Flash XL is expected to be in synchronous read mode. User-level read and write access to Platform Flash XL is typically achieved through asynchronous read mode.

FPGA designs needing user-level read or write access to Platform Flash XL typically must consider the implementation of special functions and pin constraints for managing the read mode of Platform Flash XL.

#### FPGA Design Preparation for Asynchronous Read Mode Access

Before accessing Platform Flash XL for user-level reads or writes, the FPGA design must perform a one-time setup that involves:

- Setting up a few FPGA pins to be compatible with Platform Flash XL's asynchronous read mode interface (see Table 8-2)
- Explicitly setting the Platform Flash XL configuration register for asynchronous read mode operation

| Platform Flash XL Pin | FPGA Pin                                                              | FPGA Pin Constraints                                    | Description                                                                                                               |
|-----------------------|-----------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| Ē                     | FCS_B                                                                 | Drive Low as needed<br>by the application<br>(Required) | Active-Low chip enable. Enables Platform Flash XL.                                                                        |
| Ē                     | IO_L9P_CC_GC_4<br>(Virtex-5 FPGA)<br>or IO_L18P_24<br>(Virtex-6 FPGA) | Drive Low<br>(Required)                                 | Active-Low address latch enable. Enables<br>the Platform Flash XL address latch for<br>asynchronous read or write access. |

| Table 8-2: | FPGA Pin Constraints When the FPGA Design Accesses Platform Flash XL |
|------------|----------------------------------------------------------------------|
|------------|----------------------------------------------------------------------|

Review the pin descriptions in Table 2-1, page 19 or Table 3-1, page 36 for additional FPGA design considerations that can apply to the specific use of the FPGA with the Platform Flash XL.

To set Platform Flash XL to asynchronous read mode, a Set Configuration Register command must be applied from the FPGA design to Platform Flash XL with the Configuration Register bit 15 (CR15) set to 1. The Set Configuration Register command is a two write-cycle operation. CR15 must be set to 1 for asynchronous read mode and all remaining Configuration Register bits are recommended to be set to their default values. See <u>DS617</u>, *Platform Flash XL High-Density Configuration and Storage Device* for the Set Configuration Register command, Configuration Register bit values, write AC waveforms, and timing.

#### FPGA Design Preparation for FPGA Reconfiguration

The SelectMAP and Master BPI-Up configuration mode setups described in Chapter 2, "High-Speed Configuration" and Chapter 3, "Alternate Configuration Modes" expect Platform Flash XL to be in synchronous read mode.

If the FPGA design can trigger a reconfiguration of the FPGA from Platform Flash XL (for example, using the FPGA MultiBoot feature), the FPGA design must return the Platform Flash XL configuration to synchronous read mode before triggering the FPGA reconfiguration process.

To set Platform Flash XL to synchronous read mode, a Set Configuration Register command must be applied from the FPGA design to Platform Flash XL with CR15 set to 0. The Set Configuration Register command is a two write-cycle operation. All Configuration Register bits are recommended to be set to their default values, including the default value of 0 for CR15. See *Platform Flash XL High-Density Configuration and Storage Device* for the Set Configuration Register command, Configuration Register bit values, write AC waveforms, and timing.

Alternatively, external configuration control logic can simply apply a reset pulse to simultaneously initiate FPGA reconfiguration and reset Platform Flash XL to synchronous read mode. The FPGA configuration setups shown in Figure 2-1 and Figure 3-1 connect the Platform Flash XL RP (reset) pin to the FPGA PROGRAM\_B pin. Thus, a reset pulse to these connected pins simultaneously initiates FPGA reconfiguration and resets Platform Flash XL to its default synchronous read mode.

