# **TAMC641** # **High Performance Virtex-5 AMC with FMC Slot** Version 1.0 # **User Manual** Issue 1.0.6 January 2012 #### **TAMC641-10R** XC5VLX110T-1, 512 MB DDR2, 4MB QDR-II, Mid-Size front panel #### **TAMC641-11R** same as TAMC641-10R but Full-Size front panel #### **TAMC641-12R** XC5VLX155T-1, 512 MB DDR2, 4MB QDR-II, Mid-Size front panel #### **TAMC641-13R** same as TAMC641-12R but Full-Size front panel #### **TAMC641-14R** XC5VSX95T-1, 512 MB DDR2, 4MB QDR-II Mid-Size front panel #### **TAMC641-15R** same as TAMC641-14R but Full-Size front panel #### **TAMC641-16R** XC5VFX70T-1, 512 MB DDR2, 4MB QDR-II, Mid-Size front panel #### **TAMC641-17R** same as TAMC641-16R but Full-Size front panel #### **TAMC641-18R** XC5VFX100T-1, 512 MB DDR2, 4MB QDR-II, Mid-Size front panel #### **TAMC641-19R** same as TAMC641-18R but Full-Size front panel This document contains information, which is proprietary to TEWS TECHNOLOGIES GmbH. Any reproduction without written permission is forbidden. TEWS TECHNOLOGIES GmbH has made any effort to ensure that this manual is accurate and complete. However TEWS TECHNOLOGIES GmbH reserves the right to change the product described in this document at any time without notice. TEWS TECHNOLOGIES GmbH is not liable for any damage arising out of the application or use of the device described herein. #### **Style Conventions** Hexadecimal characters are specified with prefix 0x, i.e. 0x029E (that means hexadecimal value 029E). For signals on hardware products, an ,Active Low' is represented by the signal name with # following, i.e. IP RESET#. Access terms are described as: W Write Only R Read Only R/W Read/Write R/C Read/Clear R/S Read/Set #### ©2011-2012 by TEWS TECHNOLOGIES GmbH All trademarks mentioned are property of their respective owners. | Issue | Description | Date | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 1.0.0 | preliminary Issue | March 2011 | | 1.0.1<br>(preliminary) | <ul> <li>corrected connector names in figure 10-1</li> <li>update of Appendix B (FPGA constraints)</li> <li>added factory default settings of the Board Config. CPLD</li> <li>revised chapter "Module Current Requirements"</li> <li>revised Power Requirements in chapter "Technical Specification"</li> </ul> | May 2011 | | 1.0.2 | <ul> <li>removed preliminary status</li> <li>added storage temperature</li> <li>added typical power requirements (blank FPGA)</li> <li>added MTBF</li> <li>revised chapter "Debug Connector" (formally named as "Debug Adapter"</li> </ul> | May 2011 | | 1.0.3 | - added TCLKA-D to AMC Electrical Interface in chapter "Technical Specification" | June 2011 | | 1.0.4 | - Revised chapters "SPI-Flash" and "FPGA Configuration". Added information and warning about the relationship between indirect SPI-programming with Xilinx Impact and the FPGA Mode Pins Corrected SPI Interface Pinning in Appendix B | July 2011 | | 1.0.5 | Update to V1.0 Rev. B: - Changed default FPGA configuration mode to "Master SelectMap" - Changed DIP-Switch 3 from "USER_SWITCH_CPLD" to "FPGA Configuration Source selection" - Table with worst case FPGA Configuration Times added - Pin assignment for (post configuration) user SPI access changed - Chapter "Design Help" moved to the end of the document, and chapter "Troubleshooting" added. | November 2011 | | 1.0.6 | Correction of the interchanged DIP-Switch SW1 and SW2 descriptions. This affects: - Table 5-12 "configuration DIP-Switch SW1-SW2 Settings" in chapter 5.11 "JTAG" - Table 6-1 "DIP Switch" in chapter 6.2 "DIP-Switch" Samtec Part Number of the FMC Connector corrected (chapter 9.4) | January 2012 | # **Table of Contents** | 1 | PRODUCT DESCRIPTION | 8 | |---|-----------------------------------------|----| | 2 | TECHNICAL SPECIFICATION | 10 | | 3 | HANDLING AND OPERATION INSTRUCTION | 12 | | | 3.1 ESD Protection | 12 | | | 3.2 Thermal Considerations | | | | 3.3 Mid-Size Option Usage Restrictions | 12 | | | 3.4 I/O Signaling Voltages | 12 | | | 3.5 Voltage Limits on FMCs | 12 | | 4 | IPMI SUPPORT | 13 | | | 4.1 Temperature and Voltage Sensors | 13 | | | 4.1.1 Sensor Locations | | | | 4.2 FRU Information | | | | 4.2.1 Internal Use Area | | | | 4.2.2 Board Info Area | | | | 4.2.3 Product Info Area | | | | 4.2.4.1 Module Current Requirements | | | | 4.2.4.2 AMC Point-to-Point Connectivity | | | | 4.2.4.3 Clock Configuration | | | | 4.2.5 Modifying FRU Records | 18 | | 5 | FUNCTIONAL DESCRIPTION | 19 | | | 5.1 AMC Interface | 21 | | | 5.2 FMC Interface | 22 | | | 5.2.1 VADJ | | | | 5.3 Memory Interfaces | | | | 5.3.1 SPI-Flash | | | | 5.3.2 QDR-II SRAM | | | | 5.3 DDR2 SDRAW | | | | 5.5 GPIO | | | | 5.6 I <sup>2</sup> C | | | | 5.7 UART | | | | 5.8 Multi-Gigabit Transceiver (GTPs) | | | | 5.9 Configuration | | | | 5.9.1 Board Configuration CPLD (BCC) | | | | 5.9.2 FPGA Configuration | | | | 5.9.3 Clock Configuration | | | | 5.10 Clocks | | | | 5.10.1 GTP Reference Clock Generator | | | | 5.11 JTAG5.12 Thermal Management | | | 6 | BOARD CONFIGURATION | | | J | 6.1 Overview | | | | 6.2 DIP-Switch | | | | 6.3 Battery | | | | 6.4 Debug Connector | | | | 0.7 Doday Collicotol | | | 7 | INSTALLATION | 40 | |----|--------------------------------------------------|----| | | 7.1 Installation of a FMC Module | 40 | | | 7.1.1 Using FMCs with Mid-Size faceplates | 40 | | | 7.1.2 Voltage Limits on FMC Modules | | | | 7.2 AMC Module Insertion & Hot-Swap | 41 | | | 7.2.1 Insertion | | | | 7.2.2 Extraction | 41 | | 8 | INDICATORS | 42 | | | 8.1 Front Panel LEDs | 42 | | | 8.2 On board LEDs | 42 | | 9 | I/O CONNECTORS | 44 | | | 9.1 Overview | 44 | | | 9.2 I/O Circuitry | 44 | | | 9.2.1 Differential Signaling | 44 | | | 9.3 AMC-Connector X4 | 45 | | | 9.4 FMC HPC Connector X2 | 47 | | | 9.5 Debug-Connector X1 | 50 | | 10 | DESIGN HELP | 51 | | | 10.1 GTP Reference Clock Generator Configuration | 51 | | | 10.2 Example Design | 51 | | | 10.1 Troubleshooting | 52 | | | 10.1.1 Board does not power up | 52 | | | 10.1.2 DONE is always off | | | | 10.1.3 INIT LED stays illuminated (red) | 52 | | 11 | APPENDIX A | 53 | | 12 | APPENDIX B | 59 | | | | | # **List of Figures** | FIGURE 1-1: | BLOCK DIAGRAM | 9 | |--------------|--------------------------------------------|-----| | FIGURE 4-1 : | TEMP. SENSOR LOCATIONS | .13 | | FIGURE 5-1 : | TAMC641 FUNCTIONAL BLOCK DIAGRAM | .19 | | FIGURE 5-2 : | AMC INTERFACE DIAGRAM | .21 | | FIGURE 5-3 : | FMC INTERFACE TO VIRTEX-5 FPGA | .22 | | FIGURE 5-4 : | A FMC MODULE | .23 | | FIGURE 5-5 : | QDR-II SRAM INTERFACES TO FPGA | .24 | | FIGURE 5-6 : | DDR2 SDRAM INTERFACES TO FPGA | .25 | | FIGURE 5-7 : | RESET STRUCTURE | .25 | | FIGURE 5-8 : | I2C BUS STRUCTURE OVERVIEW | .27 | | FIGURE 5-9: | GTP BLOCK DIAGRAM | .28 | | FIGURE 5-10: | BOARD CONFIGURATION CPLD BLOCK DIAGRAM | .29 | | FIGURE 5-11: | CLOCK CONFIGURATION | .33 | | FIGURE 5-12: | FPGA CLOCK SOURCES | .34 | | FIGURE 5-13: | JTAG-CHAIN SEGMENTATION | .37 | | FIGURE 6-1 : | PRE-INSERTION BOARD CONFIGURATION OVERVIEW | .38 | | FIGURE 7-1: | USING FMCS WITH MID-SIZE FACEPLATES | .40 | | | FRONT PANEL LED VIEW | | | FIGURE 8-2: | ON BOARD LED VIEW | .42 | | FIGURE 9-1: | CONNECTOR POSITIONS - SIDE 1 | .44 | | FIGURE 0-2. | CONNECTOR POSITION - SIDE 2 | 11 | # **List of Tables** | TABLE 2-1: TECHNICAL SPECIFICATION | 11 | |-------------------------------------------------------|----| | TABLE 4-1: TEMPERATURE AND VOLTAGE SENSORS | 13 | | TABLE 4-2: FRU INFORMATION | 14 | | TABLE 4-3: INTERNAL USE AREA | 14 | | TABLE 4-4: BOARD INFO AREA | 15 | | TABLE 4-5: PRODUCT INFO AREA | 15 | | TABLE 4-6: MODULE CURRENT REQUIREMENT (W/O FMC) | 16 | | TABLE 4-7: AMC POINT-TO-POINT CONNECTIVITY | 17 | | TABLE 4-8: CLOCK CONFIGURATION | 17 | | TABLE 5-1: TAMC641 FPGA FEATURE OVERVIEW | 20 | | TABLE 5-2: FPGA BANK USAGE | 21 | | TABLE 5-3: FMC-SUPPLIES | 23 | | TABLE 5-4: GENERAL PURPOSE I/O | 26 | | TABLE 5-5: I2C BUS SIGNALS | 26 | | TABLE 5-6: FPGA UART | 27 | | TABLE 5-7: WORST CASE FPGA CONFIGURATION TIMES | 31 | | TABLE 5-8: TCLK TRANSCEIVER CONFIGURATION | 32 | | TABLE 5-9: JITTER ATTENUATOR CONFIGURATION | 32 | | TABLE 5-10: AVAILABLE FPGA CLOCKS | 35 | | TABLE 5-11: PROGRAMMABLE GTP REFERENCE CLOCK | 36 | | TABLE 5-12: CONFIGURATION DIP-SWITCH SW1-SW2 SETTINGS | 37 | | TABLE 6-1: DIP-SWITCH | 38 | | TABLE 7-1: VOLTAGE LIMITS ON FMC MODULES | 40 | | TABLE 7-2: HOT-SWAP STATES | 41 | | TABLE 8-1: FRONT PANEL LEDS | 42 | | TABLE 8-2: BOARD-STATUS LEDS | 43 | | TABLE 9-1: PIN ASSIGNMENT AMC CONNECTOR X4 | 46 | | TABLE 9-2: PIN ASSIGNMENT FMC-CONNECTOR X2 ROW F-K | 48 | | TABLE 9-3: PIN ASSIGNMENT FMC-CONNECTOR X2 ROW A-E | 49 | | TABLE 9-4: PIN ASSIGNMENT DEBLIG CONNECTOR X1 | 50 | # 1 **Product Description** The TAMC641 is a standard single Mid-Size or Full-Size AMC module providing a user configurable Virtex-5 FPGA. The integrated PCIe Endpoint Block of the Virtex-5 can be used to build an x1, x4 or x8 PCIe link via AMC Port 4-11. The implementation of other protocols like SRIO or XAUI is also possible. AMC Ports 0 & 1, commonly used for Gigabit Ethernet, and AMC Ports 2 & 3 are also connected to the FPGA. The integrated Gigabit Ethernet MACs of the Virtex-5 allow fast and easy protocol implementation. To allow direct board-to-board communication, AMC Ports 12-17 are connected to Virtex-5 I/Os, allowing AC-coupled LVDS communication with a port speed up to 1.0Gb/sec. For flexible I/O solutions the TAMC641 provides a VITA 57.1 high pin count FMC Module slot, allowing active and passive signal conditioning. All FMC I/O lines are directly connected to the FPGA, which maintains the flexibility of the Select I/O technology of the Virtex-5 FPGA. In addition, the FPGA is connected to the following external memories: - two banks of DDR2 SDRAM (up to 128 M x 32 (512 MB) each) - two banks of QDR-II SRAM (up to 4 M x 18 (8 MB) each) Multiple clocks from the AMC-interface, the FMC and from on-board sources are supplied to the FPGA. The FPGA is configured by a flash device, which is in-system programmable and able to store multiple code versions. The TAMC641 supports encrypted FPGA bitstream usage. Encrypted FPGA bitstreams cannot be copied or reverse engineered, securing your intellectual property. The IPMI Connectivity Records located inside the Module Management Controller (MMC) can be modified by the customer (e.g. via IPMI), to adapt to the different possible communication protocols (PCIe, SRIO, XAUI, ...). User applications for the TAMC641 require the full ISE Foundation software, which must be purchased from Xilinx. The Engineering Documentation TAMC641-ED includes all information needed for customer specific FPGA programming. The FPGA Development Kit TAMC641-FDK includes the engineering documentation, ucf-files with all necessary pin assignments and basic timing constraints, and a well documented VHDL example application. This example application is called TPLD003 (Tews Programmable Logic Design) and covers the main functionalities of the TAMC641 like DMA capable PCIe endpoint with interrupt support, register mapping, DDR2 and QDR-II memory access and basic I/O to the FMC slot. It comes as a Xilinx ISE project with source code and as a ready-to-download bitstream. It is the basis for fast and reliable customer application development, and can significantly reduce time to market. Software support for the TPLD003 is available for all major operating systems. In-circuit programming and debugging of the FPGA design (e.g. using Xilinx "ChipScope") is supported. The Program and Debug Box TA900 allows access to the module while it is inserted in a system. It provides access to the module's JTAG Chain, the UART of the on-board Module Management Controller (MMC) and to two user pins of the Virtex-5 FPGA. If a UART core is implemented in the FPGA, serial communication via the TA900 is possible. The TA900 can be accessed by USB 2.0 and by a 14-pin JTAG Header (e.g. for connecting a Xilinx Platform Cable). Figure 1-1: Block Diagram # **Technical Specification** | PICMG® AMC.0 R2.0 (Advanced Mezzanine Card Base Specification) Module Type: Single Mid-Size module or Single Full-Size module (see data sheet for order information) Electrical Interface Virtex-5 GTPs connected to AMC port 0 - 11 Virtex-5 LVDS Transceivers connected to port 12-15 & 17 TCLKA-D connected to FPGA IPMI IPMI Version 1.5 Blue Hot-Swap LED Red Failure Indication LED (LED1) Green Board OK / User LED (LED2) On Board Devices PCIe Endpoint Virtex-5 integrated PCI Express Endpoint Block User configurable FPGA Virtex-5 (Xillinx) XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash 2 x Xillinx XCF32P, 32 MBit each SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | AMC Interface | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | Virtex-5 LVDS Transceivers connected to port 12-15 & 17 TCLKA-D connected to FPGA IPMI IPMI Version 1.5 Front Panel LEDs Blue Hot-Swap LED Red Failure Indication LED (LED1) Green Board OK / User LED (LED2) On Board Devices PCIe Endpoint Virtex-5 integrated PCI Express Endpoint Block User configurable FPGA Virtex-5 (Xilinx) XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash PPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | Mechanical Interface | PICMG® AMC.0 R2.0 (Advanced Mezzanine Card Base Specification) Module Type: Single Mid-Size module or Single Full-Size module | | IPMI Version | Electrical Interface | Virtex-5 LVDS Transceivers connected to port 12-15 & 17 | | Blue Hot-Swap LED Red Failure Indication LED (LED1) Green Board OK / User LED (LED2) On Board Devices PCIe Endpoint Virtex-5 integrated PCI Express Endpoint Block User configurable FPGA Virtex-5 (Xilinx) XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash 2 x Xilinx XCF32P, 32 MBit each SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator Si5338B (Silicon Labs) FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | IPMI | | | Red Failure Indication LED (LED1) Green Board OK / User LED (LED2) On Board Devices PCIe Endpoint Virtex-5 integrated PCI Express Endpoint Block User configurable FPGA Virtex-5 (Xilinx) XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash 2 x Xilinx XCF32P, 32 MBit each SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | IPMI Version | 1.5 | | PCIe Endpoint Virtex-5 integrated PCI Express Endpoint Block Virtex-5 (Xilinx) XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash 2 x Xilinx XCF32P, 32 MBit each SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | Front Panel LEDs | Red Failure Indication LED (LED1) | | User configurable FPGA Virtex-5 (Xilinx) XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash 2 x Xilinx XCF32P, 32 MBit each SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | On Board Devices | | | XC5VLX110T, XC5VLX155T, XC5VSX95T, XC5VFX70T or XC5VFX100T (see data sheet for order information) Configuration Flash 2 x Xilinx XCF32P, 32 MBit each SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | PCIe Endpoint | Virtex-5 integrated PCI Express Endpoint Block | | SPI-Flash MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | User configurable FPGA | XC5VLX110T, XC5VLX155T,<br>XC5VSX95T,<br>XC5VFX70T or XC5VFX100T | | DDR2 SDRAM 4 x Micron MT47H64M16 (64M x 16) 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | Configuration Flash | 2 x Xilinx XCF32P, 32 MBit each | | QDR-II SRAM 2 x IDT 71P74804 (1M x 18) Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | SPI-Flash | MP25P64 (Micron) 64 Mbit (can be used for FPGA configuration) | | Programmable Clock Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | DDR2 SDRAM | 4 x Micron MT47H64M16 (64M x 16) | | Generator I/O Interface I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | QDR-II SRAM | 2 x IDT 71P74804 (1M x 18) | | I/O Connector FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) User Defined Signals 80 differential or 160 single-ended I/O plus 4 differential Clocks | Programmable Clock<br>Generator | Si5338B (Silicon Labs) | | User Defined Signals Card (FMC) Standard) 80 differential or 160 single-ended I/O plus 4 differential Clocks | I/O Interface | | | | I/O Connector | FMC high pin count slot according to VITA 57.1 (FPGA Mezzanine Card (FMC) Standard) | | Multi-Gigabit-Interfaces 4 gigabit data plus 2 gigabit reference clocks | User Defined Signals | 80 differential or 160 single-ended I/O plus 4 differential Clocks | | | Multi-Gigabit-Interfaces | 4 gigabit data plus 2 gigabit reference clocks | | Physical Data | | | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | Power Requirements | Depends on FPGA design. | | | | 500 mA typical @ +12V DC (Payload Power, Blank FPGA) | | | | 40 mA typica | ll @ +3.3V DC (Management Power) | | | 4.7A as per Module Current Requirement Record (max.) | | | | Additional po | wer is used by the FMC. | | Temperature Range | Operating 0°C to +70°C | | | | Storage | -40°C to +85°C | | MTBF | 304000 h | | | | MTBF values shown are based on calculation according to MIL-HDBK-217F and MIL-HDBK-217F Notice 2; Environment: G <sub>B</sub> 20°C. | | | | The MTBF calculation is based on component FIT rates provided by the component suppliers. If FIT rates are not available, MIL-HDBK-217F and MIL-HDBK-217F Notice 2 formulas are used for FIT rate calculation. | | | Humidity | 5 – 95 % non-condensing | | | Weight | 190 g | | Table 2-1: Technical Specification # 3 Handling and Operation Instruction #### 3.1 ESD Protection The TAMC641 is sensitive to static electricity. Packing, unpacking and all other handling of the TAMC641 has to be done in an ESD/EOS protected Area. #### 3.2 Thermal Considerations Forced air cooling is recommended during operation. Without forced air cooling, damage to the device will occur. # 3.3 Mid-Size Option Usage Restrictions Please note that the Mid-Size module has restrictions to its usage because of a component height violation. It is within the responsibility of the user to carefully check if the Mid-Size module with its component height violation can be used in the system. Otherwise damage to the TAMC641 or the slot it is used in may occur! Refer to the chapter "Using FMCs with Mid-Size faceplates" for details. # 3.4 I/O Signaling Voltages The FPGA I/O-Lines to the FMC Slot are directly connected to the FPGA I/O pins. The I/O voltage of these FPGA I/O pins is 3.3V maximum. The FPGA I/O pins are NOT 5V tolerant. # 3.5 Voltage Limits on FMCs The AMC.0 specification limits the voltages on AMC modules. These limits also apply to mounted FMCs. Refer to the chapter "Voltage Limits on FMC Modules" for details. # 4 IPMI Support The TAMC641 provides a Module Management Controller (MMC) that performs health monitoring, hot-swap functionality and Field Replaceable Unit (FRU) information storage. The MMC communicates via an Intelligent Platform Management Interface (IPMI) with its superordinated IPMI controller / shelf manager. # 4.1 Temperature and Voltage Sensors The MMC monitors on board sensors and reports sensor events to the superordinated IPMI controller / shelf manager. | Sensor Number | Signal Type | Thresholds <sup>1</sup> | Signal Monitored | |---------------|-------------|-------------------------|------------------------| | 0 | Event | - | Hot-swap switch | | 1 | Temperature | lcr lnc unc ucr | FPGA Temp. | | 2 | Temperature | Icr Inc unc ucr | Board Temp. | | 3 | Temperature | lcr lnc unc ucr | FMC Air Temp. | | 4 | Voltage | lcr lnc unc ucr | PWR | | 5 | Voltage | Icr Inc unc ucr | +12V (FMC) | | 6 | Voltage | lcr lnc unc ucr | +5V | | 7 | Voltage | lcr lnc unc ucr | V <sub>ADJ</sub> (FMC) | Table 4-1: Temperature and Voltage Sensors #### 4.1.1 Sensor Locations Figure 4-1: Temp. Sensor Locations <sup>&</sup>lt;sup>1</sup> unr: upper non-recoverable, ucr: upper critical, unc: upper non-critical lnc: lower non-critical, lcr: lower critical, lnr: lower non-recoverable ## 4.2 FRU Information The MMC stores the module FRU information in a non-volatile EEPROM. Some of the records are writeable to allow adapting the TAMC641 to user FPGA designs. If records are modified, the user is responsible to set the affected checksums to correct values. | Area | Size (in Bytes) | Writeable | |------------------------------------|-----------------|-----------| | Common Header | 8 | no | | Internal Use Area | 72 | yes | | Chassis Info Area | 0 | no | | Board Info Area | variable | no | | Product Info Area | variable | no | | Multi Record Area | variable | see below | | Module Current<br>Requirements | variable | yes | | AMC Point-to-Point<br>Connectivity | variable | yes | | Clock Configuration | variable | yes | Table 4-2: FRU Information #### 4.2.1 Internal Use Area The TAMC641 uses the Internal Use Area to store default FMC-slot settings for the case that a module is present, but no valid FRU information is found. The value of "Fallback-Voltage for VADJ" determines what happens in this case. If the "Fallback-Voltage for VADJ" is set to 0x0000, the module won't turn on. Any other value sets VADJ to "Fallback-Voltage for VADJ" \* 10mV, as long this value is within the range defined by Minimum VADJ and Maximum VADJ. Example: 0x00FA = 250 \* 10mV = 2.5V. | Product Information | Value | |-----------------------------|-------------------------------------------------------------------| | Internal Use Format Version | 0x01 | | TEWS IUA Format-Version | 0x01 | | Present FMC Slots | 0x01 - FMC-slot #0 | | Fallback-Voltage for VADJ | 0x0000 – if no valid FMC-FRU is found, the TAMC641 won't turn on. | | Minimum VADJ | 0x0078 - 1200mV for TAMC641 | | Maximum VADJ | 0x014A - 3300mV for TAMC641 | Table 4-3: Internal Use Area The whole Internal Use Area is writeable, but if changes become necessary, only the Fallback-Voltage for VADJ should be altered. ## 4.2.2 Board Info Area | Product Information | Value | |------------------------|-----------------------------------------------------------------| | Version | 0x01 | | Language Code | 0x00 - English | | Manufacturer date/time | determined at manufacturing | | Board manufacturer | TEWS TECHNOLOGIES GmbH | | Board product name | TAMC641 | | Board serial number | determined at manufacturing (see board label) | | Board part number | TAMC641-xx(R) | | | -xx = -10 / -11 / -12 / -13 / -14 / -15 / -16 / -17 / -18 / -19 | Table 4-4: Board Info Area #### 4.2.3 Product Info Area | Product Information | Value | |-------------------------|----------------------------------------------------------------------------------| | Version | 0x01 | | Language Code | 0x00 - English | | Product manufacturer | TEWS TECHNOLOGIES GmbH | | Product name | TAMC641 | | Board part/model number | TAMC641-xx(R)<br>-xx = -10 / -11 / -12 / -13 / -14 / -15 / -16 / -17 / -18 / -19 | | Product version | V1.0 Rev. B (see board label) | | Product serial number | determined at manufacturing (see board label) | | Asset tag | = Product serial Number | Table 4-5: Product Info Area #### 4.2.4 Multi Record Area #### 4.2.4.1 Module Current Requirements The "Current Draw" value holds the Payload Power (PWR) requirement of the module given as current requirement in units of 0.1A at 12V. The AMC module announces the sum of "Current Draw" and FMC Current Requirement as current demand to the shelf manager. If the power budget for the AMC slot is smaller than this value, the shelf manager may not enable Payload power for the slot. If required, the "Current Draw" value in the Module Current Requirements record may be modified to a value that falls within the given power budget. Make sure that the modified value still satisfies the AMC module power requirements for the actual FPGA content. | Product Information | Value | |---------------------|--------------| | Current Draw | 0x2F (4.7 A) | Table 4-6: Module Current Requirement (w/o FMC) #### 4.2.4.2 AMC Point-to-Point Connectivity The TAMC641's Virtex-5 FPGA allows implementing a wide range of interfaces (Serial RapidIO, PCI-Express, Gig.-Eth., SAS, SATA, XAUI, etc.). The MMC stores a Connectivity Record for each interface that is implemented by the TAMC641. By default, the MMC of the TAMC641 stores the following Connectivity Records: - 2x GbE Links on AMC Ports 0-1 - 2 x SATA Links on AMC Port 2-3 - x1 2.5 Gbps PCI-Express Gen1 Link on AMC Port 4 - x4 2.5 Gbps PCI-Express Gen1 Link on AMC Port 4-7 - x8 2.5 Gbps PCI-Express Gen1 Link on AMC Port 4-11 | Channel | Port | Link Type | Link Type Extension | Link Grouping ID | Asymmetric Match | | |---------|---------------|---------------------------|-------------------------------|---------------------|------------------|--| | 0 | 0 | AMC.2 Ethernet | 1000BASE-BX<br>Ethernet Link | Single Channel Link | exact match | | | 1 | 1 | AMC.2 Ethernet | 1000BASE-BX<br>Ethernet Link | Single Channel Link | exact match | | | 2 | 2 | AMC.3 Storage | Serial ATA | Single Channel Link | matches with 01 | | | 3 | 3 | AMC.3 Storage | Serial ATA | Single Channel Link | matches with 01 | | | 4 | 4 | AMC.1 PCI | Gen 1 PCI Express,<br>non-SSC | Single Channel Link | | | | 4 4 | | Express | Gen 1 PCI Express,<br>SSC | Single Channel Link | matches with 10 | | | 5 | 4.7 | -7 AMC.1 PCI<br>Express | Gen 1 PCI Express, non-SSC | Single Channel Link | matches with 10 | | | 5 | 4-7 | | Gen 1 PCI Express,<br>SSC | Single Channel Link | | | | 6 | 4.7 | AMC.1 PCI | Gen 1 PCI Express, non-SSC | 0x1 | motoboo with 10 | | | 0 | 6 4-7 Express | | Gen 1 PCI Express,<br>SSC | OXI | matches with 10 | | | 7 | 0 11 | 8-11 AMC.1 PCI<br>Express | Gen 1 PCI Express,<br>non-SSC | 0x1 | matches with 10 | | | 7 | 8-11 | | Gen 1 PCI Express,<br>SSC | UXI | | | Table 4-7: AMC Point-to-Point Connectivity #### 4.2.4.3 Clock Configuration AMC FCLKA should be used as the PCI Express Reference Clock. TCLKA – D are all inputs by default, but can independently be changed to outputs. | Clock ID | Clock Features | Clock Family | Clock<br>Accuracy | Clock<br>Frequency | |----------|--------------------------------------------------------------------------------------------------|--------------|----------------------|--------------------| | FCLKA | Clock Receiver,<br>connected through Jitter<br>Attenuator and<br>programmable Clock<br>Generator | PCI Express | PCI Express<br>Gen 1 | 100 MHz nom | | TCLKA | Clock Receiver | misc | - | - | | TCLKB | Clock Receiver | misc | - | - | | TCLKC | Clock Receiver | misc | - | - | | TCLKD | Clock Receiver | misc | - | - | Table 4-8: Clock Configuration # Modifying FRU Records 4.2.5 Some of the records are writeable to allow adapting the TAMC641 to user FPGA designs. If records are modified, the user is responsible to set the affected checksums to correct values. # 5 Functional Description This chapter gives a brief overview of the various module functions. Figure 5-1: TAMC641 Functional Block Diagram The FPGA is a Virtex-5 LX110T, LX155T, SX95T, FX70T or FX100T FPGA. Each FPGA provides four Gigabit Ethernet MACs, and one (for the LX and SX devices) or three (for the FX devices) Endpoint Blocks for PCI Express. In addition, the FX70T has one, and the FX100T two PowerPC® 440 Processor Blocks. | Virtex-5 | Logic<br>Cells | DSP48A1<br>Slices | Block<br>RAM<br>(Kb) | CMTs | Ethernet<br>MACs | PCIe<br>Endpoints | GTP / GTX<br>Transceivers | Power<br>PCs | |----------|----------------|-------------------|----------------------|------|------------------|-------------------|---------------------------|--------------| | LX110T | 110,592 | 64 | 5,328 | 6 | 4 | 1 | 16 / - | - | | LX155T | 155,648 | 128 | 7,632 | 6 | 4 | 1 | 16 / - | - | | SX95T | 94,208 | 640 | 8,784 | 6 | 4 | 1 | 16 / - | ı | | FX70T | 71,680 | 128 | 5,328 | 6 | 4 | 3 | - / 16 | 1 | | FX100T | 102,400 | 256 | 8,208 | 6 | 4 | 3 | - / 16 | 2 | Table 5-1: TAMC641 FPGA Feature Overview The FPGA is equipped with 18 I/O banks and 16 Multi-Gigabit Transceivers. | I/O Bank | V <sub>cco</sub> | $V_{REF}$ | Signals | Remarks | |------------|------------------|------------------|---------------------|---------------------| | 0 | 2.5V | - | Configuration | no user I/Os | | 1 | VCC_B | VREF_B_M2C | FMC HB[17:21] | | | 2 | 2.5V | - | AMC Tx12 -15 | + Configuration | | 3 | VADJ | VREF_A_M2C | FMC LA[17:23] | + 50MHz Clock | | 4 | 2.5V | - | AMC TCLK<br>FMC CLK | + AMC Tx 17 | | 5 | 1.8V | 0.9V | QDR-II Bank 1 | | | 6 | 1.8V | 0.9V | DDR2 Bank 0 | | | 11 | VADJ | VREF_A_M2C | FMC LA[17:33] | | | 12 | 1.8V | 0.9V | QDR-II Bank 0 | | | 13 | VADJ | VREF_A_M2C | FMC LA[00:16] | | | 15 | VADJ | VREF_A_M2C | FMC HA[00:16] | | | 17 | 1.8V | 0.9V | DDR2 Bank 1 | | | 18 | 1.8V | 0.9V | DDR2 Bank 0 | + AMC Rx 12-15 & 17 | | 19 | VCC_B | VREF_B_M2C | FMC HB[00:16] | | | 20 | 1.8V | ı | QDR-II Bank 0 | | | 21 | 1.8V | 0.9V | DDR2 Bank 1 | + GPIO | | 22 | 1.8V | 0.9V | DDR2 Bank 0 | + GPIO | | 23 | 1.8V | ı | QDR-II Bank 1 | | | 25 | 1.8V | 0.9V | DDR2 Bank 1 | | | GTP Bank | | Description | on | Remarks | | 112 (X0Y4) | AMC Backpla | ne, Port 6 & 7 | | | | 114 (X0Y3) | AMC Backpla | ne, Port 8 & 9 | | | | 116 (X0Y5) | AMC Backpla | ne, Port 4 & 5 | | | | 118 (X0Y2) | AMC Backpla | ne, Port 10 & 11 | | | | 120 (X0Y6) | AMC Backpla | | | | | 122 (X0Y1) | FMC, DP 0 & | 1 | | | | 124 (X0Y7) | AMC Backplane, Port 2 & 3 | | |------------|---------------------------|--| | 126 (X0Y0) | FMC, DP 2 & 3 | | Table 5-2: FPGA Bank Usage All FMC I/O lines are directly connected to the FPGA-pins. Refer to the Xilinx UG190: *Virtex-5 FPGA User Guide* for SelectIO interface signal standards, slew rate control and current drive strength capabilities. The board supports FPGA configuration via JTAG, from a Platform Flash or a SPI-Flash. ## **5.1 AMC Interface** AMC Ports 0 – 11 are connected to Virtex-5 GTP transceivers. Ports 12-17 are connected to Virtex-5 LVDS Receivers / Transmitters. All Ports provide on board AC-coupling on the Rx and Tx lines. FCLKA, commonly used as PCI-Express reference clock, is feed into a powerful clock distribution that allows using this clock on any FPGA GTP transceiver needed. TCLKA – TCLKD are accessible by the Virtex-5 FPGA via M-LVDS transceivers that allow their use as inputs or outputs. All TCLKx inputs are lead on FPGA global clock buffers. Figure 5-2: AMC Interface Diagram # 5.2 FMC Interface Instead of a front I/O Connector, the TAMC641 offers a FPGA Mezzanine Card (FMC) module slot. This allows a wide range of connectors to be used with the TAMC641 and customer specific I/O solutions can be easily applied. The FMC module can adapt the TAMC641 to various I/O standards, either mechanical (connector) or electrical. The TAMC641 implements the High Pin Count (HPC) option of the VITA 57.1 specification. It offers almost the full set of connectivity options for the High Pin Count option: - 160 single-ended or 80 differential user defined signals - · 4 differential clocks - 4 GTP links - · 2 GTP reference clock The geographic address pins GA[0:1] are wired to a default of "00". The FMC's present signal (FMC\_PRESENT\_1V8#) and the FMC I<sup>2</sup>C bus are also connected to the FPGA. Figure 5-3: FMC Interface to Virtex-5 FPGA Refer to chapter "X2 FMC HPC Connector" for the FMC HPC Connector pin assignment. The TAMC641 supports the maximum current for each FMC supply, as defined for a High Pin Count module slot. | Supply Voltage | Range | Max Amps | | | |----------------|--------------------------|----------|--|--| | VADJ | 1.2V <sup>2</sup> - 3.3V | 4 A | | | | VIO_B_M2C | 1.2V <sup>3</sup> - VADJ | 1.15 A | | | | VREF_A_M2C | 0V - VADJ | 1 mA | | | | VREF_B_M2C | 0V - VIO_B_M2C | 1 mA | | | | 3.3VAUX | 3.3V | 20 mA | | | | 3.3V | 3.3V | 3 A | | | | 12V | 12V | 1 A | | | Table 5-3: FMC-Supplies The FMC standard is described in: VITA 57.1, available at <a href="www.vita.com/fmc">www.vita.com/fmc</a>. Figure 5-4: A FMC Module #### 5.2.1 VADJ If a FMC is present, the TAMC641 MMC reads the FRU information from the FMC's I<sup>2</sup>C-EEPROM to determine how VADJ has to be adjusted. It uses the value in the "Nominal Voltage" field of the "DC Load" record for VADJ. If a FMC is present, but no valid FRU information is found (because the FMC EEPROM is empty or does not exist), the TAMC641 MMC uses its "Fallback-Voltage for VADJ" setting that is stored in the Internal Use Area of the TAMC641 FRU information. To avoid damage to a plugged FMC, the "Fallback-Voltage for VADJ" is set to "0x0000" by default, which means that the module will not be turned on by the MMC. If no FMC is present, the TAMC641 is turned on, with a VADJ set to 1.8V. $<sup>^2</sup>$ Vita 57.1 defines this voltage as 0 -3.3V. On the TAMC641, this is limited to 1.2 – 3.3V, because the FPGA I/O buffer will not work with voltages below 1.2V. <sup>&</sup>lt;sup>3</sup> Vita 57.1 defines this voltage as 0 -VADJ. On the TAMC641, this is limited to 1.2 –VADJ, because the FPGA I/O buffer will not work with voltages below 1.2V. If HB[21:00] are not used on the FMC, this voltage can be left unconnected. # **5.3 Memory Interfaces** The TAMC641 is equipped with two banks of 256 Mbytes, 32 bit wide DDR2 SDRAM, two banks of 2 Mbytes, 18 bit wide QDR-II SRAM and one 64-Mbit non-volatile SPI-Flash. #### 5.3.1 SPI-Flash The TAMC641 provides a Numonyx M25P64 64-Mbit serial Flash memory, which can be used as FPGA configuration source. After configuration, it is accessible from the FPGA, so it also can be used for code or user data storage. Before accessing the SPI-Flash (e.g. using Xilinx Impact), the FPGA Mode Pins must be set to "Master SPI" (factory default for V1.0 Rev. B). If the FPGA Mode Pins are set to a slave configuration Mode (factory default of V1.0 Rev. A), damage to the device will occur during SPI programming via Impact. See chapter "Board Configuration CPLD" for more details. #### 5.3.2 QDR-II SRAM The TAMC641 provides a total of 4 MByte (36 MBit) QDR-II SRAM per default (larger memories are possible). The FPGA has access to two QDR-II SRAM devices with 2 Mbit depth at 18 bit data bus width each. Both QDR-II SRAMs have fully independent interfaces to the FPGA (see figure below). The TAMC641 uses Burst of 4 QDR-II SRAM to lower address-bus switching speed and simultaneously achieve read and write accesses to independent addresses of the SRAM without any wait cycles. The maximum RAM clock frequency depends on FPGA speed and available routing resources. Figure 5-5: QDR-II SRAM Interfaces to FPGA #### 5.3.3 DDR2 SDRAM The TAMC641 provides four MT47H64M16 DDR2 memory components with a total of 512 MByte DDR2 SDRAM at 32 Bit data bus width. Both DDR2 SDRAM banks have fully independent interfaces to the FPGA. Figure 5-6: DDR2 SDRAM Interfaces to FPGA For details regarding the DDR2 SDRAM interface, please refer to the DDR2 SDRAM datasheet and the Xilinx UG086: Xilinx Memory Interface Generator (MIG) User Guide. #### 5.4 Reset The MMC generates the reset signal to the TAMC641 payload devices. It is connected to the Board Configuration CPLD (BCC) that vice versa generates the reset signal for the FPGA. Figure 5-7: Reset Structure # **5.5 GPIO** The TAMC641 has some general purpose I/O connected to the FPGA and the CPLD. | Signal | Bank | V <sub>cco</sub> | Pin | Description | |-----------------------|--------|------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | USER_SWITCH_CPLD | 1 | 2.5V | 49 | Select FPGA configuration source: | | | | | | ON = 0x0 (SPI) | | | | | | OFF = 0x1 (Platform Flash) | | USER_SWITCH_FPGA | 21 | 1.8V | Y24 | ON = 0x0, OFF = 0x1 | | GPIO_FPGA | 21 | 1.8V | AA24 | Push-Button (not installed on board, accessible via debug-connector) | | PL_LED2_CTRL | 1 | 2.5V | AA1 | Connected to MMC, pulled to MP, use as open- | | (CPLD) | (CPLD) | | | collector. | | | | | | When high, USER_LED is edge sensitive. When low, USER_LED is level sensitive | | PL_LED2_1V8<br>(FPGA) | 22 | 1.8V | AA2 | Connected to MMC, pulled to MP, use as open-collector. | | | | | | Controls the AMC "USER" front panel LED2. | | | | | | When edge sensitive, a rising or falling edge of USER_LED triggers the MMC to turn off the USER LED in the front panel for app. 100ms. When level sensitive it directly controls the USER LED. | Table 5-4: General Purpose I/O # 5.6 I<sup>2</sup>C The TAMC641 provides two user accessible I<sup>2</sup>C busses for communication between FPGA, FMC, Board Configuration CPLD (BCC), MMC and Si5338. | Signal | Description | |-------------|---------------------------------------------------------------------------------------------------------------| | SCL_PL | I <sup>2</sup> C between FPGA, MMC, BCC and Si5338 (I <sup>2</sup> C communication with the MMC is for future | | SDA_PL | use.) | | SCL_FMC_1V8 | I <sup>2</sup> C between FMC and FPGA The I <sup>2</sup> C to the FMC allows accessing the I <sup>2</sup> C- | | SDA_FMC_1V8 | EEPROM on the FMC. This I <sup>2</sup> C-bus is shared with the MMC. | | SCL_CPLD | I <sup>2</sup> C between BCC and EEPROM Only used by the BBC for clock configuration | | SDA_CPLD | data loading. User accessible after successful FPGA configuration. | Table 5-5: I2C Bus Signals Figure 5-8: I2C Bus Structure Overview The MMC has a slave I<sup>2</sup>C interface, while the BCC has a master only I<sup>2</sup>C interface. The BCC dedicated I<sup>2</sup>C interface is linked to SDA\_PL/SCL\_PL after successful FPGA configuration. Hence, the EEPROM can also be accessed by the FPGA. #### **5.7 UART** Two pins of the FPGA are routed to the Debug Connector for use as debug interface (UART). This is not a real RS-232 interface. A RS-232 transceiver or USB-UART that can work with 1.8V I/O voltage should connect with these signals. TEWS TA900 provides such an interface. | Signal | V <sub>cco</sub> | Description | |---------|------------------|--------------------------------| | Rx_FPGA | 1.8V | Accessible via debug-connector | | Tx_FPGA | 1.8V | | Table 5-6: FPGA UART # 5.8 Multi-Gigabit Transceiver (GTPs) The TAMC641 provides 16 GTPs (also referred to as Multi Gigabit Transceivers (MGTs), or RocketIOs): - 12 GTPs are wired to AMC ports 0 -11 (common options and fat pipe region). FPGA hardware resources (e.g. PCI Express Endpoint Blocks or Gigabit Ethernet MACs) can be used with the GTPs connected to these lanes. - 4 GTPs are wired to the FMC HPC connector (DP0 DP3). FPGA hardware resources like the Gigabit Ethernet MACs can be used with the GTPs connected to these lanes. Figure 5-9: GTP Block Diagram # 5.9 Configuration The user configurable parts of the TAMC641 are the Virtex-5 FPGA, a Board Configuration CPLD (BCC), two Xilinx Platform Flashes, a SPI-Flash and the Clock Generator device (necessary for the GTP Reference-Clock generation). The FPGA can be configured using either of the following sources: - Platform Flash (depending on FPGA-Size, storing multiple code revisions can be possible) - SPI-Flash - JTAG The configuration method is defined by the BCC (refer next chapter). Reprogramming the BCC allows (among others) adjusting different configuration methods. Alternatively, JTAG configuration is always available. On delivery, the FPGA configuration devices are blank whereas the BCC is programmed with an initial configuration. A green on board "DONE"-LED is lit when the FPGA is configured. If the FPGA is not configured, the red front panel out-of-service status LED remains lit. The BCC is configured via JTAG, and handles the basic board setup. # 5.9.1 Board Configuration CPLD (BCC) The Board Configuration CPLD (BCC) is configured via JTAG, and handles the basic board setup. This setup includes - FCLKA jitter attenuator setup - Configuration of the GTP Reference-Clock generation (Si5338) via I<sup>2</sup>C. - FPGA configuration source selection (performed by controlling the FPGA mode pins circuit) and starting FPGA configuration - TCLK[A-D] M-LVDS transceiver setup Two Platform Flashes are available. These can be cascaded to store the configuration data for the largest FPGAs. With a smaller FPGA, it is possible to store two or more different code versions, depending on FPGA or Code size. An I<sup>2</sup>C EEPROM is connected to the BCC. This is used to store the GTP Reference Clock configuration data. After configuration, its I<sup>2</sup>C bus is linked to the payload I<sup>2</sup>C bus to allow the FPGA accessing the EEPROM content. Figure 5-10: Board Configuration CPLD Block Diagram The factory default programming of the BCC causes the following: - MGTREFCLK\_116 (GTP-Dual Tile X0Y5) driven by FCLKA (100 MHz) - MGTREFCLK\_114 (GTP-Dual Tile X0Y3) driven by locally generated 156.25 MHz clock - MGTREFCLK\_120 (GTP-Dual Tile X0Y6) driven by locally generated 125 MHz clock - MGTREFCLK\_124 (GTP-Dual Tile X0Y7) driven by locally generated 75 MHz clock - TCLK [A-D] are configured as Type 1 Inputs - PL\_LED2 is level sensitive - FPGA Configuration Mode is "Master SelectMap" (fastest configuration method) or "Master SPI" - o Configuration Source in "Master SelectMap" are the two cascaded Platform Flashes The common power-up sequence is the following: - 1. BCC holds PROGRAM and INIT low (delaying FPGA configuration) - 2. BCC performs necessary Si5338 setup via I<sup>2</sup>C for GTP-Ref Clock generation. - 3. After successful Si5338 configuration (GTP-Ref. Clocks are valid), PROGRAM followed by INIT are released to start FPGA configuration. Configuration Source can be switched between Platform Flash and SPI-Flash by DIP-Switch 3. See chapter "Board Configuration" for more details. After configuration, the SPI-Flash is accessible by the FPGA logic via the following pins: | FPGA Signal | FPGA Pin | Mapping | |--------------------------|----------|----------| | IO_L4P_FCS_B_2 | AE14 | SPI CS_n | | CCLK_0 | N15 | SPI CLK | | IO_L4N_VREF_FOE_B_MOSI_2 | AF14 | SPI MOSI | | D_IN_0 | P15 | SPI MISO | See also Xilinx XAPP1020 "Post-Configuration Access to SPI Flash" for more details. # 5.9.2 FPGA Configuration As aforementioned, besides direct JTAG configuration, the TAMC641 provides up to three configuration sources: the two Platform Flashes and a SPI-Flash. Configuration from the SPI-Flash is done in the Master SPI configuration mode, whereas configuration from the Platform Flash can be done in Master or Slave Serial as well as in Master or Slave SelectMap mode. There are various ways of using the Platform Flashes. All configuration devices are programmed via JTAG; the SPI-Flash uses the indirect SPI programming mode (Xilinx Impact supported method). In all Master Modes, the Virtex-5 drives the Configuration Clock (CCLK). In all Slave Modes, the BCC drives CCLK to the Virtex-5 and the Flashes. This causes a conflict when indirect SPI programming (via Xilinx Impact) is used while the Virtex-5 is in a Slave Configuration Mode, because the Xilinx indirect SPI programming drives CCLK regardless of the FPGA Configuration Mode. Before accessing the SPI-Flash (e.g. using Xilinx Impact), the FPGA Mode Pins must be set to "Master SPI" (factory default for V1.0 Rev. B). If the FPGA Mode Pins are set to a Slave Configuration Mode (factory default of V1.0 Rev. A) during indirect SPI programming via Xilinx Impact, damage to the device will occur. By default, the FPGA configures from the Platform Flash in "Master SelectMap" Mode. By the use of DIP-Switch 3, the configuration can be switched to the SPI-Flash and "Master SPI" Mode. To change the TAMC641 programming, JTAG-capable hardware is needed (i.e. the Xilinx Platform Cable USB II). When the SPI-Flash is used for configuration, the FPGA is always master. Using the Platform Flashes in serial mode is not recommended, due to the high amount of time, but possible. Performing a Platform Flash based configuration in SelectMap mode is the fastest way to get the FPGA configured. (A byte-wide interface is used in this mode.) The following table lists the worst case configuration time of all TAMC641 configuration modes. In all Master Modes, the FPGA drives CCLK with ±50% frequency tolerance. The table below calculates with -50% of the nominal frequency. | | Configuration | FPGA Configuration Time | | | | | | |-----------|------------------|--------------------------------------|--------|--------|--------|--------|--------| | Device | Mode | max. allowed<br>Frequency<br>setting | LX110T | LX155T | SX95T | FX70T | FX100T | | Platform | Slave Serial | 32 MHz | 980 ms | 1.4 s | 1.2 s | 850 ms | 1.3 s | | Flash | Master Serial | 24 MHz (±50%) | 2.6 s | 3.6 s | 3.0 s | 2.3 s | 3.3 s | | | Slave SelectMap | 32 MHz | 125 ms | 170 ms | 140 ms | 110 ms | 160 ms | | | Master SelectMap | 20 MHz (±50%) | 390 ms | 540 ms | 450 ms | 340 ms | 500 ms | | SPI Flash | Master SPI | 20 MHz (±50%) | 3.2 s | 4.3 s | 3.6 s | 2.7 s | 4.0 s | Table 5-7: Worst Case FPGA Configuration Times In all Master configuration Modes, the desired configuration frequency must be set during bitstream generation (The Xilinx ISE "Generate Programming File" options allow to set the "Configuration Rate" (in MHz) in the "Configuration Options" category). If the Configuration Rate is not set by the user, the default configuration frequency of 2 MHz will be used and configuration time will rise up to 20 seconds. There are different configuration options. In Master SelectMap mode, the Virtex-5 supports Fallback Multiboot. In Slave SelectMap Mode, Platform Flash decompression can be used, or fastest configuration time is achieved. The slave mode uses the on board 32 MHz clock as configuration clock source. Bitsream encryption is supported in all configuration modes, but not in combination with Fallback Multiboot. After the FPGA configuration is done, the SPI-Flash is user accessible to enable the user to use it in a design, i.e. for data or code storage. ## 5.9.3 Clock Configuration TCLKA – TCLKD are connected to the FPGA via M-LVDS Transceivers as single-ended nodes TCLK?\_Rx and TCLK?\_Tx. Transmitter enable/disable and selection of receiver input type is controlled by the Board Configuration CPLD (BCC). The Receiver path (\_Rx) is always enabled. | Signal | Description | | |----------|------------------------------------------|--| | TC_DE1 | Transmit-Enable for TCLKA | | | | 0 = Disable (default) | | | | 1 = Enable | | | TC_DE3 | Transmit-Enable for TCLKB | | | | 0 = Disable (default) | | | | 1 = Enable | | | TC_DE0 | Transmit-Enable for TCLKC | | | | 0 = Disable (default) | | | | 1 = Enable | | | TC_DE2 | Transmit-Enable for TCLKD | | | | 0 = Disable (default) | | | | 1 = Enable | | | TC_FSEN2 | Select receiver input type for TCLK[A&B] | | | | 0 = Type 1 receiver inputs | | | | 1 = Type 2 receiver inputs (failsafe) | | | TC_FSEN1 | Select receiver input type for TCLK[C&D] | | | | 0 = Type 1 receiver inputs | | | | 1 = Type 2 receiver inputs (failsafe) | | Table 5-8: TCLK Transceiver configuration FCLKA is routed through a Jitter attenuator on the TAMC641. Its configuration is also defined by the BCC. The Jitter attenuator guarantees, that the FCLKA jitter is suitable for the Virtex-5 GTP-Transceiver. The output is always enabled. | Signal | Description | | |--------------|------------------------------------------------------|--| | J_MR | Master Reset | | | | 0 = Operation | | | | 1 = Reset | | | J_PLL_SEL | PLL Select | | | | 0 = Bypass PLL | | | | 1 = Use PLL (default) | | | J_BW_SEL | Select PLL Bandwidth | | | | 0 = 2.2 MHz (best jitter performance) | | | | 1 = 3 MHz (use for spread spectrum, factory default) | | | J_F_SEL[1:0] | Output-Frequency select pins | | | | 00 = 1 x Input-Frequency (factory default) | | | | 01 = 1.25 x Input-Frequency | | | | 10 = 2.5 x Input-Frequency | | | | 11 = 5 x Input-Frequency | | Table 5-9: Jitter attenuator configuration The TAMC641 provides the Si5338 as a user programmable GTP reference-clock generator. The generator allows changing the GTP reference-clocks to any specific application needs. The Si5338 is configured at each power-up via the PL-I<sup>2</sup>C bus by the BCC. An I<sup>2</sup>C EEPROM is connected to the BCC as non-volatile clock-configuration-data storage. At power up, the BCC reads the configuration data from the EEPROM, and writes it to the Si5338. The Si5338 INTR interrupt line can be used to detect e.g. a Loss of clock. By default, this signal is not used in the factory default CPLD code. Figure 5-11: Clock Configuration ## 5.10 Clocks The TAMC641 has the following main clock sources: - 100 MHz AMC fabric clock FCLKA. Routed through an ICS874001I-05 PCI Express jitterattenuator, which feeds the Si5338 that generates up to four clocks of any frequency needed. These clocks are connected to GTP reference clock inputs. - 50 MHz, provided by two fixed frequency oscillators. These clocks are connected to global clock inputs of the FPGA. - Clocks provided by the FMC slot. These clocks are connected to global and regional (clock capable) clock pins of the Virtex-5 FPGA, except GBTCLK0\_M2C and GBTCLK1\_M2C, which connect to GTP reference clock inputs. - TCLK[A-D]. All four AMC TCLK signals are connected via single-ended nodes to global clock pins of the FPGA via M-LVDS transceivers. The M-LVDS transceiver can independently be configured as input or output. AMC FCLKA is connected to the FPGA via a PCIe jitter-attenuator and a clock generator (Si5338) to reduce the Clock Jitter and allow pre-scaling the clock. The PCI-Express Interface works with Spread-Spectrum Clock (SSC) and non SSC PCI-Express Reference Clocks. Figure 5-12: FPGA Clock Sources The following table lists the available clock sources on the TAMC641: | FPGA Clock Pin/Signal Name | FPGA Pin<br>Number | Source | Description | | |----------------------------|--------------------|----------------------------|----------------------------------------------------------|--| | MGTREFCLK_120 | E4 / D4 | Si5338 CLK0 | GTP RefClock, differential | | | MGTREFCLK_124 | D8 / C8 | Si5338 CLK1 | GTP RefClock, differential | | | MGTREFCLK_116 | H4 / H3 | Si5338 CLK2 | GTP RefClock, differential | | | MGTREFCLK_114 | Y4 / Y3 | Si5338 CLK3 | GTP RefClock, differential | | | MGTREFCLK_122 | AL5 / AL4 | FMC GBTCLK0_M2C | GTP RefClock (from FMC) , differential | | | MGTREFCLK_126 | AL7 / AM7 | FMC GBTCLK1_M2C | GTP RefClock (from FMC) , differential | | | TCLKA_Rx | AH20 | TCLKA | Via M-LVDS Transceiver | | | TCLKB_Rx | AH14 | TCLKB | Via M-LVDS Transceiver | | | TCLKC_Rx | AG22 | TCLKC | Via M-LVDS Transceiver | | | TCLKD_Rx | AH12 | TCLKD | Via M-LVDS Transceiver | | | UCLK | AG21 | On board 50 MHz Oscillator | | | | HA_CLK | H17 | On board 50 MHz Oscillator | AC-Coupled | | | CLK0_M2C | AF18 / AE18 | FMC CLK0_M2C | LPC & HPC FMC, differential | | | CLK1_M2C | AH18 / AG17 | FMC CLK1_M2C | LPC & HPC FMC, differential | | | CLK2_BIDIR | AG18 / AF19 | FMC CLK2_BIDIR | HPC FMC only, differential, driven by either FPGA or FMC | | | CLK3_BIDIR | AH17 / AG16 | FMC CLK3_BIDIR | HPC FMC only, differential, driven by either FPGA or FMC | | | LA00_CC | AH34 / AJ34 | FMC LA00_CC | LPC & HPC FMC | | | LA01_CC | AF34 / AE34 | FMC LA01_CC | LPC & HPC FMC | | | LA17_CC | K33 / K32 | FMC LA17_CC | LPC & HPC FMC | | | LA18_CC | L34 / K34 | FMC LA18_CC | LPC & HPC FMC | | | HA00_CC | M31 / N30 | FMC HA00_CC | HPC FMC only | | | HA01_CC | P31 / P30 | FMC HA01_CC | HPC FMC only | | | HA17_CC | K17 / L18 | FMC HA17_CC | HPC FMC only | | | HB00_CC | G27 / H27 | FMC HB00_CC | HPC FMC only | | | HB06_CC | H28 / G28 | FMC HB06_CC | HPC FMC only | | | HB17_CC | G23 / H23 | FMC HB17_CC | HPC FMC only | | Table 5-10: Available FPGA clocks #### 5.10.1 GTP Reference Clock Generator The TAMC641 provides a user programmable Si5338 clock generator. The clock generator allows changing the GTP Reference-Clocks to any specific application needs. AMC FCLKA (lead over the on board Jitter Attenuator) or the on-board 50 MHz clock can be used as clock source for the GTP reference clock generation. Silicon Labs supplies software, which can be used to generate the settings for the desired GTP reference clocks. The default clock settings are: | Pin | Frequency | FPGA Pin | Description | |-----------|-------------------------|-----------------------------------|-------------------------------------------------------------------------------------------| | IN5 / IN6 | 100 MHz | - | Clock generator differential input, connected to Jitter Attenuator / PCIe Reference Clock | | IN3 | 50MHz | - | On board clock | | CLK0 | 125 MHz<br>(default) | Ref-Clkin of<br>GTP_DUAL<br>_X0Y6 | Reference Clock for AMC Port 0 & 1 | | CLK1 | 150 MHz<br>(default) | Ref-Clkin of<br>GTP_DUAL<br>_X0Y7 | Reference Clock for AMC Port 2 & 3 | | CLK2 | 100 MHz<br>(default) | Ref-Clkin of<br>GTP_DUAL<br>_X0Y5 | Reference Clock for AMC Port 4 – 7 | | CLK3 | 156.25 MHz<br>(default) | Ref-Clkin of<br>GTP_DUAL<br>_X0Y3 | Reference Clock for AMC Port 8 – 11 | Table 5-11: Programmable GTP Reference Clock For an instruction on how to reprogram the clock generator, refer to chapter "GTP Reference Clock Generator Configuration". ## 5.11 JTAG Beneath Platform Flash and SPI-Flash programming, direct FPGA configuration, FPGA readback or insystem diagnostics with ChipScope is possible using the JTAG-chain. The JTAG-chain can be extended to include the FMC-Slot, so JTAG capable FMCs can be accessed. The JTAG-chain is either accessible from the Debug Connector or from the AMC backplane JTAG port. If a debug adapter is connected to the TAMC641, the AMC backplane JTAG port is disabled. To ease the use of the JTAG-chain, it is partitioned into segments. Each segment can be separately held inactive and thereby excluded ("bypassed") from the chain. This allows masking the on board JTAG devices segment when a JTAG-device on a mounted FMC is targeted and vice versa. Figure 5-13: JTAG-Chain Segmentation The FMC-Slot is only included into the JTAG chain when a FMC is installed (PRSNT\_M2C# is asserted). (Signal not shown in the preceding figure.) The Configuration DIP-Switch allows configuring the JTAG-chain. The Configuration DIP-Switch is located on the back side of the TAMC641. | Switch | Signal | Description | | |--------|--------|---------------------------------------|--| | SW1 | ON | Include FMC in JTAG-chain | | | | OFF | Bypass FMC | | | SW2 | ON | Include TAMC641 devices in JTAG-chain | | | | OFF | Bypass TAMC641 devices | | Table 5-12: Configuration DIP-Switch SW1-SW2 Settings Devices in inactive segments are held in the Test-Logic-Reset State. ## 5.12 Thermal Management Power dissipation is design dependent. Main factors are device utilization, frequency and GTP-transceiver usage. Use the Xilinx XPower Estimator (XPE) or XPower Analyzer to determine the necessary amount of additional cooling requirements as forced air cooling. Forced air cooling is recommended during operation. The TAMC641 has a heatsink mounted on the Virtex-5 FPGA. The heatsink provides a $R_{TH}$ of app. 6 K/W without air flow, with forced air cooling $R_{TH}$ will decrease to app. 1.5 K/W. # 6 **Board Configuration** This chapter describes aspects of board configuration prior to board installation. ## 6.1 Overview Figure 6-1: Pre-Insertion Board Configuration Overview ## 6.2 DIP-Switch The DIP-Switch is located on the bottom side of the TAMC641 and provides the following configuration options. | Switch<br>No. | Switch<br>Position | Description | | |---------------|--------------------|-----------------------------------------------------|--| | 1 | ON | Include FMC in the JTAG-chain (default) | | | | OFF | Bypass FMC JTAG devices | | | 2 | ON | Include TAMC641 devices in the JTAG-chain (default) | | | | OFF | Bypass TAMC641 JTAG devices | | | 3 | ON | FPGA configures from SPI-Flash | | | | OFF | FPGA configures from Platform Flash (default) | | | 4 | ON | USER_SWITCH_FPGA read as 0 | | | | OFF | USER_SWITCH_FPGA read as 1 (default) | | Table 6-1: DIP-Switch ## 6.3 Battery Virtex-5 devices have on-chip decryption logic to support encrypted FPGA bitstream usage. Encrypted FPGA bitstreams cannot be copied or reverse engineered, securing your intellectual property. The TAMC641 provides a retainer for a 1225 button/coin cell. This battery is only used to store the encryption key inside the FPGA. To enable the usage of FPGA bitstream encryption, a battery (1225 button/coin cell) has to be populated in the TAMC641 battery retainer: - 1. Remove the heat sink - 2. Insert battery into holder - 3. Remount heat sink The thermal interface material between FPGA and Heat Sink is a so called "phase change material", and does not need to be renewed after heat sink removal. ## 6.4 Debug Connector The Debug Connector (X1) of the TAMC641 can be used to connect a Debug Adapter if necessary. The debug Adapter must be connected to the TAMC641 prior to AMC installation. It is recommended to use the TEWS TA900 Debug Adapter. The Debug Connector provides four logical interfaces: JTAG, MMC-UART, FPGA-UART and a General Purpose User Signal (GPIO BUT). - The JTAG interface consists of the signals TDI, TDO, TMS, TCK, uses 3.3V I/O voltage, and can run with up to 10 MHz. - The MMC-UART consists of Rx and Tx, uses 3.3V I/O voltage, and runs at 38400 bit/s using 8 data bits, no parity, one stop bit. - The FPGA-UART consists of Rx and Tx and uses 1.8V I/O voltage. Communication settings depend on the FPGA programming. - The General Purpose User Signal uses 1.8V I/O voltage. When used with the TEWS TA900, this signal is connected to a Push button on the TEWS TA900 and must be configured as FPGA input. ## 7 Installation This chapter contains general notes regarding installing the AMC module into a system. #### 7.1 Installation of a FMC Module Before installing a FMC module, make sure that the power supply for the TAMC641 is turned off. Components are Electrostatic Sensitive Devices (ESD). Use an anti-static mat connected to a wristband when handling or installing the components. #### 7.1.1 Using FMCs with Mid-Size faceplates The TAMC641 places the FMC directly at the AMC faceplate. The TAMC641 Mid-Size faceplate provides a cut-out to ease the installation of the FMC to the TAMC641. Pins of FMC I/O-connectors that protrude on the Side 2 (the "back side") of the FMC (compare read arrows) may still touch the AMC front panel. This is a potential hazardous electrical problem, depending on the I/O circuitry used. Figure 7-1: Using FMCs with Mid-Size faceplates It is within the responsibility of the user to carefully check whether a specific FMC can be used on a Mid-Size TAMC641. When you are not sure that the available spacing to conductive parts of the FMC is sufficient, it is strongly recommended to use a TAMC641 with Full-Size front panel. ### 7.1.2 Voltage Limits on FMC Modules The AMC.0 specification limits the voltages on AMC modules to following thresholds: | | DC voltage | AC voltage | | |----------|------------|------------|--| | Positive | +27V | +27V peak | | | Negative | -15V | -15V peak | | Table 7-1: Voltage Limits on FMC Modules For FMC modules using voltages (including I/O voltages) that exceed these thresholds, an additional insulation to adjacent modules or carrier boards becomes necessary. # 7.2 AMC Module Insertion & Hot-Swap During insertion and extraction, the operational state of the AMC is visible via the blue LED in the AMCs front panel. The following table lists all valid combinations of Hot-swap handle position and blue LED status, including a short description of what's going on. | Blue LED Handle | On | Off | Long Blink | Short Blink | |----------------------------------|------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------|--------------------------------------------------------| | Open<br>(Pulled out) | Extraction: Module can be extracted Insertion: Module is waiting for closed Handle | Module is waiting for hot swap negotiation | - | Hot swap<br>negotiation in<br>progress<br>(Extraction) | | Closed<br>(Pushed all way<br>in) | Module is waiting for hot swap negotiation | Module is active (operating) | Hot swap<br>negotiation in<br>progress<br>(Insertion) | - | Table 7-2: Hot-Swap states #### 7.2.1 Insertion Typical insertion sequence: - 1. Insert the AMC module into an appropriate slot, with the board edges aligned to the card guides - 2. Make sure that the module handle is pushed positional way in - a. Blue LED turns "ON." (Module is ready to attempt activation by the system) - b. Blue LED starts "Long Blink" (Hot Swap Negotiation / Module activation in progress) - c. Blue LED turns "OFF", and green LED turns "ON" (Module is ready and powered) When the Blue LED does not go off but returns to the "ON" state, the module FRU information is invalid or the system cannot provide the power requested by the AMC module. If the blue LED is off, but the red front panel out-of-service status LED remains lit, the FPGA may not be configured. #### 7.2.2 Extraction Typical extraction sequence: - 1. Pull the module handle out half way out - a. Blue LED starts "Short Blink" (Hot Swap Negotiation in progress) - b. Blue LED turns "ON" (Module is ready to be extracted) - 2. Pull the module handle out completely and extract the AMC module from the slot. # 8 **Indicators** This chapter describes all board indicators (LEDs) of the TAMC641. ## 8.1 Front Panel LEDs For a quick visual status inspection, the AMC module provides the following front panel LEDs. Figure 8-1: Front Panel LED View | LED | Color | State | Description | | | |----------|-------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--| | | | Off | No Power or Module is ready for normal operation | | | | | | Short Blink | Hot-Swap negotiation (extraction) | | | | HS | Blue | Long Blink | Hot-Swap negotiation (insertion) | | | | | | On | Module is ready to attempt activation by the system or Module is ready to be extracted | | | | FAIL Red | | Off | No fault | | | | | | On | Failure or out of service status | | | | | R Green Off On Design dependent, ca | Off | | | | | USER | | Design dependent, can be controlled by the FPGA. Refer to chapter "GPIO" | | | | | | | Blink | - Neier to chapter of 10 | | | Table 8-1: Front Panel LEDs ### 8.2 On board LEDs The TAMC641 provides a couple of board-status LEDs as shown below. These include Power-Good and FPGA configuration status indications. Figure 8-2: On board LED View | Indicator | Color | Description | |-----------|-------|--------------------------------------------------------------------------------| | FMC | Green | Power Good from FMC to Carrier Card Indicates that all FMC supplies are within | | | | tolerance | | 12V | Green | Power Good for +12V FMC supply | | MGT | Green | Power Good for FPGA supplies | | VADJ | Green | Power Good for VADJ | | 0V9 | Green | Power Good for QDR-II and DDR2 power supplies. | | DONE | Green | FPGA DONE-Pin LED | | | | Indicates successful FPGA configuration | | INIT# | Red | FPGA INIT-Pin LED | | | | DONE Low : Indicates unsuccessful FPGA configuration | | | | DONE High : Readback CRC Error if Readback CRC is enabled | Table 8-2: Board-Status LEDs # 9 I/O Connectors #### 9.1 Overview Figure 9-1: Connector Positions - Side 1 Figure 9-2: Connector Position - Side 2 # 9.2 I/O Circuitry All FMC I/O lines are directly connected to the FPGA-pins. Together with the adjustable $V_{CCO}$ and $V_{REF}$ this maintains the flexibility of the SelectIO technology of the Virtex-5 FPGA. Refer to UG190: *Virtex-5 FPGA User Guide* for SelectIO interface signal standards, slew rate control and current drive strength capabilities. ### 9.2.1 Differential Signaling As defined in the FMC specification, the TAMC641 expects the AC-coupling for DP signals to be placed on the FMC. ## 9.3 AMC-Connector X4 This is an excerpt of the AMC-connector pin assignment. Only the user available signals are listed. | Pin | Signal | Function | |-----|--------|----------------------------| | 15 | Rx0- | AMC port 0 (normally | | 14 | Rx0+ | used for GbE) | | 12 | Tx0- | Connected to | | 11 | Tx0+ | GTP_DUAL_X0Y5 | | 24 | Rx1- | AMC port 1 (normally | | 23 | Rx1+ | used for GbE) | | 21 | Tx1- | Connected to | | 20 | Tx1+ | GTP_DUAL_X0Y5 | | 33 | Rx2- | AMC port 2 (normally | | 32 | Rx2+ | used for Storage) | | 30 | Tx2- | Connected to | | 29 | Tx2+ | GTP_DUAL_X0Y0 | | 39 | Rx3- | AMC port 3 (normally | | 38 | Rx3+ | used for Storage) | | 36 | Tx3- | Connected to | | 35 | Tx3+ | GTP_DUAL_X0Y0 | | 48 | Rx4- | AMC port 4 (used for | | 47 | Rx4+ | PCIe, SRIO, XAUI,) | | 45 | Tx4- | Connected to | | 44 | Tx4+ | GTP_DUAL_X0Y4 | | 54 | Rx5- | AMC port 5 (used for | | 53 | Rx5+ | PCIe, SRIO, XAUI,) | | 51 | Tx5- | Connected to | | 50 | Tx5+ | GTP_DUAL_X0Y4 | | 63 | Rx6- | AMC port 6 (used for | | 62 | Rx6+ | PCIe, SRIO, XAUI,) | | 60 | Tx6- | Connected to | | 59 | Tx6+ | GTP_DUAL_X0Y3 | | 69 | Rx7- | AMC port 7 (used for | | 68 | Rx7+ | PCIe, SRIO, XAUI,) | | 66 | Tx7- | Connected to | | 65 | Tx7+ | GTP_DUAL_X0Y3 | | | | | | 81 | FCLKA- | - Fabric Clock (100 MHz) | | 80 | FCLKA+ | T abile Clock (100 WII IZ) | | Pin | Signal | Function | | |-----|--------|-----------------------|--| | 87 | Rx8- | AMC port 8 (used for | | | 88 | Rx8+ | PCIe, SRIO, XAUI,) | | | 90 | Tx8- | Connected to | | | 91 | Tx8+ | GTP_DUAL_X0Y2 | | | 93 | Rx9- | AMC port 9 (used for | | | 94 | Rx9+ | PCIe, SRIO, XAUI,) | | | 96 | Tx9- | Connected to | | | 97 | Tx9+ | GTP_DUAL_X0Y2 | | | 99 | Rx10- | AMC port 10 (used for | | | 100 | Rx10+ | PCIe, SRIO, XAUI,) | | | 102 | Tx10- | Connected to | | | 103 | Tx10+ | GTP_DUAL_X0Y1 | | | 105 | Rx11- | AMC port 11 (used for | | | 106 | Rx11+ | PCIe, SRIO, XAUI,) | | | 108 | Tx11- | Connected to | | | 109 | Tx11+ | GTP_DUAL_X0Y1 | | | 111 | Rx12- | | | | 112 | Rx12+ | AMC Dark 40 | | | 114 | Tx12- | AMC Port 12 | | | 115 | Tx12+ | | | | 117 | Rx13- | | | | 118 | Rx13+ | - AMC Port 13 | | | 120 | Tx13- | AIVIC POIL 13 | | | 121 | Tx13+ | | | | 123 | Rx14- | | | | 124 | Rx14+ | AMC Dowt 4.4 | | | 126 | Tx14- | AMC Port 14 | | | 127 | Tx14+ | | | | 129 | Rx15- | | | | 130 | Rx15+ | AMC Port 45 | | | 132 | Tx15- | - AMC Port 15 | | | 133 | Tx15+ | ] | | | 141 | Rx17- | | | | 142 | Rx17+ | AMC Dort 47 | | | 144 | Tx17- | - AMC Port 17 | | | 145 | Tx17+ | | | | Pin | Signal | Function | |-----|--------|----------------------| | 78 | TCLKB- | - Differential Clock | | 77 | TCLKB+ | Differential Clock | | 75 | TCLKA- | - Differential Clock | | 74 | TCLKA+ | - Dillerential Clock | | Pin | Signal | Function | |-----|--------|---------------------| | 135 | TCLKC- | Differential Clock | | 136 | TCLKC+ | Differential Clock | | 138 | TCLKD- | Differential Clock | | 139 | TCLKD+ | Dilleterillar Clock | Table 9-1: Pin Assignment AMC Connector X4 ## 9.4 FMC HPC Connector X2 The TAMC641 provides a High Pin Count interface. The connector is a Samtec #ASP-134486-01. | Pin | K | J | Н | G | F | |-----|------------|------------|-------------|------------|-----------| | 1 | VREF_B_M2C | GND | VREF_B_M2C | GND | PG_M2C | | 2 | GND | CLK3_M2C_P | PRSNT_M2C_L | CLK1_M2C_P | GND | | 3 | GND | CLK3_M2C_N | GND | CLK1_M2C_N | GND | | 4 | CLK2_M2C_P | GND | CLK0_M2C_P | GND | HA00_P_CC | | 5 | CLK2_M2C_N | GND | CLK0_M2C_N | GND | HA00_N_CC | | 6 | GND | HA03_P | GND | LA00_P_CC | GND | | 7 | HA02_P | HA03_N | LA02_P | LA00_N_CC | HA04_P | | 8 | HA02_N | GND | LA02_N | GND | HA04_N | | 9 | GND | HA07_P | GND | LA03_P | GND | | 10 | HA06_P | HA07_N | LA04_P | LA03_N | HA08_P | | 11 | HA06_N | GND | LA04_N | GND | HA08_N | | 12 | GND | HA11_P | GND | LA08_P | GND | | 13 | HA10_P | HA11_N | LA07_P | LA08_N | HA12_P | | 14 | HA10_N | GND | LA07_N | GND | HA12_N | | 15 | GND | HA14_P | GND | LA12_P | GND | | 16 | HA17_P_CC | HA14_N | LA11_P | LA12_N | HA15_P | | 17 | HA17_N_CC | GND | LA11_N | GND | HA15_N | | 18 | GND | HA18_P | GND | LA16_P | GND | | 19 | HA21_P | HA18_N | LA15_P | LA16_N | HA19_P | | 20 | HA21_N | GND | LA15_N | GND | HA19_N | | 21 | GND | HA22_P | GND | LA20_P | GND | | 22 | HA23_P | HA22_N | LA19_P | LA20_N | HB02_P | | 23 | HA23_N | GND | LA19_N | GND | HB02_N | | 24 | GND | HB01_P | GND | LA22_P | GND | | 25 | HB00_P_CC | HB01_N | LA21_P | LA22_N | HB04_P | | 26 | HB00_N_CC | GND | LA21_N | GND | HB04_N | | 27 | GND | HB07_P | GND | LA25_P | GND | | 28 | HB06_P_CC | HB07_N | LA24_P | LA25_N | HB08_P | | 29 | HB06_N_CC | GND | LA24_N | GND | HB08_N | | 30 | GND | HB11_P | GND | LA29_P | GND | | 31 | HB10_P | HB11_N | LA28_P | LA29_N | HB12_P | | 32 | HB10_N | GND | LA28_N | GND | HB12_N | | 33 | GND | HB15_P | GND | LA31_P | GND | | 34 | HB14_P | HB15_N | LA30_P | LA31_N | HB16_P | | 35 | HB14_N | GND | LA30_N | GND | HB16_N | | 36 | GND | HB18_P | GND | LA33_P | GND | | Pin | K | J | Н | G | F | |-----|-----------|-----------|--------|--------|--------| | 37 | HB17_P_CC | HB18_N | LA32_P | LA33_N | HB20_P | | 38 | HB17_N_CC | GND | LA32_N | GND | HB20_N | | 39 | GND | VIO_B_M2C | GND | VADJ | GND | | 40 | VIO_B_M2C | GND | VADJ | GND | VADJ | Table 9-2: Pin Assignment FMC-Connector X2 Row F-K | Pin | E | D | С | В | A | |-----|-----------|---------------|-----------|----------------|-----------| | 1 | GND | PG_M2C | GND | CLK_DIR | GND | | 2 | HA01_P_CC | GND | DP0_C2M_P | GND | DP1_M2C_P | | 3 | HA01_N_CC | GND | DP0_C2M_N | GND | DP1_M2C_N | | 4 | GND | GBTCLK0_M2C_P | GND | - | GND | | 5 | GND | GBTCLK0_M2C_N | GND | - | GND | | 6 | HA05_P | GND | DP0_M2C_P | GND | DP2_M2C_P | | 7 | HA05_N | GND | DP0_M2C_N | GND | DP2_M2C_N | | 8 | GND | LA01_P_CC | GND | - | GND | | 9 | HA09_P | LA01_N_CC | GND | - | GND | | 10 | HA09_N | GND | LA06_P | GND | DP3_M2C_P | | 11 | GND | LA05_P | LA06_N | GND | DP3_M2C_N | | 12 | HA13_P | LA05_N | GND | - | GND | | 13 | HA13_N | GND | GND | - | GND | | 14 | GND | LA09_P | LA10_P | GND | - | | 15 | HA16_P | LA09_N | LA10_N | GND | - | | 16 | HA16_N | GND | GND | - | GND | | 17 | GND | LA13_P | GND | - | GND | | 18 | HA20_P | LA13_N | LA14_P | GND | - | | 19 | HA20_N | GND | LA14_N | GND | - | | 20 | GND | LA17_P_CC | GND | GBTCLK1_M2C_P* | GND | | 21 | HB03_P | LA17_N_CC | GND | GBTCLK1_M2C_N* | GND | | 22 | HB03_N | GND | LA18_P_CC | GND | DP1_C2M_P | | 23 | GND | LA23_P | LA18_N_CC | GND | DP1_C2M_N | | 24 | HB05_P | LA23_N | GND | - | GND | | 25 | HB05_N | GND | GND | - | GND | | 26 | GND | LA26_P | LA27_P | GND | DP2_C2M_P | | 27 | HB09_P | LA26_N | LA27_N | GND | DP2_C2M_N | | 28 | HB09_N | GND | GND | - | GND | | 29 | GND | TCK | GND | - | GND | | 30 | HB13_P | TDI | SCL | GND | DP3_C2M_P | | 31 | HB13_N | TDO | SDA | GND | DP3_C2M_N | | 32 | GND | 3P3V AUX | GND | - | GND | | Pin | Е | D | С | В | Α | |-----|--------|--------|------|-----|-----| | 33 | HB19_P | TMS | GND | - | GND | | 34 | HB19_N | TRST_L | GA0 | GND | - | | 35 | GND | GA1 | 12V | GND | - | | 36 | HB21_P | 3P3V | GND | - | GND | | 37 | HB21_N | GND | 12V | - | GND | | 38 | GND | 3P3V | GND | GND | - | | 39 | VADJ | GND | 3P3V | GND | - | | 40 | GND | 3P3V | GND | - | GND | Table 9-3: Pin Assignment FMC-Connector X2 Row A-E # 9.5 Debug-Connector X1 | Pin | Signal | I/O | Description | |-----|----------|-----|------------------------------------------------------------------------| | 1 | JTAG SEL | 0 | A 1k pullup to 3.3 Volt is located on the TAMC641 | | 2 | 3.3V | 0 | JTAG reference I/O voltage | | 3 | TDO | 0 | Test Data Output | | 4 | GND | - | Ground | | 5 | TDI | I | Test Data Input | | 6 | TMS | I | Test Mode Select Input | | 7 | GND | - | Ground | | 8 | TCK | I | Test Clock | | 9 | GND | - | Ground | | 10 | UART_RxD | I | FPGA UART Receive Data | | 11 | 1.8V | 0 | UART reference I/O voltage | | 12 | UART_TxD | 0 | FPGA UART Transmit Data (driven by FPGA) | | 13 | GND | - | Ground | | 14 | MMC_RxD | I | MMC UART Receive Data | | 15 | MP | 0 | UART reference I/O voltage (3.3V) | | 16 | MMC_TxD | 0 | MMC UART Transmit Data (driven by MMC) | | 17 | GND | - | Ground | | 18 | 3.3V | 0 | +3.3 Volt | | 19 | 1.8V | 0 | User signal reference I/O voltage | | 20 | GPIO_BUT | I | User signal connected to the FPGA. Use FPGA internal Pullup if needed. | Table 9-4: Pin Assignment Debug Connector X1 # 10 Design Help ## 10.1 GTP Reference Clock Generator Configuration Use the Silicon Labs software to generate a new configuration file. Take the related register content, and program it into the EEPROM. ## 10.2 Example Design TEWS offers an FPGA Development Kit (TAMC641-FDK), which consists of a well documented basic example design. It includes an .ucf file with all necessary pin assignments and basic timing constraints. The example design covers the main functionalities of the TAMC641. It implements a DMA capable PCIe endpoint with interrupt support, register mapping, DDR2 and QDR-II memory access and basic I/O to the FMC slot. It comes as a Xilinx ISE project with source code and as a ready-to-download bitstream. This example design can be used as a starting point for own projects. The basic example design requires the Embedded Development Kit (EDK), which is part of the Embedded or System Edition of the ISE Design Suite from Xilinx (downloadable from <a href="www.xilinx.com">www.xilinx.com</a>, a 30 day evaluation license is available) or can be licensed separately. It will not work with the free ISE WebPACK. ## 10.1 Troubleshooting #### 10.1.1 Board does not power up #### Possible Cause: - (1) An FMC without valid EEPROM content is mounted, and the MMC is not able to set V<sub>ADJ</sub>. To avoid potential hardware damage, the board does not power up. A solution is to manually set the VADJ as described in chapter "Internal Use Area". - (2) The module current requirements including the FMC exceed the system limits. There are several possibilities to solve this issue: - a. Remove other AMCs from the system - b. Use a different power-supply with higher wattage correct configuration source via DIP Switch 3 and try again. c. Modify the "Current Draw" value in the Multi record Area, as described in chapter "Module Current Requirements" #### 10.1.2 DONE is always off #### Possible Cause: (1) If the Configuration Clock Rate for the FPGA bitstream generation is left at the Xilinx default setting of 2 MHz and the SPI flash is selected as configuration source, it may take up to one minute until the FPGA configuration is finished. Set the Configuration Clock Rate to the desired value as described in chapter "FPGA Configuration" to speed up your FPGA configuration. Do not exceed the maximum value for the Configuration Clock - Rate. Otherwise the FPGA configuration will fail. (2) The configuration source is empty or the wrong configuration source is selected. Make sure that you programmed your bitstream into the desired configuration source, select the - (3) The board is shipped with a preprogrammed Board Configuration CPLD (BCC), which is necessary for FPGA configuration. If the BCC is erased by mistake, FPGA configuration will fail. You have to reprogram the BCC for successful FPGA configuration and board operation. The factory default BCC program-file is part of the TAMC641-ED and the TAMC641-FDK. #### 10.1.3 INIT LED stays illuminated (red) #### Possible Cause: - If the Si5338 configuration data is modified by the customer, the Si5338 configuration may fail due to faulty settings. Carefully check your custom Si5338 settings, or do a cross-check with the factory default settings. - 2) EDGA indicates a CPC or IDCODE Error during configuration (DONE LED off) - (2) FPGA indicates a CRC or IDCODE Error during configuration (DONE LED off). Please check if you selected the correct Device and Package in your VHDL-project design flow. ## 11 Appendix A This appendix contains the signal to pin assignments for the Board Configuration CPLD (BCC). ``` TEWS TECHNOLOGIES ## ## : TAMC64x Configuration CPLD Project Name ## File Name : tamc64x_cpld.ucf : XC2C256-6VQ100 ## Target Device Design Tool : Xilinx ISE Design Suit Embedded 13.2 ## ## Simulation Tool : Xilinx ISIM ## ## Description : The files lists all CPLD pins that are connected on the TAMC64x ## : TEWS TECHNOLOGIES GmbH ## Owner ## Am Bahnhof 7 D-25469 Halstenbek ## ## ## Tel.: +49 / (0)4101 / 4058-0 ## Fax.: +49 / (0)4101 / 4058-19 ## e-mail: support@tews.com ## ## Copyright (c) 2011 TEWS TECHNOLOGIES GmbH ## ## ## History 1 : (SE, 13.04.2011) ## Version ## Initial Version ## Version 2 : (SE, 04.07.2011) ## For safety reason the following changes have been made: ## - Set timing constraints for PAD-to-PAD I/O ## - Set timing constraints for CPLD payload and EEPROM I2C bus - Added pull up constraints for SPI_MISO, FPGA_RS[x], CFG_D[5,6], FCS_n, CCLK, ## MOSI and D_IN ## ## 3 : (SE, 05.07.2011) Version ## For safety reason the following changes have been made: - Added Schmitt Trigger I/O for FCS_n and DONE ## ## - Removed MMC SPI and Revision Interface ## Version 4 : (SE, 08.07.2011) ## Changed Design Tool Version 5 : (SE, 11.07.2011) ## Revised timing constraints ## Version 6 : (SE, 18.07.2011) ## For safety reason the following changes have been made: ## - Added Schmitt Trigger I/O for I2C busses ## Version 6 : (SE, 27.07.2011) Minor file cosmetics ## ## Comments ## - Net CFG_Dx 0-2 do not have the extension _FSx 0-2 ## ## ## Section: Miscellaneous # Define IO Standards net "CFG CLK[?]" iostandard = LVCMOS25; net "SCL_PL" iostandard = LVCMOS25; net "SDA_PL" iostandard = LVCMOS25; net "BATTERY_LOW_n" iostandard = LVCMOS25; net. "WC n" iostandard = LVCMOS25; ``` ``` net "SCL_CPLD" iostandard = LVCMOS25; net "SDA CPLD" iostandard = LVCMOS25; net "E[?]" iostandard = LVCMOS25; net "FPGA_RST_n" iostandard = LVCMOS25; iostandard = LVCMOS25; net "PL_LED2_CTRL" net "USER_SWITCH_CPLD" iostandard = LVCMOS25; net "INTR" iostandard = LVCMOS25; # Define Location Constraints net "CFG_CLK[0]" loc = P23; # Bank 1, 32 MHz On-board Oscillator net "CFG_CLK[1]" loc = P27; # Bank 1, Same as [0] net "SCL PL" loc = P22; # Bank 1, open drain net "SDA_PL" loc = P28; # Bank 1, open drain net "BATTERY_LOW_n" loc = P63; # Bank 1 net "WC n" loc = P55; # Bank 1 net "SCL_CPLD" loc = P53; # Bank 1 net "SDA_CPLD" loc = P52; # Bank 1 loc = P59; net "E[0]" # Bank 1, EEPROM A8 respectively net "E[1]" # Bank 1, EEPROM A9 respectively # Bank 1, EEPROM A10 respectively loc = P58; net "E[2]" loc = P56; net "FPGA_RST_n" loc = P60; # Bank 1 net "PL_LED2_CTRL" loc = P44; # Bank 1 net "USER_SWITCH_CPLD" loc = P49; # Bank 1 net "INTR" loc = P19; # Bank 1 # Timing Constraints net "CFG_CLK[?]" tnm_net = "CFG_CLK"; timespec "TS_CFG_CLK" = period "CFG_CLK" 32 MHz high 50 %; # There are two different modes exist for configuration: Master Modes and Slave Modes. In Slave Modes # the clock is provided by the CPLD. The timing afforts are relaxed since the clock arrives almost to # the same time at the Platform Flash devices and the FPGA. # In Master Modes the Clock must pass the CPLD and the configuration data must return within the same # cycle to the FPGA. Consequently, timing afforts are high. # Since no the CPLD drivers cannot be selected, the constraint is set as close as possible to the \ensuremath{\mathtt{\#}} hardware limit in order to detect the maximum frequency timespec "TS_PADS" = from pads to pads 10 ns; # Cover direct Connections # The I2C bus operates at 333.33 kHz respectively 3 us. Hence, the timing constraints are relaxed net "SCL_PL" offset = out 50 ns after "CFG_CLK[1]"; # Ensure internal expected timing net "SDA_PL" offset = out 50 ns after "CFG_CLK[1]"; # Ensure internal expected timing offset = in 50 ns after "CFG_CLK[1]"; # Ensure internal expected timing net "SDA_PL" net "SCL_CPLD" offset = out 50 ns after "CFG_CLK[1]"; # Ensure internal expected timing offset = out 50 ns after "CFG_CLK[1]"; # Ensure internal expected timing net "SDA_CPLD" offset = in 50 ns after "CFG_CLK[1]"; # Ensure internal expected timing net "SDA_CPLD" # Additional Constrains net "SCL_PL" open_drain; # Uses open drain due to pin circuit net "SCL_PL" schmitt_trigger; # For Safty Reason on Control I/O net "SDA_PL" # Uses open drain due to pin circuit open drain; net "SDA PL" schmitt_trigger; # For Safty Reason on Control I/O net "SCL_CPLD" open_drain; # Uses open drain due to pin circuit schmitt_trigger; # For Safty Reason on Control I/O net "SCL_CPLD" ``` ``` net "SDA_CPLD" # Uses open drain due to pin circuit open drain; schmitt_trigger; # For Safty Reason on Control I/O net "SDA CPLD" ## Section: Configuration Flash I/II (Shared) # Define IO Standards net "XCF D[?]" iostandard = LVCMOS33; # Define Location Constraints net "XCF_D[0]" loc = P76; # Bank 2, Shared between Flash I/II # Bank 2, Shared between Flash I/II net "XCF_D[1]" loc = P71; net "XCF D[2]" loc = P72; # Bank 2, Shared between Flash I/II # Bank 2, Shared between Flash I/II net "XCF D[3]" loc = P73; net "XCF_D[4]" loc = P74; # Bank 2, Shared between Flash I/II # Bank 2, Shared between Flash I/II # Bank 2, Shared between Flash I/II net "XCF_D[5]" loc = P77; loc = P70; net "XCF_D[6]" loc = P78; net "XCF_D[7]" # Bank 2, Shared between Flash I/II ## Section: Configuration Flash 0 # Define IO Standards net "CLK_PF0" iostandard = LVCMOS33; net "CE_PF0_n" iostandard = LVCMOS33; net "CEO_PF0_n" iostandard = LVCMOS33; net "REV_SEL?_PF0" iostandard = LVCMOS33; iostandard = LVCMOS33; net "CLKOUT PF0" net "EN_EXT_SEL_PF0_n" iostandard = LVCMOS33; # Define Location Constraints net "CLK_PF0" loc = P79; # Bank 2 net "CE PF0 n" loc = P81; # Bank 2 loc = P86; net "CEO_PF0_n" # Bank 2 net "REV_SEL0_PF0" loc = P68; # Bank 2 net "REV_SEL1_PF0" loc = P67; # Bank 2 net "CLKOUT PF0" loc = P66; # Bank 2 net "EN_EXT_SEL_PF0_n" loc = P65; # Bank 2 # Timing Constraints # Two different paths exist: Xilinx Platform Flash and normal Flash. Xilinx limits the # maximum frequency for its Platform Flashs to 25ns (serial mode) or 30 ns (parallel). \ensuremath{\sharp} For safety reasons the slower path is used below net "CLK_PF0" tnm_net = "CLK_PF0"; timespec "TS_CLK_PF0" = period "CLK_PF0" 33.33 MHz high 50 %; ## Section: Configuration Flash 1 # Define IO Standards net "CLK_PF1" iostandard = LVCMOS33; net "CE_PF1_n" iostandard = LVCMOS33; iostandard = LVCMOS33; net "REV_SEL?_PF1" net "CLKOUT_PF1" iostandard = LVCMOS33; net "EN_EXT_SEL_PF1_n" iostandard = LVCMOS33; ``` ``` # Define Location Constraints loc = P95; net "CLK_PF1" # Bank 2 net "CE_PF1_n" loc = P12; # Bank 2 loc = P94; net "REV_SEL0_PF1" # Bank 2 loc = P92; net "REV_SEL1_PF1" # Bank 2 net "CLKOUT PF1" loc = P89; # Bank 2 net "EN_EXT_SEL_PF1_n" loc = P91; # Bank 2 # Timing Constraints # Two different paths exist: Xilinx Platform Flash and normal Flash. Xilinx limits the # maximum frequency for its Platform Flashs to 25ns (serial mode) or 30 ns (parallel). # For safety reasons the slower path is used below tnm_net = "CLK_PF1"; net "CLK PF1" = period "CLK_PF1" 33.33 MHz high 50 %; timespec "TS_CLK_PF1" ## Section: MLVDS Telecom Clocks (0-3) # Define IO Standarts net "TC_DE[?]" iostandard = LVCMOS33; net "TC_FSEN[?]" iostandard = LVCMOS33; # Define Location Constraints net "TC DE[0]" loc = P93; # Bank 2 net "TC_DE[1]" loc = P87; # Bank 2 net "TC_DE[2]" loc = P82; # Bank 2 loc = P96; net "TC_DE[3]" # Bank 2 loc = P85; net "TC_FSEN[1]" # Bank 2 net "TC FSEN[2]" loc = P97; # Bank 2 ## Section: Jitter Attenuator # Define IO Standarts net "J *" iostandard = LVCMOS33; # Define Location Constraints net "J_MR" loc = P90; # Bank 2 net "J_PLL_SEL" loc = P8; # Bank 2 net "J_BW_SEL" loc = P9; # Bank 2 net "J_F_SEL[0]" loc = P10; # Bank 2 loc = P11; net "J_F_SEL[1]" # Bank 2 ## Section: SPI Flash Interface # Define IO Standarts net "SPI_*" iostandard = LVCMOS33; # Define Location Constraints loc = P7; net "SPI_MOSI" # Bank 2 net "SPI_CS_n" loc = P80; # Bank 2 net "SPI MISO" loc = P13; # Bank 2 net "SPI_CLK" loc = P6; # Bank 2 ``` ``` # Additional Constraints net "SPI MISO" pullup; # Ensure Valid Input Level ## Section: MMC # Define IO Standards net "PL RESET n" iostandard = LVCMOS33; # Define Location Constraints net "PL_RESET_n" loc = P99; # Bank 2 config prohibit = P3; # Bank 2 config prohibit = P4; # Bank 2 config prohibit = P1; # Bank 2 config prohibit = P2; # Bank 2 config prohibit = P64; # Bank 1 config prohibit = P61; # Bank 1 ## Section: FPGA Configuration # Define IO Standards net "FPGA_RS[?]" iostandard = LVCMOS25; net "CFG_D[?]" iostandard = LVCMOS25; net "FCS_n" iostandard = LVCMOS25; net "MOSI" iostandard = LVCMOS25; iostandard = LVCMOS25; net "CCLK" iostandard = LVCMOS25; iostandard = LVCMOS25; net "INIT_n" net "DONE" net "PROGRAM n" iostandard = LVCMOS25; net "HSWAPEN" iostandard = LVCMOS25; net "D IN" iostandard = LVCMOS25; iostandard = LVCMOS25; net "M[?]" # Define Location Constraints net "FPGA_RS[0]" loc = P43; # Bank 1 net "FPGA_RS[1]" loc = P29; # Bank 1 net "CFG_D[0]" loc = P40; # Bank 1 net "CFG D[1]" loc = P41; # Bank 1 net "CFG D[2]" loc = P37; # Bank 1 loc = P39; net "CFG_D[3]" # Bank 1 net "CFG_D[4]" loc = P32; # Bank 1 net "CFG_D[5]" loc = P15; # Bank 1 loc = P36; net "CFG_D[6]" # Bank 1 net "CFG_D[7]" loc = P35; # Bank 1 net "FCS_n" loc = P30; # Bank 1 loc = P17; net "MOST" # Bank 1 net "CCLK" loc = P14; # Bank 1 net "INIT n" loc = P33; # Bank 1 net "DONE" loc = P50; # Bank 1 net "PROGRAM_n" loc = P54; # Bank 1 net "HSWAPEN" # Bank 1 loc = P46; net "D_IN" loc = P16; # Bank 1 net "M[0]" loc = P34; # Bank 1 net "M[1]" loc = P18; # Bank 1 net "M[2]" loc = P42; # Bank 1 ``` #### # Timing Constraints ``` # Two different paths exist: Xilinx Platform Flash and normal Flash. Xilinx limits the # maximum frequency for its Platform Flashs to 25ns (serial mode) or 30 ns (parallel). # The maximum frequency for the normal SPI Flash is 50 MHz. In accordance to that, the # maximum frequency is set net "CCLK" tnm_net = "CCLK"; timespec "TS_CCLK" = period "CCLK" 50 MHz high 50 %; # Additional Constraints net "FPGA_RS[0]" pullup; # Ensure Valid Input Level net "FPGA_RS[1]" # Ensure Valid Input Level pullup; net "FCS_n" # Recommend in UG191 pullup; net "FCS_n" schmitt_trigger; # For Safty Reason on Control I/O net "MOSI" net "CCLK" # Recommend in UG191 pullup; pullup; # Ensure Valid Input Level net "DONE" schmitt_trigger; # For Safty Reason on Control I/O net "D_IN" # Recommend in UG191 pullup; ``` ## 12 Appendix B This appendix contains the signal to pin assignments for the Virtex-5 FPGA. ``` TEWS TECHNOLOGIES ## ## : TAMC641 Complete Pinning Project Name ## File Name : tamc641_fpga.ucf ## Target Device : XC5VxxxxT-xFF1136 : Xilinx ISE Design Suit Embedded 12.4 ## Design Tool ## Simulation Tool: Xilinx ISIM included in Design Tool ## ## Description : The file lists all FPGA pins that are connected on the TAMC641 ## : TEWS TECHNOLOGIES GmbH ## Owner ## Am Bahnhof 7 D-25469 Halstenbek ## ## ## Tel.: +49 / (0)4101 / 4058-0 ## Fax.: +49 / (0)4101 / 4058-19 ## e-mail: support@tews.com ## ## Copyright (c) 2011 ## TEWS TECHNOLOGIES GmbH ## ## History 1 : (SE, 03.08.2010) ## Version ## Initial Version ## Version 2 : (NK, 03.11.2010) ## - DDR2 and QDR-II Pinout changed, ## - DDR2 Address-Bank is now DCI capable, ## DDR2 Addr.- and Conrtol-Signal I/O-Standard changed to DCI ## - some I/O-Standards corrected ## 3 : (NK, 24.11.2010) ## Version ## I/O-Standard of DDRx_CKE changed to SSTL18_II ## Version 4 : (NK, 25.11.2010) ## QDR-II SRAM Bank 0: ## - Pinout change to improve routing - I/O-Standard of QDRx_CQ and _CQ_n changed to HSTL_DCI_18 ## ## Version 5 : (SE, 10.02.2011) ## General Revise ## Version 6 : (SE, 14.02.2011) ## - Corrected default I/O standard for DM and DQS (DDRO/1) ## Version 7 : (SE, 18.04.2011) ## - DDR1_BA[2] Updated Bank Assignment - DDR1_CKE Pin-Location Correction ## ## Version 8 : (SE, 19.04.2011) - Added Pin Locations for GBTCLK1_M2C_C_P/GBTCLK1_M2C_C_N ## ## Version 9 : (SE, 04.05.2011) ## - Removed VCCAUX config setting (unsupported for Virtex 5 devices) ## - Added Pin Location for PL_LED2_1V8 ## Version 10 : (SE, 01.07.2011) ## - Corrected SPI Interface Pinning Version 11: (SE, 29.11.2011) ## - Revised sections Miscellaneous and Configuration / User Storage ## - Added I/O Standard Comment in Section FMC HB ## - Fixed LDQS/UDQS index for DDR2 Memory 0 and 1 ## - Added HA_CLK location and I/O standard constraint in Section HA ## : VADJ and VCC_B vary from 0V to 3.3V. Hence the pins with VCCO = VADJ must be ## Comments set to an appripiate IO standard that reflects the real VADJ value. These ## pins get, as a placeholder, the LVCMOS12 standard, as this will most ## likely throw a warning as a reminder. ## The constraints for the GTP-transceiver for reference only. Replace ## them with the constraints valid for your implementaion (i.e. the .ucf from ## the core generator output). ``` ``` ## Section: Miscellaneous # The configuration interface is linked to CPLD device. Signals that are dedicated (no dual purpose) # are prohibited for any aplication usage = "AE13"; config prohibit # Configuration FPGA_RS1 config prohibit = "AE12"; # Configuration FPGA_RS0 config prohibit = "AD19"; # Configuration CFG_D0_FS0 config prohibit = "AE19"; # Configuration CFG_D1_FS1 = "AE17"; config prohibit # Configuration CFG_D2_FS2 config prohibit # Configuration CFG_D3 = "AF16"; = "AD20"; config prohibit # Configuration CFG_D4 config prohibit = "AE21"; # Configuration CFG_D5 config prohibit = "AE16"; # Configuration CFG D6 config prohibit = "AF15"; # Configuration CFG_D7 # For Configuration FCS_N and MOSI refer section Configuration / User Storage ## Section: Configuration / User Storage # SPI access is performed via the FPGA standard interface (refer XAPP1020). User configurable I/O # pins are prohibited for usage due to safety reasons # Pin Location constraints config prohibit = "AE14"; # Configuration FCS N config prohibit = "AF14"; # Configuration MOSI ## Section: Gigabit Ethernet (AMC Lanes 0/1) # I/O Standard net "REF_CLK_01_C_?" iostandard = "LVDS_25"; # Pin Location constraints net "REF_CLK_01_C_P" loc = "E4"; # BANK 120, On-board generated by SI5338 net "REF_CLK_01_C_N" loc = "D4"; # BANK 120, On-board generated by SI5338 # BANK 120, Port 0 net "V Tx P[0]" loc = "B4"; loc = "B3"; net "V_Tx_N[0]" # BANK 120, Port 0 loc = "A3"; net "V_Rx_P[0]" # BANK 120, Port 0 loc = "A2"; net "V_Rx_N[0]" # BANK 120, Port 0 net "V_Tx_P[1]" loc = "E2"; # BANK 120, Port 1 net "V_Tx_N[1]" loc = "D2"; # BANK 120, Port 1 net "V_Rx_P[1]" loc = "D1"; # BANK 120, Port 1 net "V_Rx_N[1]" loc = "C1"; # BANK 120, Port 1 ## Section: Mass Storage (AMC Lanes 2/3) # I/O Standard net "REF_CLK_23_C_?" iostandard = "LVDS_25"; # Pin Location constraints net "REF_CLK_23_C_P" loc = "D8"; # BANK 124, On-board generated by SI5338 net "REF_CLK_23_C_N" loc = "C8"; # BANK 124, On-board generated by SI5338 net "V_Tx_P[2]" loc = "B10"; # BANK 124, Port 0 net "V_Tx_N[2]" loc = "B9"; # BANK 124, Port 0 ``` ``` loc = "A9"; net "V_Rx_P[2]" # BANK 124, Port 0 net "V Rx N[2]" loc = "A8"; # BANK 124, Port 0 net "V_Tx_P[3]" loc = "B5"; # BANK 124, Port 1 # BANK 124, Port 1 net "V_Tx_N[3]" loc = "B6"; net "V_Rx_P[3]" loc = "A6"; # BANK 124, Port 1 net "V_Rx_N[3]" loc = "A7"; # BANK 124, Port 1 ## Section: Fat Pipe Region (AMC Lanes 4-11) # I/O Standard net "V_REFCLK_47_?" iostandard = "LVDS_25"; net "V_REFCLK_811_?" iostandard = "LVDS 25"; # Pin Location constraints loc = "H4"; net "V_REFCLK_47_P" # BANK 116, aligned to the first 8-lanes [0-7] loc = "H3"; net "V_REFCLK_47_N" # BANK 116, on-board generated by SI5338 net "V_REFCLK_811_P" loc = "Y4"; # BANK 114, aligned to the first 8-lanes [8-15] net "V REFCLK 811 N" loc = "Y3"; # BANK 114, on-board generated by SI5338 loc = "F2"; net "V_Tx_P[4]" # BANK 116, Lane 0 # BANK 116, Lane 0 # BANK 116, Lane 0 loc = "G2"; net "V_Tx_N[4]" net "V_Rx_P[4]" loc = "G1"; net "V_Rx_N[4]" loc = "H1"; # BANK 116, Lane 0 loc = "L2"; net "V_Tx_P[5]" # BANK 116, Lane 1 net "V_Tx_N[5]" loc = "K2"; # BANK 116, Lane 1 net "V_Rx_P[5]" loc = "K1"; # BANK 116, Lane 1 loc = "J1"; net "V_Rx_N[5]" # BANK 116, Lane 1 # BANK 112, Lane 2 net "V_Tx_P[6]" loc = "M2"; # BANK 112, Lane 2 # BANK 112, Lane 2 net "V_Tx_N[6]" loc = "N2"; loc = "N1"; net "V_Rx_P[6]" net "V_Rx_N[6]" loc = "P1"; # BANK 112, Lane 2 net "V_Tx_P[7]" loc = "U2"; # BANK 112, Lane 3 net "V_Tx_N[7]" loc = "T2"; # BANK 112, Lane 3 loc = "T1"; net "V_Rx_P[7]" # BANK 112, Lane 3 net "V_Rx_N[7]" loc = "R1"; # BANK 112, Lane 3 net "V Tx P[8]" loc = "V2"; # BANK 114, Lane 4 loc = "W2"; net "V_Tx_N[8]" # BANK 114, Lane 4 # BANK 114, Lane 4 # BANK 114, Lane 4 loc = "W1"; net "V_Rx_P[8]" net "V_Rx_N[8]" loc = "Y1"; # BANK 114, Lane 5 net "V_Tx_P[9]" loc = "AC2"; net "V_Tx_N[9]" loc = "AB2"; # BANK 114, Lane 5 # BANK 114, Lane 5 net "V_Rx_P[9]" loc = "AB1"; loc = "AA1"; net "V_Rx_N[9]" # BANK 114, Lane 5 net "V_Tx_P[10]" loc = "AD2"; # BANK 118, Lane 6 net "V_Tx_N[10]" loc = "AE2"; # BANK 118, Lane 6 # BANK 118, Lane 6 net "V_Rx_P[10]" loc = "AE1"; net "V_Rx_N[10]" loc = "AF1"; # BANK 118, Lane 6 net "V_Tx_P[11]" loc = "AJ2"; # BANK 118, Lane 7 # BANK 118, Lane 7 # BANK 118, Lane 7 net "V_Tx_N[11]" loc = "AH2"; loc = "AH1"; net "V_Rx_P[11]" net "V_Rx_N[11]" loc = "AG1"; # BANK 118, Lane 7 ## Section: Extended Options Region (AMC Lanes 12-15) ``` ``` # Define I/O Standards net "Tx_C_?[1?]" iostandard = "LVDS_25"; # 2.5V net "Rx_C_?[1?]" iostandard = "LVDS 18"; # 1.8V # Location Constraints net "Tx_C_P[12]" loc = "AF20"; # BANK 2 # BANK 2 # BANK 18 # BANK 18 net "Tx_C_N[12]" loc = "AF21"; net "Rx_C_P[12]" loc = "V10"; net "Rx_C_N[12]" loc = "V9"; loc = "AF23"; loc = "AG23"; net "Tx_C_P[13]" # BANK 2 # BANK 2 # BANK 18 net "Tx_C_N[13]" loc = "V8"; net "Rx_C_P[13]" loc = "U8"; net "Rx_C_N[13]" # BANK 18 net "Tx_C_P[14]" loc = "AF13"; # BANK 2 net "Tx_C_N[14]" loc = "AG12"; # BANK 2 # BANK 18 net "Rx_C_P[14]" loc = "W10"; loc = "W9"; net "Rx_C_N[14]" # BANK 18 # BANK 2 net "Tx_C_P[15]" loc = "AE22"; # BANK 2 # BANK 18 net "Tx_C_N[15]" loc = "AE23"; net "Rx_C_P[15]" loc = "Y11"; net "Rx_C_N[15]" loc = "W11"; # BANK 18 # AMC Port 16 is used for Telecom Clocks # BANK 4 net "Tx_C_P[17]" loc = "AH15"; loc = "AG15"; # BANK 4 # BANK 18 net "Tx_C_N[17]" net "Rx_C_P[17]" loc = "W7"; loc = "V7"; net "Rx_C_N[17]" # BANK 18 ## Section: FMC (Miscellaneous) # Define I/O Standards net "FMC_PRESNT_1V8_N" iostandard = "LVCMOS18"; # 1.8V net "CLK_DIR_1V8" iostandard = "LVCMOS18"; # 1.8V net "SDA_FMC_1V8" iostandard = "LVCMOS18"; # 1.8V net "SCL_FMC_1V8" iostandard = "LVCMOS18"; # 1.8V iostandard = "LVDS_25"; # 2.5V net "GBTCLK0_M2C_C_?" net "CLK?_BIDIR_?" iostandard = "LVDS 25"; # 2.5V net "CLK?_M2C_?" iostandard = "LVDS_25"; # 2.5V # Location Constraints net "FMC_PRESNT_1V8_N" loc = "AA10"; # BANK 21 net "CLK_DIR_1V8" loc = "AA25"; # BANK 21 net "SDA_FMC_1V8" loc = "AA9"; # BANK 22 net "SCL_FMC_1V8" loc = "AA8"; # BANK 22 net "GBTCLK0_M2C_C_P" loc = "AL5"; # BANK 122 loc = "AL4"; net "GBTCLK0_M2C_C_N" # BANK 122 loc = "AL7"; net "GBTCLK1_M2C_C_P" # BANK 122 loc = "AM7"; net "GBTCLK1_M2C_C_N" # BANK 122 loc = "AK2"; # BANK 122, Lane 0 net "DP_C2M_P[0]" loc = "AL2"; # BANK 122, Lane 0 # BANK 122, Lane 0 net "DP_C2M_N[0]" net "DP_M2C_P[0]" loc = "AL1"; # BANK 122, Lane 0 net "DP_M2C_N[0]" loc = "AM1"; net "DP_C2M_P[1]" loc = "AN4"; # BANK 122, Lane 1 # BANK 122, __ # BANK 122, Lane 1 loc = "AN3"; net "DP_C2M_N[1]" ``` ``` loc = "AP3"; net "DP_M2C_P[1]" # BANK 122, Lane 1 net "DP M2C N[1]" loc = "AP2"; # BANK 122, Lane 1 net "DP_C2M_P[2]" loc = "AN5"; # BANK 126, Lane 2 # BANK 126, Lane 2 # BANK 126, Lane 2 net "DP_C2M_N[2]" loc = "AN6"; loc = "AP6"; net "DP_M2C_P[2]" net "DP_M2C_N[2]" loc = "AP7"; # BANK 126, Lane 2 net "DP_C2M_P[3]" loc = "AN10"; # BANK 126, Lane 3 loc = "AN9"; net "DP C2M N[3]" # BANK 126, Lane 3 loc = "AP9"; net "DP_M2C_P[3]" # BANK 126, Lane 3 net "DP_M2C_N[3]" loc = "AP8"; # BANK 126, Lane 3 net "CLK2_BIDIR_P" loc = "AG18"; # BANK 4 loc = "AF19"; # BANK 4 net "CLK2_BIDIR_N" loc = "AH17"; net "CLK3_BIDIR_P" # BANK 4 net "CLK3_BIDIR_N" loc = "AG16"; # BANK 4 net "CLK0_M2C_P" loc = "AF18"; # BANK 4 net "CLK0_M2C_N" loc = "AE18"; # BANK 4 net "CLK1_M2C_P" loc = "AH18"; # BANK 4 net "CLK1_M2C_N" loc = "AG17"; # BANK 4 ## Section: FMC LA # Define IO Standards net "LA ?[*]" iostandard = "LVDS_12"; # VADJ # Location Constraints net "LA_P[0]" loc = "AH34"; # BANK 13 loc = "AF34"; # BANK 13 net "LA_P[1]" # BANK 13 # BANK 13 net "LA_P[2]" loc = "AN32"; net "LA_P[3]" loc = "AN34"; # BANK 13 net "LA_P[4]" loc = "AM33"; # BANK 13 # BANK 13 loc = "AK34"; net "LA_P[5]" net "LA_P[6]" loc = "AL34"; # BANK 13 net "LA_P[7]" loc = "AF33"; loc = "AJ32"; net "LA_P[8]" # BANK 13 # BANK 13 # BANK 13 net "LA_P[9]" loc = "AC34"; net "LA_P[10]" loc = "AD32"; net "LA_P[11]" loc = "AC33"; # BANK 13 # BANK 13 # BANK 13 loc = "AC32"; net "LA P[12]" net "LA_P[13]" loc = "AA34"; net "LA P[14]" loc = "Y33"; # BANK 13 loc = "W34"; net "LA_P[15]" # BANK 13 # BANK 13 # BANK 11 loc = "V32"; net "LA_P[16]" loc = "K33"; net "LA_P[17]" net "LA_P[18]" loc = "L34"; # BANK 11 # BANK 11 # BANK 11 # BANK 11 loc = "U33"; net "LA_P[19]" net "LA_P[20]" loc = "U32"; net "LA_P[21]" loc = "P32"; loc = "T33"; net "LA_P[22]" # BANK 11 # BANK 11 # BANK 11 net "LA_P[23]" loc = "R33"; net "LA_P[24]" loc = "G33"; loc = "J32"; net "LA_P[25]" # BANK 11 # BANK 11 net "LA P[26]" loc = "H34"; # BANK 11 net "LA_P[27]" loc = "L33"; net "LA P[28]" loc = "F33"; # BANK 11 loc = "E32"; net "LA_P[29]" # BANK 11 # BANK 11 # BANK 11 net "LA_P[30]" loc = "C34"; net "LA_P[31]" loc = "C32"; net "LA_P[32]" loc = "B32"; # BANK 11 net "LA_P[33]" loc = "B33"; # BANK 11 loc = "AJ34"; # BANK 13 net "LA N[0]" net "LA_N[1]" loc = "AE34"; # BANK 13 net "LA_N[2]" loc = "AP32"; # BANK 13 loc = "AN33"; net "LA_N[3]" # BANK 13 ``` ``` loc = "AM32"; net "LA_N[4]" # BANK 13 # BANK 13 # BANK 13 # BANK 13 net "LA N[5]" loc = "AK33"; net "LA N[6]" loc = "AL33"; net "LA_N[7]" loc = "AE33"; # BANK 13 # BANK 13 net "LA_N[8]" loc = "AK32"; loc = "AD34"; net "LA_N[9]" net "LA_N[10]" # BANK 13 loc = "AE32"; # BANK 13 # BANK 13 # BANK 13 net "LA_N[11]" loc = "AB33"; net "LA_N[12]" loc = "AB32"; net "LA N[13]" loc = "Y34"; net "LA_N[14]" loc = "AA33"; # BANK 13 # BANK 13 # BANK 13 net "LA N[15]" loc = "V34"; loc = "V33"; net "LA_N[16]" # BANK 11 net "LA_N[17]" loc = "K32"; # BANK 11 # BANK 11 # BANK 11 loc = "K34"; net "LA_N[18]" net "LA_N[19]" loc = "T34"; net "LA_N[20]" loc = "U31"; net "LA_N[21]" loc = "N32"; # BANK 11 # BANK 11 # BANK 11 net "LA N[22]" loc = "R34"; loc = "R32"; net "LA_N[23]" net "LA_N[24]" loc = "F34"; # BANK 11 loc = "H33"; # BANK 11 # BANK 11 # BANK 11 net "LA_N[25]" loc = "J34"; net "LA_N[26]" net "LA_N[27]" loc = "M32"; net "LA_N[28]" loc = "E34"; # BANK 11 # BANK 11 loc = "E33"; net "LA_N[29]" loc = "D34"; net "LA_N[30]" # BANK 11 net "LA_N[31]" loc = "D32"; # BANK 11 loc = "A33"; net "LA_N[32]" # BANK 11 net "LA_N[33]" loc = "C33"; # BANK 11 ## Section: FMC HA # Define IO Standards iostandard = "LVCMOS12"; # VADJ net "HA_CLK" iostandard = "LVDS 12"; # VADJ net "HA ?[*]" # Location Constraints net "HA_CLK" loc = "H17"; # BANK 3 net "HA_P[0]" loc = "M31"; # BANK 15 # BANK 15 # BANK 15 loc = "P31"; net "HA P[1]" loc = "U27"; net "HA_P[2]" loc = "R26"; # BANK 15 net "HA P[3]" loc = "U26"; net "HA_P[4]" # BANK 15 # BANK 15 # BANK 15 net "HA_P[5]" loc = "U25"; net "HA_P[6]" loc = "T31"; net "HA_P[7]" loc = "T28"; # BANK 15 # BANK 15 # BANK 15 # BANK 15 loc = "L30"; net "HA_P[8]" net "HA_P[9]" loc = "N29"; net "HA_P[10]" loc = "J30"; loc = "K31"; net "HA_P[11]" # BANK 15 # BANK 15 # BANK 15 net "HA_P[12]" loc = "H30"; net "HA_P[13]" loc = "H29"; net "HA_P[14]" loc = "F31"; # BANK 15 # BANK 15 loc = "G30"; net "HA_P[15]" net "HA_P[16]" loc = "E29"; # BANK 15 net "HA P[17]" loc = "K17"; # BANK 3 loc = "L19"; net "HA_P[18]" # BANK 3 # BANK 3 # BANK 3 net "HA_P[19]" loc = "H14"; net "HA_P[20]" loc = "J14"; net "HA_P[21]" loc = "K18"; # BANK 3 loc = "J20"; # BANK 3 net "HA_P[22]" net "HA_P[23]" loc = "H19"; # BANK 3 net "HA_N[0]" loc = "N30"; # BANK 15 net "HA_N[1] loc = "P30"; # BANK 15 loc = "U28"; net "HA_N[2]" # BANK 15 ``` ``` # BANK 15 loc = "R27"; net "HA_N[3]" # BANK 15 # BANK 15 # BANK 15 net "HA_N[4]" loc = "T26"; loc = "T25"; net "HA N[5]" net "HA_N[6]" loc = "R31"; # BANK 15 # BANK 15 # BANK 15 net "HA_N[7]" loc = "T29"; loc = "M30"; net "HA_N[8]" loc = "P29"; net "HA_N[9]" # BANK 15 # BANK 15 # BANK 15 loc = "J31"; net "HA_N[10]" net "HA_N[11]" loc = "L31"; net "HA N[12]" loc = "G31"; # BANK 15 net "HA_N[13]" loc = "J29"; # BANK 15 # BANK 15 net "HA_N[14]" loc = "E31"; loc = "F30"; net "HA_N[15]" # BANK 15 loc = "F29"; net "HA_N[16]" loc = "L18"; # BANK 3 # BANK 3 # BANK 3 net "HA_N[17]" net "HA_N[18]" loc = "K19"; net "HA_N[19]" loc = "H15"; net "HA_N[20]" loc = "H13"; # BANK 3 # BANK 3 # BANK 3 loc = "J19"; net "HA N[21]" net "HA_N[22]" loc = "J21"; # BANK 3 net "HA_N[23]" loc = "H20"; # Timing Constraints tnm_net = "HA_CLK"; net "HA_CLK" timespec "TS_HA_CLK" = period "HA_CLK" 50 MHz high 50 %; ## Section: FMC HB # Define IO Standards iostandard = "LVDS_12"; # VCC_B (FMC provided Power Supply) net "HB_?[*]" # Location Constraints # BANK 19 # BANK 19 net. "HB P[0]" loc = "G27"; net "HB P[1]" loc = "P26"; net "HB P[2]" loc = "N24"; # BANK 19 # BANK 19 # BANK 19 # BANK 19 loc = "R24"; net. "HB P[3]" net "HB_P[4]" loc = "M25"; net "HB_P[5]" loc = "P25"; # BANK 19 # BANK 19 # BANK 19 # BANK 19 loc = "H28"; net "HB_P[6]" net "HB_P[7]" loc = "M28"; net "HB_P[8]" loc = "K24"; net "HB_P[9]" loc = "L25"; # BANK 19 # BANK 19 loc = "E28"; net "HB_P[10]" loc = "K28"; net "HB_P[11]" net "HB P[12]" loc = "H25"; # BANK 19 loc = "J24"; # BANK 19 net "HB_P[13]" # BANK 19 # BANK 19 # BANK 19 net "HB_P[14]" loc = "E26"; net "HB_P[15]" loc = "G25"; net "HB_P[16]" loc = "F25"; # BANK 1 # BANK 1 loc = "G23"; net "HB_P[17]" net "HB_P[18]" loc = "K23"; # BANK 1 net "HB_P[19]" loc = "L15"; loc = "J22"; net "HB_P[20]" # BANK 1 net "HB_P[21]" loc = "L21"; # BANK 1 net "HB_N[0]" loc = "H27"; # BANK 19 # BANK 19 net "HB_N[1]" loc = "P27"; # BANK 19 # BANK 19 net "HB_N[2]" loc = "P24"; net "HB N[3]" loc = "T24"; loc = "M26"; net "HB_N[4]" # BANK 19 # BANK 19 # BANK 19 net "HB_N[5]" loc = "N25"; net "HB_N[6]" loc = "G28"; net "HB_N[7]" # BANK 19 loc = "N28"; loc = "L24"; # BANK 19 # BANK 19 net "HB_N[8]" loc = "L26"; net "HB N[9]" net "HB N[10]" loc = "F28"; # BANK 19 loc = "L28"; net "HB_N[11]" # BANK 19 # BANK 19 # BANK 19 net "HB_N[12]" loc = "H24"; net "HB_N[13]" loc = "J25"; ``` ``` net "HB_N[14]" loc = "E27"; # BANK 19 # BANK 19 # BANK 19 net "HB N[15]" loc = "G26"; net "HB N[16]" loc = "F26"; loc = "H23"; # BANK 1 net "HB_N[17]" # BANK 1 # BANK 1 net "HB_N[18]" loc = "K22"; net "HB_N[19]" loc = "L16"; loc = "K21"; net "HB_N[20]" # BANK 1 loc = "L20"; # BANK 1 net "HB_N[21]" ## Section: Clocking \ensuremath{\#\#} Note: Telecom Clocks are controlled by the on-board CPLD device # Define IO Standards net "TCLK?_?x" iostandard = "LVCMOS25"; # 2.5V net "UCLK" iostandard = "LVCMOS25"; # 2.5V # Location Constraints net "TCLKA Rx" loc = "AH20"; # BANK 4 net "TCLKA_Tx" loc = "AH19"; # BANK 4 net "TCLKB_Rx" loc = "AH14"; # BANK 4 net "TCLKB_Tx" loc = "AH13"; # BANK 4 net "TCLKC_Rx" loc = "AG22"; # BANK 4 loc = "AH22"; net "TCLKC_Tx" # BANK 4 loc = "AH12"; # BANK 4 net "TCLKD Rx" loc = "AG13"; net "TCLKD_Tx" # BANK 4 net "IICLK" loc = "AG21"; # BANK 4, General purpose 50 MHz clock (single ended) # Timing Specification tnm_net = "UCLK"; net "UCLK" timespec "TS_UCLK" = period "UCLK" 50 MHz high 50 %; ## Section: QDR Memory 0 ## ## Do not modify the I/O standard of the QDR memory due to board signal integrity # Define IO Standards net "QDR0_D*" iostandard = HSTL_I_18; net "QDR0_Q*" iostandard = HSTL_I_DCI_18; iostandard = HSTL_I_18; net "QDR0_A*" net "QDR0_W_n" iostandard = HSTL_I_18; net "QDR0_R_n" iostandard = HSTL_I_18; net "QDR0_BW_n*" iostandard = HSTL_I_18; net "QDR0_CQ*" iostandard = HSTL_I_DCI_18; net "ODR0 K*" iostandard = HSTL_I_18; # BANK 20 # BANK 20 net "QDR0_D[0]" loc = "M10"; net "QDR0_D[1]" loc = "N10"; net "QDR0_D[2]" # BANK 20 loc = "L9"; # BANK 20 loc = "L10"; net "QDR0_D[3]" net "QDR0_D[4]" loc = "L11"; # BANK 20 net "ODRO D[5]" loc = "J9"; # BANK 20 net "QDR0_D[6]" loc = "H9"; # BANK 20 # BANK 20 # BANK 20 net "QDR0_D[7]" loc = "H8"; loc = "G8"; net "QDR0_D[8]" ``` ``` loc = "B12"; net "ODR0 D[9]" # BANK 20 net "QDR0_D[10]" loc = "D12"; # BANK 20 # BANK 20 net "ODR0 D[11]" loc = "D11"; net "QDR0_D[12]" loc = "E11"; # BANK 20 # BANK 20 # BANK 20 net "QDR0_D[13]" loc = "D10"; loc = "F11"; net "QDR0_D[14]" loc = "F10"; net "QDR0_D[15]" # BANK 20 loc = "E9"; # BANK 20 net "QDR0_D[16]" net "QDR0_D[17]" loc = "E8"; # BANK 20 net "QDR0_Q[0]" loc = "U7"; # BANK 12 # BANK 12 loc = "T6"; net "QDR0_Q[1]" loc = "T8"; net "QDR0_Q[2]" # BANK 12 loc = "T9"; net "QDR0_Q[3]" # BANK 12 # BANK 12 # BANK 12 # BANK 12 loc = "U10"; net "QDR0_Q[4]" net "QDR0_Q[5]" loc = "T10"; net "QDR0_Q[6]" loc = "T11"; net "QDR0_Q[7]" loc = "R8"; # BANK 12 # BANK 12 # BANK 12 net "QDR0_Q[8]" loc = "R11"; loc = "E7"; net "QDR0_Q[9]" loc = "E6"; net "QDR0_Q[10]" # BANK 12 # BANK 12 # BANK 12 # BANK 12 loc = "G7"; net "QDR0_Q[11]" net "QDR0_Q[12]" loc = "G6"; loc = "F6"; net "QDR0_Q[13]" net "QDR0_Q[14]" loc = "F5"; # BANK 12 # BANK 12 loc = "G5"; net "QDR0_Q[15]" loc = "H5"; net "QDR0_Q[16]" # BANK 12 net "QDR0_Q[17]" loc = "J5"; # BANK 12 # BANK 20 net "QDR0_A[0]" loc = "C12"; " # BANK 20 loc = "H10"; net "QDR0_A[1]" net "QDR0_A[2]" loc = "E12"; # BANK 20 # BANK 20 # BANK 20 loc = "G11"; net "QDR0_A[3]" net "QDR0_A[4]" loc = "K8"; net "QDR0_A[5]" loc = "L6"; # BANK 20 # BANK 20 loc = "M7"; net "QDR0_A[6]" # BANK 20 # BANK 20 net "QDR0_A[7]" loc = "N9"; net "QDR0_A[8]" loc = "K7"; net "ODRO A[9]" loc = "M6"; # BANK 12 # BANK 12 # BANK 12 net "QDR0_A[10]" loc = "N8"; net "QDR0_A[11]" loc = "L8"; net "QDR0_A[12]" loc = "M8"; # BANK 12 # BANK 12 # BANK 12 # BANK 12 loc = "K6"; net "QDR0_A[13]" net "QDR0_A[14]" loc = "N7"; net "QDR0_A[15]" loc = "P6"; loc = "P7"; net "QDR0_A[16]" # BANK 12 # BANK 20 # BANK 20 net "QDR0_A[17]" loc = "J10"; net "QDR0_A[18]" loc = "B13"; net "ODRO A[19]" loc = "K11"; # BANK 20 net "QDR0_A[20]" loc = "A13"; # BANK 20 net "QDR0_W_n" net "ODRO R n" loc = "J11"; # BANK 12 net "QDR0_BW_n[0]" loc = "G12"; # BANK 20 net "QDR0_BW_n[1]" loc = "E13"; # BANK 20 net "QDR0_CQ_P[0]" loc = "R7"; # BANK 12 net "QDR0_CQ_N[0]" loc = "H7"; # BANK 12 net "QDR0_K_P[0]" loc = "F13"; # BANK 12 net "QDR0_K_N[0]" loc = "G13"; # BANK 12 net "QDR0_DOFF_n" loc = "F9"; # BANK 20 ## Section: ODR1 ## ## Do not modify the I/O standard of the ODR memory due to board signal integrity # Define IO Standards ``` ``` net "QDR1_D*" iostandard = HSTL_I_18; net "QDR1_Q*" iostandard = HSTL_I_DCI_18; net "QDR1_A*" iostandard = HSTL_I_18; net "QDR1_W_n" iostandard = HSTL_I_18; net "QDR1_R_n" iostandard = HSTL_I_18; net "QDR1_BW_n*" iostandard = HSTL_I_18; net "QDR1_CQ*" iostandard = HSTL_I_DCI_18; net "QDR1_K*" iostandard = HSTL_I_18; loc = "C18"; net "QDR1_D[0]" # BANK 23 loc = "C19"; # BANK 23 net "QDR1_D[1]" net "QDR1_D[2]" loc = "C20"; # BANK 23 # BANK 23 net "QDR1_D[3]" loc = "C22"; net "QDR1_D[4]" loc = "C23"; # BANK 23 # BANK 23 # BANK 23 # BANK 23 net "QDR1_D[5]" loc = "C24"; net "QDR1_D[6]" loc = "C25"; net "QDR1_D[7]" loc = "A25"; loc = "B25"; # BANK 23 # BANK 23 # BANK 23 net "QDR1_D[8]" net "QDR1_D[9]" loc = "A31"; loc = "A30"; net "QDR1_D[10]" loc = "A29"; net "QDR1_D[11]" # BANK 23 loc = "B28"; # BANK 23 # BANK 23 net "QDR1_D[12]" net "QDR1_D[13]" loc = "A28"; # BANK 23 net "QDR1_D[14]" loc = "A23"; loc = "A21"; net "QDR1_D[15]" # BANK 23 loc = "B20"; # BANK 23 # BANK 23 net "QDR1_D[16]" net "QDR1_D[17]" loc = "B18"; # BANK 5 net "QDR1_Q[0]" loc = "F14"; loc = "E14"; net "QDR1_Q[1]" # BANK 5 net "QDR1_Q[2]" loc = "F15"; # BANK 5 loc = "F16"; # BANK 5 net "QDR1_Q[3]" # BANK 5 # BANK 5 net "QDR1_Q[4]" loc = "E16"; loc = "G17"; net "QDR1_Q[5]" net "QDR1_Q[6]" loc = "F18"; # BANK 5 net "QDR1_Q[7]" loc = "G20"; # BANK 5 # BANK 5 net "QDR1_Q[8]" loc = "F23"; # BANK 5 net "QDR1_Q[9]" loc = "B17"; loc = "C17"; net "QDR1_Q[10]" # BANK 5 # BANK 5 # BANK 5 net "QDR1_Q[11]" loc = "B16"; net "QDR1_Q[12]" loc = "A16"; loc = "B15"; net "QDR1_Q[13]" # BANK 5 net "QDR1_Q[14]" loc = "A15"; # BANK 5 # BANK 5 net "QDR1_Q[15]" loc = "A14"; .. # BANK 5 net "QDR1_Q[16]" loc = "C15"; net "QDR1_Q[17]" loc = "C14"; # BANK 5 loc = "C30"; net "QDR1_A[0]" # BANK 23 net "QDR1_A[1]" loc = "B27"; # BANK 23 # BANK 23 # BANK 23 loc = "C29"; net "QDR1_A[2]" net "QDR1_A[3]" loc = "C27"; # BANK 5 net "QDR1_A[4]" loc = "B23"; loc = "D22"; net "QDR1_A[5]" # BANK 5 # BANK 5 # BANK 5 net "QDR1_A[6]" loc = "D21"; net "QDR1_A[7]" loc = "A20"; loc = "B22"; net "QDR1_A[8]" # BANK 5 # BANK 23 loc = "D20"; net "QDR1_A[9]" # BANK 23 net "QDR1_A[10]" loc = "E23"; # BANK 5 net "QDR1_A[11]" loc = "A18"; net "QDR1_A[12]" loc = "A19"; # BANK 5 # BANK 5 # BANK 5 net "QDR1_A[13]" loc = "B21"; loc = "E19"; net "QDR1_A[14]" net "QDR1_A[15]" loc = "E22"; # BANK 5 loc = "E21"; net "QDR1_A[16]" # BANK 5 loc = "A26"; # BANK 23 net "QDR1_A[17]" net "QDR1_A[18]" loc = "B30"; # BANK 23 loc = "B26"; net "QDR1_A[19]" # BANK 23 net "QDR1_A[20]" loc = "B31"; # BANK 5 ``` ``` loc = "D31"; net "ODR1 W n" # BANK 23 net "ODR1 R n" loc = "D26"; # BANK 23 net "QDR1_BW_n[0]" loc = "D29"; # BANK 23 net "QDR1_BW_n[1]" loc = "D30"; # BANK 23 net "QDR1_CQ_P[0]" loc = "F21"; # BANK 5 net "QDR1_CQ_N[0]" loc = "E17"; # BANK 5 loc = "C28"; # BANK 23 net "QDR1_K_P[0]" net "QDR1_K_N[0]" loc = "D27"; # BANK 23 net "QDR1_DOFF_n" loc = "D16"; # BANK 5 ## Section: DDR2 Memory 0 ## Do not modify the I/O standard of the DDR2 memory due to board signal integrity # Define I/O Standards net "DDR0_DQ[*]" iostandard = SSTL18_II_DCI; net "DDR0_A[*]" iostandard = SSTL18_II_DCI; net "DDR0_BA[*]" iostandard = SSTL18_II_DCI; net "DDR0_RAS_n" iostandard = SSTL18_II_DCI; net "DDR0_CAS_n" iostandard = SSTL18_II_DCI; net "DDR0_WE_n" iostandard = SSTL18_II_DCI; net "DDR0_CS_n[*]" iostandard = SSTL18_II_DCI; net "DDR0_ODT[*]" iostandard = SSTL18_II_DCI; net "DDR0_CKE[*]" iostandard = SSTL18_II; net "DDR0_?DM[*]" iostandard = SSTL18_II_DCI; net "DDR0_?DQS_P[*]" iostandard = DIFF_SSTL18_II_DCI; net "DDR0_?DQS_N[*]" iostandard = DIFF_SSTL18_II_DCI; net "DDR0_CK_P[*]" iostandard = DIFF_SSTL18_II_DCI; net "DDR0_CK_N[*]" iostandard = DIFF_SSTL18_II_DCI; # Location Constraints net "DDR0_DQ[0]" loc = "AJ7"; # BANK 18 # BANK 18 # BANK 18 net "DDR0_DQ[1]" loc = "AC4"; net "DDR0_DQ[2]" loc = "AJ6"; net "DDR0 DO[3]" loc = "AD4"; # BANK 18 loc = "AA5"; net "DDR0_DQ[4]" # BANK 18 # BANK 18 # BANK 18 net "DDR0_DQ[5]" loc = "AK6"; loc = "AB5"; net "DDR0_DQ[6]" net "DDR0 DO[7]" loc = "AK7"; # BANK 18 # BANK 18 loc = "AD7"; net "DDR0_DQ[8]" net "DDR0_DQ[9]" loc = "AB7"; # BANK 18 net "DDR0_DQ[10]" loc = "AD6"; # BANK 18 loc = "AC5"; net "DDR0_DQ[11]" # BANK 18 # BANK 18 # BANK 18 net "DDR0_DQ[12]" loc = "AB6"; net "DDR0_DQ[13]" loc = "AE6"; loc = "AA6"; net "DDR0_DQ[14]" # BANK 18 # BANK 18 net "DDR0_DQ[15]" loc = "AH7"; loc = "AK18"; net "DDR0_DQ[16]" # BANK 6 net "DDR0 DO[17]" loc = "AJ16"; # BANK 6 loc = "AM16"; net "DDR0_DQ[18]" # BANK 6 # BANK 6 net "DDR0_DQ[19]" loc = "AJ15"; net "DDR0_DQ[20]" loc = "AJ14"; # BANK 6 net "DDR0_DQ[21]" loc = "AP16"; # BANK 6 loc = "AJ19"; net "DDR0_DQ[22]" # BANK 6 loc = "AL19"; # BANK 6 net "DDR0 D0[23]" net "DDR0 D0[24]" loc = "AK23"; # BANK 6 net "DDR0_DQ[25]" loc = "AH23"; # BANK 6 loc = "AJ22"; loc = "AJ21"; net "DDR0_DQ[26]" # BANK 6 net "DDR0_DQ[27]" # BANK 6 ``` ``` loc = "AJ20"; net "DDR0_DQ[28]" # BANK 6 net "DDR0_DQ[29]" loc = "AK22"; # BANK 6 # BANK 6 net "DDR0 D0[30]" loc = "AH24"; loc = "AK24"; net "DDR0_DQ[31]" # BANK 6 net "DDR0_A[0]" loc = "AJ10"; # BANK 22 net "DDR0_A[1]" loc = "AF11"; # BANK 22 # BANK 22 net "DDR0_A[2]" loc = "AH10"; # BANK 22 # BANK 22 net "DDR0_A[3]" loc = "AC8"; net "DDR0_A[4]" loc = "AK9"; loc = "AG10"; net "DDR0_A[5]" # BANK 22 # BANK 22 net "DDR0_A[6]" loc = "AH9"; loc = "AC9"; net "DDR0_A[7]" # BANK 22 net "DDR0_A[8]" loc = "AJ9"; # BANK 22 loc = "AF9"; # BANK 22 net "DDR0_A[9]" net "DDR0_A[10]" loc = "AE11"; # BANK 22 # BANK 22 net "DDR0_A[11]" loc = "AH8"; net "DDR0_A[12]" loc = "AE8"; # BANK 22 net "DDR0_R[1]" loc = "AC10"; # BANK 22, Address Pin A[13] for future use net "DDR0_R[2]" # BANK 22, Address Pin A[14] for future use loc = "AG8"; loc = "AK8"; net "DDR0_R[3]" # BANK 22, Address Pin A[15] for future use net "DDR0 BA[0]" loc = "AJ11"; # BANK 22 net "DDR0_BA[1]" loc = "AK11"; # BANK 22 net "DDR0_BA[2]" loc = "AG11"; # BANK 22 net "DDR0_RAS_n" loc = "AM13"; # BANK 22 # BANK 22 net "DDR0_CAS_n" loc = "AL10"; loc = "AB8"; # BANK 22 net "DDR0 WE n" loc = "AD9"; # BANK 22 net "DDR0_CS_n[0]" loc = "AL11"; net "DDR0_CS_n[1]" # BANK 6 # BANK 22 net "DDR0_ODT[0]" loc = "AD10"; net "DDR0_ODT[1]" loc = "AN13"; # BANK 6 net "DDR0 CKE[0]" loc = "AD11"; # BANK 22 net "DDR0_LDM[0]" loc = "AD5"; # BANK 18, DM[0] net "DDR0_UDM[0]" loc = "AC7"; # BANK 18, DM[1] # BANK 6, DM[2] # BANK 6, DM[3] loc = "AK19"; net "DDR0_LDM[1]" loc = "AJ24"; net "DDR0_UDM[1]" # BANK 18, DQS_P[0] net "DDR0_LDQS_P[0]" loc = "AG5"; loc = "AF5"; net "DDR0_LDQS_N[0]" # BANK 18, DQS_N[0] # BANK 18, DQS_P[1] net "DDR0 UDOS P[0]" loc = "AE7"; loc = "AF6"; net "DDR0_UDQS_N[0]" # BANK 18, DQS_N[1] # BANK 6, DQS_P[2] # BANK 6, DQS_N[3] # BANK 6, DQS_P[3] loc = "AK16"; net "DDR0_LDQS_P[1]" loc = "AL16"; net "DDR0_LDQS_N[1]" loc = "AL21"; net "DDR0 UDOS P[1]" loc = "AK21"; net "DDR0_UDQS_P[1]" # BANK 6, DQS_N[3] net "DDR0_CK_P[0]" loc = "AM12"; # BANK 22 loc = "AM11"; net "DDR0_CK_N[0]" # BANK 22 net "DDR0_CK_P[1]" loc = "AN14"; # BANK 6 loc = "AP14"; net "DDR0_CK_N[1]" # BANK 6 ## Section: DDR2 Memory 1 ## Do not modify the I/O standard of the DDR2 memory due to board signal integrity # Define I/O Standards net "DDR1_DQ[*]" iostandard = SSTL18_II_DCI; net "DDR1_A[*]" iostandard = SSTL18_II_DCI; net "DDR1_BA[*]" iostandard = SSTL18_II_DCI; net "DDR1_RAS_n" iostandard = SSTL18_II_DCI; ``` ``` net "DDR1_CAS_n" iostandard = SSTL18_II_DCI; net "DDR1_WE_n" iostandard = SSTL18_II_DCI; net "DDR1_CS_n[*]" iostandard = SSTL18_II_DCI; net "DDR1_ODT[*]" iostandard = SSTL18_II_DCI; net "DDR1_CKE[*]" iostandard = SSTL18_II; net "DDR1_?DM[*]" iostandard = SSTL18_II_DCI; net "DDR1_?DQS_P[*]" iostandard = DIFF_SSTL18_II_DCI; net "DDR1_?DQS_N[*]" iostandard = DIFF_SSTL18_II_DCI; net "DDR1_CK_P[*]" iostandard = DIFF_SSTL18_II_DCI; net "DDR1_CK_N[*]" iostandard = DIFF_SSTL18_II_DCI; # Location Constraints loc = "AC29"; net "DDR1 DO[0]" # BANK 17 net "DDR1_DQ[1]" loc = "Y27"; # BANK 17 # BANK 17 # BANK 17 net "DDR1_DQ[2]" loc = "AD29"; loc = "AF29"; net "DDR1_DQ[3]" net "DDR1_DQ[4]" loc = "AE29"; # BANK 17 loc = "AD30"; # BANK 17 net "DDR1_DQ[5]" loc = "Y28"; # BANK 17 # BANK 17 net "DDR1_DQ[6]" loc = "AA29"; net "DDR1 DO[7]" net "DDR1_DQ[8]" loc = "AA30"; # BANK 17 # BANK 17 # BANK 17 # BANK 17 loc = "V28"; net "DDR1_DQ[9]" loc = "W29"; net "DDR1_DQ[10]" net "DDR1_DQ[11]" loc = "V27"; loc = "W27"; # BANK 17 # BANK 17 # BANK 17 net "DDR1_DQ[12]" net "DDR1_DQ[13]" loc = "Y31"; loc = "V29"; net "DDR1_DQ[14]" loc = "W31"; # BANK 17 net "DDR1_DQ[15]" # BANK 25 # BANK 25 loc = "AL29"; net "DDR1_DQ[16]" net "DDR1_DQ[17]" loc = "AN23"; # BANK 25 net "DDR1_DQ[18]" loc = "AN25"; loc = "AP21"; net "DDR1_DQ[19]" # BANK 25 loc = "AL24"; loc = "AM28"; # BANK 25 # BANK 25 net "DDR1_DQ[20]" net "DDR1_DQ[21]" # BANK 25 net "DDR1_DQ[22]" loc = "AL25"; loc = "AN28"; # BANK 25 # BANK 25 net "DDR1_DQ[23]" net "DDR1_DQ[24]" loc = "AP30"; # BANK 25 net "DDR1_DQ[25]" loc = "AM30"; loc = "AN29"; net "DDR1_DQ[26]" # BANK 25 # BANK 25 # BANK 25 net "DDR1_DQ[27]" loc = "AN30"; loc = "AL30"; net "DDR1_DQ[28]" # BANK 25 net "DDR1_DQ[29]" loc = "AP29"; # BANK 25 loc = "AL31"; net "DDR1_DQ[30]" loc = "AP31"; net "DDR1_DQ[31]" # BANK 25 net "DDR1_A[0]" loc = "AK29"; # BANK 21 # BANK 21 # BANK 21 net "DDR1_A[1]" loc = "AH27"; net "DDR1_A[2]" loc = "AJ27"; loc = "AG27"; # BANK 21 net "DDR1_A[3]" # BANK 21 # BANK 21 net "DDR1_A[4]" loc = "AK28"; net "DDR1_A[5]" loc = "AE28"; # BANK 21 net "DDR1_A[6]" loc = "AJ26"; loc = "AF26"; net "DDR1_A[7]" # BANK 21 # BANK 21 # BANK 21 net "DDR1_A[8]" loc = "AK27"; net "DDR1_A[9]" loc = "AG25"; loc = "AF28"; net "DDR1_A[10]" # BANK 21 # BANK 21 net "DDR1_A[11]" loc = "AE27"; net "DDR1_A[12]" loc = "AF25"; # BANK 21 # BANK 21, Address Pin A[13] for future use net "DDR1_R[1]" loc = "AF24"; net "DDR1_R[2]" loc = "AE26"; # BANK 21, Address Pin A[14] for future use loc = "AK26"; net "DDR1_R[3]" # BANK 21, Address Pin A[15] for future use loc = "AH28"; # BANK 21 net "DDR1_BA[0]" loc = "AH29"; # BANK 17 net "DDR1 BA[1]" net "DDR1_BA[2]" loc = "AG28"; # BANK 21 net "DDR1_RAS_n" loc = "AJ30"; # BANK 21 loc = "AJ29"; net "DDR1_CAS_n" # BANK 21 ``` ``` net "DDR1 WE n" loc = "AH30"; # BANK 21 # BANK 21 net "DDR1_CS_n[0]" loc = "AF30"; net "DDR1 CS n[1]" loc = "AM22"; # BANK 25 net "DDR1_ODT[0]" loc = "AF31"; # BANK 21 # BANK 25 net "DDR1_ODT[1]" loc = "AN22"; net "DDR1 CKE[0]" loc = "AE24"; # BANK 21 net "DDR1 LDM[0]" loc = "Y29"; # BANK 17, DM[0] loc = "V30"; # BANK 17, DM[1] net "DDR1_UDM[0]" loc = "AM25"; # BANK 25, DM[2] net "DDR1_LDM[1]" loc = "AM31"; net "DDR1_UDM[1]" # BANK 25, DM[3] loc = "AB30"; # BANK 17, DQS_P[0] net "DDR1_LDQS_P[0]" # BANK 17, DQS_N[0] # BANK 17, DQS_P[1] # BANK 17, DQS_N[1] net "DDR1_LDQS_N[0]" loc = "AC30"; net "DDR1_UDQS_P[0]" loc = "AB31"; loc = "AA31"; net "DDR1_UDQS_N[0]" # BANK 25, DQS_P[2] net "DDR1_LDQS_P[1]" loc = "AP26"; # BANK 25, DQS_N[2] # BANK 25, DQS_P[3] # BANK 25, DQS_N[3] loc = "AP25"; net "DDR1_LDQS_N[1]" net "DDR1_UDQS_P[1]" loc = "AM26"; loc = "AL26"; net "DDR1 UDOS N[1]" net "DDR1_CK_P[0]" loc = "AJ31"; # BANK 21 loc = "AK31"; net "DDR1_CK_N[0]" # BANK 21 " # BANK 25 net "DDR1_CK_P[1]" loc = "AN19"; loc = "AP19"; net "DDR1_CK_N[1]" # BANK 25 ## Section: Debug Connector # Define I/O Standards net "RX_FPGA" iostandard = "LVCMOS18"; # 1.8V net "TX_FPGA" iostandard = "LVCMOS18"; # 1.8V net "USER SWITCH" iostandard = "LVCMOS18"; # 1.8V net "GPIO_FPGA" iostandard = "LVCMOS18"; # 1.8V # Location Constraints net "USER_SWITCH" loc = "Y24"; # BANK 21 net "GPIO FPGA" loc = "AA24"; # BANK 21 net "RX FPGA" loc = "AB25"; # BANK 21 loc = "AB26"; net "TX_FPGA" # BANK 21 ## Section: MMC # Define I/O Standards net "FPGA_RST_n" iostandard = "LVCMOS25"; # 2.5V net "SDA_PL_1V8" iostandard = "LVCMOS18"; # 1.8V net "SCL_PL_1V8" iostandard = "LVCMOS18"; # 1.8V iostandard = "LVCMOS18"; # 1.8V net "PL LED2 1V8" # Location Constraints loc = "AG20"; # BANK 4 net "FPGA_RST_N" net "SDA_PL_1V8" loc = "AB27"; # BANK 21 loc = "AC27"; net "SCL_PL_1V8" # BANK 21 net "PL_LED2_1V8" loc = "AB10"; # BANK 22 ``` | # | Ad | dition | nal | Constraints | |----|------------|--------|-----|-------------| | ne | <b>+</b> د | "FPGA | RST | n" | pullup;