

LOGIC Emulation Source

# User Guide DN9002K10PCIE8T

# DN9002K10PCIE8T User Manual Major Revision 1

Last Update April 13, 2009

7469 Draper Avenue La Jolla, CA92037 USA Phone 858.454.3419 • Fax 858.454.1279 <a href="mailto:support@dinigroup.com">support@dinigroup.com</a> <a href="mailto:www.dinigroup.com">www.dinigroup.com</a>

# **1 Table of Contents**

# **Contents**

| 1 TABLE OF CONTENTS                   | 3       |
|---------------------------------------|---------|
| CHAPTER 1: INTRODUCTION               | 1       |
| 1 MANUAL CONTENTS                     | 1       |
| 1.1 Introduction                      | 1       |
|                                       | 1       |
| 1.3 CONTROLLER SOFTWARE               | 1       |
|                                       | 2       |
|                                       | 2       |
| 1.6 ORDERING INFORMATION              | 2       |
| 2 CONVENTIONS                         | 2       |
| 2.1 Typographical                     | 2       |
| 2.2 MANUAL CONTENT                    | 2       |
|                                       | 2       |
| · · · · · · · · · · · · · · · · · · · | 2       |
|                                       | 3       |
|                                       |         |
| 2.3 TERMINOLOGY                       | 3       |
| 3 RESOURCES                           | 4       |
| 3.1 USER CD                           | 4       |
|                                       | 5       |
|                                       | ATIONS5 |
|                                       | 5       |
|                                       | 6       |
|                                       |         |
|                                       | 6       |
|                                       | 6       |
|                                       | 6       |
|                                       |         |
| 4 EMAIL AND PHONE SUPPORT.            | 7       |
| CHAPTER 2: QUICK START GUIDE          | 9       |
| -                                     |         |
| 1 PROVIDED MATERIALS                  | 9       |

| 1.1        | SYSTEM REQUIREMENTS                                | 9  |
|------------|----------------------------------------------------|----|
| 2 V        | WARNINGS                                           | 10 |
| 2.1        | ESD                                                | 10 |
| 2.2        | OTHER                                              | 10 |
| 2.3        | OTHER WARNINGS                                     | 10 |
| 3 I        | PRE-POWER ON INSTRUCTIONS                          | 11 |
| 3.1        | Install Memory                                     | 11 |
| 3.2        | PREPARE CONFIGURATION FILES                        |    |
| 3.3        | INSERT THE COMPACT FLASH CARD INTO THE DN9002K10PC |    |
|            | SH SLOT                                            |    |
| 3.4<br>3.5 | INSTALL DN9002K10PCIE8T IN COMPUTER CABLES         |    |
| 3.5<br>3.5 |                                                    |    |
| 3.5        |                                                    |    |
| 3.5        |                                                    |    |
| 3.6        | VIEW CONFIGURATION FEEDBACK OVER RS232             |    |
| 3.7        | CHECK LED STATUS LIGHTS                            | 15 |
| 4 I        | RUN USB CONTROLLER                                 | 16 |
| 4.1        | DRIVER INSTALLATION                                | 16 |
| 4.2        | OPERATING THE USB CONTROLLER PROGRAM               | 17 |
| 4.2        | 2.1 Configure an FPGA                              | 18 |
| 4.2        | <b>1</b>                                           |    |
| 4.2        | , , , , , , , , , , , , , , , , , , , ,            |    |
| 4.3        |                                                    |    |
| 5 (        | COMMUNICATING OVER THE SERIAL PORT                 | 21 |
| 6 F        | RUN AETEST_WDM                                     | 21 |
|            | !.1 Use AETest                                     |    |
| 7 8        | SCAN THE JTAG CHAIN                                | 23 |
| 7.1        | Moving On                                          |    |
|            | PTER 3: CONTROLLER SOFTWARE                        |    |
| CIIAI      | TER 3. CONTROLLER SOFT WARE                        | 20 |
| 1 U        | USB CONTROLLER                                     | 26 |
| 1.1        | MAIN WINDOW                                        | 26 |
| 1.1        | $\boldsymbol{\mathcal{J}}$                         |    |
| 1.1        |                                                    |    |
|            | 1.3 Log Window                                     |    |
| 1.1<br>1.2 | 1.4 Board Graphic                                  |    |
| 1.4        | 171L/110 O1 110/10                                 |    |

| 1.2.1  | File Menu                               | 29         |
|--------|-----------------------------------------|------------|
| 1.2.2  | Edit Menu                               | 29         |
| 1.2.3  | FPGA Configuration Menu                 | 29         |
| 1.2.4  | FPGA Reference Design                   | 30         |
| 1.2.5  | Main Bus                                | 30         |
| 1.2.6  | Settings/Info Menu                      | 31         |
| 1.2.7  | Production Tests                        | 32         |
| 1.2.8  | Unsupported Features                    |            |
| 1.3 IN | VI FILE                                 | 32         |
| 2 AET  | EST USB                                 | 33         |
| 2.1 C  | OMPILING AETEST_USB                     | 33         |
| 2.1.1  |                                         |            |
| 3 PCII | E AETEST APPLICATION                    |            |
| 3.1 F  | UNCTIONALITY                            | 33         |
|        | UNNING AETEST                           |            |
|        | OMPILING AETEST (PCIE)                  |            |
| 3.3.1  | Compiling AETest for Windows XP         |            |
| 3.3.2  | Cygwin                                  |            |
|        | LING YOUR OWN SOFTWARE                  |            |
|        |                                         |            |
|        | SB                                      |            |
| 4.2 P  | CIE                                     | 35         |
| 5 UPD  | ATING THE FIRMWARE                      | 35         |
| 5.1 O  | BTAINING THE UPDATES                    | 36         |
| 5.2 U  | PDATING THE SPARTAN (PROM) FIRMWARE     | 36         |
| 5.2.1  | Using JTAG cable (Xinlinx products)     | 36         |
| 5.2.2  | Using USBController                     | <i>38</i>  |
| 5.2.3  | Using AEtest_USB                        | <i>3</i> 8 |
|        | PDATING EEPROM FIRMWARE (NOT RECOMMEND) |            |
| 5.3.1  | Using USBController                     |            |
| 5.3.2  | Using AETest_USB                        | 40         |
|        | PDATING THE MCU (FLASH) FIRMWARE        |            |
| 5.4.1  | Using USBController                     |            |
| 5.4.2  | Using AETest_USB                        |            |
| 5.5 P  | CI Express Endpoint Firmware            |            |
| 5.5.1  | Using JTAG USB cable (Xilinx products)  |            |
| 5.5.2  | Using USBController                     |            |
| 5.5.3  | Using AETest_USB                        | 45         |
| СНАРТЕ | R 4: HARDWARE                           | 47         |
| 1 OFN  | ERAL OVERVIEW                           | 47         |

| 1 | 1.1 Marketing                            | 47  |
|---|------------------------------------------|-----|
|   | 1.1.1 Features                           | 48  |
| 2 | VIRTEX 5                                 | 49  |
| 3 | CONFIGURATION SECTION                    | 49  |
| 3 | 3.1 CONFIGURATION SECTION FEEDBACK       | 50  |
| 3 | 3.2 FPGA CONFIGURATION                   | 51  |
| 3 | 3.3 USB AND PCIE INTERFACES              | 52  |
| 3 | 3.4 COMPACTFLASH INTERFACE               | 52  |
|   | 3.4.1 Main.txt                           | 52  |
|   | 3.4.2 <i>Hardware</i>                    |     |
| 3 | 3.5 CONFIGURATION REGISTERS              |     |
|   | 3.5.1 Undocumented controls              |     |
| 3 | 3.6 Firmware                             | 57  |
| 4 | CLOCK NETWORK                            | 57  |
|   | 4.1.1 GC Pins                            | 57  |
| 4 | 4.2 GLOBAL CLOCKS                        | 57  |
| 4 | 4.3 G0, G1, G2 CLOCKS                    | 58  |
|   | 4.3.1 Clock Synthesizers                 |     |
| 4 | 4.4 Ext Clocks                           |     |
|   | 4.4.1 EXTO                               |     |
|   | 4.4.2 EXT1                               |     |
|   | 4.4.3 Daughtercard zero-delay mode       |     |
|   | 4.4.4 SMA input                          |     |
|   | 4.5 PCIE REFCLOCK                        |     |
|   | 4.6 Non-Global Clocks                    |     |
|   | 4.6.1 Clock TP                           |     |
|   | 4.6.2 Ethernet Clock                     |     |
|   | 4.6.3 DDR2 Clocks                        |     |
| _ | TEST POINTS                              |     |
|   |                                          |     |
| _ | 5.1 POWER THRU-HOLE                      |     |
| _ | 5.3 DIMM Power                           |     |
| _ | 5.4 "GC" TEST POINTS                     |     |
|   | 5.5 CLOCK TEST POINTS                    |     |
|   | 5.6 DIMM SIGNALS                         |     |
| 6 | USB INTERFACE                            |     |
|   | 6.1 CONNECTING TO THE DN9002K10PCIE8T    |     |
| ( | 6.1.1 CONNECTING TO THE DIN9002KTOPCIE81 |     |
|   | 6.1.2 Windows Vista                      |     |
|   |                                          | / 1 |

| 6.1.3                                                                                                                                                      | Linux                                                                                                                                                                                                                                                                                                                        | <i>71</i>            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| 6.1.4                                                                                                                                                      | Communication                                                                                                                                                                                                                                                                                                                | 71                   |
| 6.2 V                                                                                                                                                      | Vendor Requests                                                                                                                                                                                                                                                                                                              | 72                   |
| 6.2.1                                                                                                                                                      | VR_CLEAR_FPGA                                                                                                                                                                                                                                                                                                                | 72                   |
| 6.2.2                                                                                                                                                      | VR_SETUP_CONFIG                                                                                                                                                                                                                                                                                                              | 73                   |
| 6.2.3                                                                                                                                                      | VR_END_CONFIG                                                                                                                                                                                                                                                                                                                | 73                   |
| 6.2.4                                                                                                                                                      | VR_SET_EP6TC (Read buffer size)                                                                                                                                                                                                                                                                                              | 73                   |
| 6.2.5                                                                                                                                                      | VR_MEM_MAPPED (Configuration Registers)                                                                                                                                                                                                                                                                                      |                      |
| 6.2.6                                                                                                                                                      | Other Vendor Requests                                                                                                                                                                                                                                                                                                        | 73                   |
| 6.3 N                                                                                                                                                      | MAIN BUS ACCESSES                                                                                                                                                                                                                                                                                                            | 73                   |
| 6.3.1                                                                                                                                                      | Important Note about Endpoints                                                                                                                                                                                                                                                                                               |                      |
| 6.3.2                                                                                                                                                      | Performance                                                                                                                                                                                                                                                                                                                  | 74                   |
| 6.4 F                                                                                                                                                      | FPGA CONFIGURATION                                                                                                                                                                                                                                                                                                           |                      |
| 6.4.1                                                                                                                                                      | Readback                                                                                                                                                                                                                                                                                                                     | 75                   |
|                                                                                                                                                            | JSB Hardware                                                                                                                                                                                                                                                                                                                 |                      |
| 6.5.1                                                                                                                                                      | Cypress CY7C68013A                                                                                                                                                                                                                                                                                                           |                      |
| 6.5.2                                                                                                                                                      | Activity LED                                                                                                                                                                                                                                                                                                                 |                      |
| 6.5.3                                                                                                                                                      | Configuration FPGA                                                                                                                                                                                                                                                                                                           |                      |
| 6.5.4                                                                                                                                                      | Power                                                                                                                                                                                                                                                                                                                        |                      |
|                                                                                                                                                            | TROUBLESHOOTING                                                                                                                                                                                                                                                                                                              |                      |
| 6.6.1                                                                                                                                                      | USB Controller Freezes                                                                                                                                                                                                                                                                                                       |                      |
| 6.6.2                                                                                                                                                      | Main Bus always returns 0x (Error Codes)                                                                                                                                                                                                                                                                                     | <i>78</i>            |
|                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                              |                      |
| 7 PCI                                                                                                                                                      | E INTERFACE                                                                                                                                                                                                                                                                                                                  | 78                   |
|                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                              |                      |
| 7.1 H                                                                                                                                                      | HOST INTERFACE, ELECTRICAL                                                                                                                                                                                                                                                                                                   | 79                   |
| 7.1 F<br>7.1.1                                                                                                                                             | HOST INTERFACE, ELECTRICAL                                                                                                                                                                                                                                                                                                   | 79<br>80             |
| 7.1 I<br>7.1.1<br>7.1.2                                                                                                                                    | HOST INTERFACE, ELECTRICAL                                                                                                                                                                                                                                                                                                   | 79<br>80             |
| 7.1 H 7.1.1 7.1.2 7.2 H                                                                                                                                    | HOST INTERFACE, ELECTRICAL                                                                                                                                                                                                                                                                                                   | 79<br>80<br>81       |
| 7.1 H 7.1.1 7.1.2 7.2 H                                                                                                                                    | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"                                                                                                                                                                                                          | 79<br>80<br>81<br>81 |
| 7.1 H 7.1.1 7.1.2 7.2 H 7.3 H                                                                                                                              | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access                                                                                                                                                                                            |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1                                                                                                         | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"                                                                                                                                                                                                          |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2                                                                                                | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access                                                                                                                                                                            |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3                                                                                       | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1                                                                                                                                                      |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4                                                                              | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode                                                                                                                                     |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5                                                                     | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus                                                                                                                       |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6                                                            | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing.                                                                                                  |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6<br>7.3.7                                                   | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing.  FPGA Interface                                                                                  |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6<br>7.3.7<br>7.3.8<br>7.3.9                                 | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing.                                                                                                  |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6<br>7.3.7<br>7.3.8<br>7.3.9                                 | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing  FPGA Interface.  Host Interface, Software                                                        |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6<br>7.3.7<br>7.3.8<br>7.3.9<br>7.4                          | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing.  FPGA Interface.  Host Interface, Software  DTHER PROVIDED DESIGNS FOR THE LXT                   |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6<br>7.3.7<br>7.3.8<br>7.3.9<br>7.4 C<br>7.4.1               | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing.  FPGA Interface.  Host Interface, Software  OTHER PROVIDED DESIGNS FOR THE LXT  No design.       |                      |
| 7.1 F<br>7.1.1<br>7.1.2<br>7.2 F<br>7.3 F<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4<br>7.3.5<br>7.3.6<br>7.3.7<br>7.3.8<br>7.3.9<br>7.4 (7.4.1<br>7.4.2<br>7.4.3 | HOST INTERFACE, ELECTRICAL  Power  PCI-X  HOST INTERFACE, MECHANICAL  PROVIDED "FULL-FUNCTION PCI EXPRESS ENDPOINT"  BAR 0 Access  BAR 1-5 Access  DMA Channels 0 and 1  DMA Posted Mode  DMA Main Bus  Electrical  Timing.  FPGA Interface.  Host Interface, Software  DTHER PROVIDED DESIGNS FOR THE LXT  No design.  PIPE |                      |

| 8.1.1 Configuration              | 92  |
|----------------------------------|-----|
| 9 SYSTEM MONITOR/ADC             | 92  |
| 10 RESET                         | 03  |
|                                  |     |
| 10.1 POWER RESET                 |     |
|                                  |     |
| 11 JTAG                          |     |
| 11.1 FPGA JTAG                   |     |
|                                  | 95  |
| 11.1.2 ChipScope                 | 95  |
| 11.2 FIRMWARE UPDATE HEADER      |     |
|                                  |     |
| 12 RS232 INTERFACE               |     |
| 12.1.1 Configuration RS232       | 97  |
| 13 TEMPERATURE SENSORS           | 97  |
| 14 ENCRYPTION BATTERY            | 98  |
| 15 LED INTERFACE                 | 99  |
| 15.1 Configuration Section LEDs  | 99  |
| 15.2 USER LEDS                   | 100 |
| 15.3 ETHERNET LEDS               |     |
| 15.4 Power LEDs                  |     |
| 15.5 Unused LEDs                 | 102 |
| 16 DDR2                          | 102 |
| 16.1 Power                       | 103 |
| 16.1.1 Interface Voltages        |     |
| 16.1.2 Changing the DIMM voltage |     |
| 16.2 CLOCKING                    |     |
| 16.3 SIGNALING                   |     |
| 16.3.1 Standards                 | 105 |
| 16.3.3 Timing                    |     |
| 16.4 Compatible Modules          |     |
| 16.5 TEST POINTS                 |     |
| 17 FPGA INTERCONNECT             | 108 |
| 18 MAIN BUS                      | 110 |
| 18.1 MR SIGNALS                  | 111 |

| 18.1.1 Disambiguation                       | 111 |
|---------------------------------------------|-----|
| 18.1.2 Electrical                           |     |
| 18.1.3 Timing                               | 112 |
| 18.2 Error Codes                            | 112 |
| 18.3 FPGA INTERFACE                         | 113 |
| 18.3.1 Conventional Memory map              | 114 |
| 19 ETHERNET                                 | 115 |
| 19.1 MII                                    | 115 |
| 19.1.1 Electrical                           | 115 |
| 19.1.2 Timing                               | 116 |
| 19.2 JTAG                                   | 118 |
| 20 EPROM                                    | 119 |
| 21 MICTOR CONNECTORS                        | 120 |
| 21.1 FPGA B MICTOR                          | 120 |
| 21.2 MAINBUS MICTOR                         |     |
| 22 POWER                                    | 123 |
| 22.1 Power 12V                              | 123 |
| 22.2 Power 3.3V                             |     |
| 22.3 Power 2.5V                             |     |
| 22.4 Ground                                 |     |
| 22.5 Power Connections                      | 124 |
| 22.6 POWER MONITORS                         | 125 |
| 22.7 Heat                                   | 126 |
| 22.7.1 Fans                                 |     |
| 22.7.2 Removing Heatsinks                   |     |
| 22.7.3 Fan Tachometers                      | 127 |
| 23 CONNECTORS                               | 127 |
| 23.1 FPGA USER INTERFACE CONNECTORS         | 127 |
| 23.1.1 Comments                             |     |
| 23.2 Non-FPGA User Interface Connectors     | 128 |
| 23.2.1 Comments                             |     |
| 23.3 Not-For-Use Connectors                 |     |
| 23.3.1 Comments                             | 130 |
| 24 MECHANICAL                               | 130 |
| 25 DAUGHTERCARD HEADERS                     | 131 |
| 25.1 DAUGHTER CARD PHYSICAL                 | 132 |
| 25.1.1 Daughter Card Locations and Mounting |     |
| 25.1.2 Standard Daughtercard Size           | 134 |

| 25.                                                                              | 1.3 Insertion and removal                                | 135                      |
|----------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------|
| 25.2                                                                             | DAUGHTER CARD ELECTRICAL                                 | 137                      |
| 25.                                                                              | 2.1 Pin assignments                                      | 142                      |
| 25.                                                                              | 2.2 CC, VREF, DCI                                        | 144                      |
| 25.                                                                              | 2.3 Global clocks                                        | 144                      |
| 25.                                                                              | 2.4 Timing and Clocking                                  | 144                      |
| 25.                                                                              | 2.5 Power and Reset                                      | 145                      |
| 25.                                                                              | 2.6 VCCO Voltage                                         |                          |
|                                                                                  | 2.7 VCCO bias generation                                 |                          |
| 25.3                                                                             | ROLLING YOUR OWN DAUGHTERCARD                            | 147                      |
| 26 T                                                                             | TROUBLESHOOTING                                          | 147                      |
| 26.1                                                                             | THE BOARD IS DEAD                                        | 147                      |
| 26.2                                                                             | THE FPGAs WON'T PROGRAM                                  | 148                      |
| 26.3                                                                             |                                                          |                          |
| 26.4                                                                             | THE DCMs won't lock                                      | 149                      |
| 26.5                                                                             | THE SIGNAL ON MY BOARD IS GOING CRAZY ON MY OSCILLOSCOPE | 149                      |
| CHAI                                                                             | PTER 5: REFERENCE DESIGN                                 | 151                      |
| 1 P                                                                              | PURPOSE                                                  | 151                      |
|                                                                                  |                                                          |                          |
| 1.1                                                                              | INTERFACES USED BY REFERENCE DESIGN                      | 151                      |
| A T                                                                              | IADDWADE TECTO                                           | 152                      |
| 2 H                                                                              | HARDWARE TESTS                                           | 134                      |
| 2 F 2.1                                                                          |                                                          |                          |
|                                                                                  | .1 Testing PCI Express interface                         | 152                      |
| 2.1                                                                              | 1.1 Testing PCI Express interface                        | 152<br>152               |
| 2.1<br>2.1                                                                       | 1.1 Testing PCI Express interface                        | 152<br>152<br>152        |
| 2.1<br>2.1<br>2.1                                                                | 1.1 Testing PCI Express interface                        | 152<br>152<br>152<br>153 |
| 2.1<br>2.1<br>2.1<br>2.1                                                         | 1.1 Testing PCI Express interface                        | 152<br>152<br>152<br>153 |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1                                           | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1                                           | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3 <b>F</b>                             | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3 <b>F</b><br>3.1                      | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3 <b>F</b><br>3.1<br>3.2               | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3.1<br>3.2<br>3.3                      | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3.1<br>3.2<br>3.3<br>3.4               | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6        | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6        | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6<br>4 U | 1.1 Testing PCI Express interface                        |                          |
| 2.1<br>2.1<br>2.1<br>2.1<br>2.1<br>3.1<br>3.2<br>3.3<br>3.4<br>3.5<br>3.6<br>4 U | 1.1 Testing PCI Express interface                        |                          |

| 6   | DDR2 INTERFACE                                  | 157 |
|-----|-------------------------------------------------|-----|
| 6.1 | Provided Files                                  | 158 |
| 6.2 |                                                 |     |
| 6.3 | RUNNING THE TEST                                | 158 |
| 7   | CLOCK COUNTERS                                  | 158 |
| 8   | LEDS                                            | 158 |
| 9   | SIMULATING THE REFERENCE DESIGN                 | 159 |
| 10  | COMPILING THE REFERENCE DESIGN                  | 159 |
|     | 0.1.1 The Xilinx Embedded Development Kit (EDK) |     |
|     | 0.1.2 Xilinx ISE                                |     |
| 1   | 0.1.3 The Build Utility: Make.bat               |     |
| 10. | .2 BITGEN OPTIONS                               |     |
| 11  | LVDS REFERENCE DESIGN                           | 161 |
| 11. | .1 Provided Files                               | 161 |
| 11. |                                                 |     |
| 11. | .3 RUNNING THE TEST                             | 162 |
| 12  | PCIE INTERFACE REFERENCE DESIGN                 | 162 |
| 12. | .1 Provided Files                               | 162 |
| 12. |                                                 |     |
| 12. | .3 RUNNING THE TEST                             | 162 |
| CHA | APTER 6: ORDERING INFORMATION                   | 163 |
| 1   | SECTION TITLE                                   | 163 |
| 2   | FPGA OPTIONS                                    | 163 |
| 2.1 | FPGA A AND B:                                   | 163 |
| 2.2 | 2 CES PARTS                                     | 163 |
|     | 2.2.1 Hardware Errata Details                   |     |
| 2.3 |                                                 |     |
| 2.4 |                                                 |     |
| 2.5 |                                                 |     |
| 3   | OPTIONAL EQUIPMENT                              | 166 |
| 3.1 | COMPATIBLE DINI GROUP PRODUCTS                  | 166 |
|     | 8.1.1 Memories                                  |     |
|     | 3.1.2 Daughtercards                             |     |
| 32  | COMPATIRI E THIRD-PARTY PRODUCTS                | 168 |

| 4 COMPLIANCE DATA                                | 169 |
|--------------------------------------------------|-----|
| 4.1 COMPLIANCE                                   | 169 |
| 4.1.1 EMI                                        |     |
| 4.1.2 <i>PCIe-SIG</i>                            | 169 |
| 4.2 Environmental                                | 169 |
| 4.2.1 Temperature                                | 169 |
| 4.3 EXPORT CONTROL                               |     |
| 4.3.1 Lead-Free                                  | 169 |
| 4.3.2 The USA Schedule B number based on the HTS | 169 |
| 4.3.3 Export control classification number ECCN  | 170 |
| 4.4 MISSION CRITICAL                             | 170 |

# **Chapter 1: Introduction**

Congratulations on your purchase of the DN9002K10PCIE8T logic emulation board. If you are unfamiliar with Dini Group products, you should read Chapter 2, Quick Start Guide to familiarize yourself with the user interfaces the DN9002K10PCIE8T provides.



Figure 1 DN9002K10PCIE8T – Heat sinks negligently left uninstalled.

# **1 Manual Contents**

This manual contains the following chapters:

#### 1.1 Introduction

Reader's Guide to this manual; List of available documentation and resources

#### 1.2 Quick Start Guide

Step-by-step instructions for powering on the DN9002K10PCIE8T, loading and communicating with a simple, provided FPGA design, and using the board's common control features

#### 1.3 Controller Software

A summary of the functionality of the provided software; Implementation details for the remote USB board control functions and instructions for developing your own USB host software

#### 1.4 Hardware

Detailed description and operating instructions of each individual circuit on the DN9002K10PCIE8T; A description of each user-accessible interface and user features

# 1.5 The Reference Design

Detailed description of the provided DN9002K10PCIE8T reference design; Implementation details of the reference design interaction with DN9002K10PCIE8T hardware features

# 1.6 Ordering Information

Contains a list of the available options and available optional equipment; some suggested parts and equipment available from third party vendors; Compatibility lists

# 2 Conventions

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

# 2.1 Typographical

The following typographical conventions are used in this document:

| Convention      | Meaning or Use                 | Example                                  |
|-----------------|--------------------------------|------------------------------------------|
| Prefix "0x"     | Indicates hexadecimal notation | Read from address 0x00110373, returned   |
| Letter "#", "N" | Signal is active low           | INT# is active low<br>RSTn is active low |

#### 2.2 Manual Content

#### 2.2.1 File names

Paths to documents included on the User CD are prefixed with "D:\". This refers to your CD drive's root directory when the User CD is inserted in your Windows computer.

Alternately, copy the entire contents of the User CD to your hard drive, and allow D:\ to refer to this path. Due to limitations of the Xilinx ISE software, we recommend a path without space characters in it. (Bad places include C:/Documents and Settings/username/Desktop/)

# 2.2.2 Physical Dimensions

By convention, the board is oriented as shown in the above board photo, with the "top" of the board being the edge near the DDR2 SODIMM. The "right" edge is near FPGA B. The "left" side is the side with the PCIe bezel. "Top" side refers to the side of the PWB with FPGAs and fans; the "back" side is the side with the two daughtercard connectors. The reference origin of

the board is the center of the lower PCIe bezel mounting hole. Physical dimensions are given in millimeters.

#### 2.2.3 Part Pin Names

References to individual part's pin are given in the form  $\langle X \rangle \langle Y \rangle$ .  $\langle Z \rangle$ ; The  $\langle X \rangle$  is one of: U for ICs, R for resistors, C for capacitors, P or J for connectors, FB or L for inductors, TP for test points, MH for mounting structures, FD for fiducials, BT for sockets, DS for displays (light-emitting diodes), F for fuses, PSU for power supply modules, Q for discrete semiconductors, RN for resistor networks, G for oscillators, X for sockets, Y for crystals and the PCIe bezel.  $\langle Y \rangle$  is a number uniquely identifying each part from other parts of the same class.  $\langle Z \rangle$  is the pin or terminal number or name, as defined in the datasheet of the part. Datasheets for all standard and optional parts used on the DN9002K10PCIE8T are included in the Document library on the user CD.

# 2.2.4 Schematic Clippings

Partial schematic drawings are included in this document to aid quick understanding of the features of the DN9002K10PCIE8T. These clippings have been modified for clarity and brevity, and may be missing signals, parts, net names and connections. Unmodified Schematics are included in the User CD as a PDF. *Please refer to this document when designing an interface in the FPGA*. Use the PDF search feature to search for nets and parts.

# 2.3 Terminology

Abbreviations and pronouns are used for some commonly used phrases. The user is assumed to know the meaning of the following:

#### Spartan

Spartan refers to the Spartan-3 FPGA device used by the DN9002K10PCIE8T to perform configuration circuit functions. It is used interchangeably with "configuration circuit"

DCM, DLL, PLL

"Digital Clock Manager" or "Digitally-locked-loop"

This is a clock synthesis module in a Virtex-5 FPGA. PLL is "Phase-locked-loop". See Xilinx documentation.

LVDS

"Low-Voltage differential signaling"; a signaling standard with a 1.2V DC, and 300mV AC level; in this manual and in advertisements, LVDS is often used where "Differential Signal" should be used instead.

Net, Signal, Plane, rail

A net is an electrically continuous piece of conductor on the PCB before assembly. Signal can refer to an electrically continuous conductor on the PCB, or to the logical meaning of that net. Plane is a net for voltage sources. Rail is also used to mean a power net.

GND, ground, grounded

GND is a net on the DN9002K10PCIE8T, to which all voltages are referenced. "Ground" is equivalent". Grounded means "connected to GND". There is a single ground net on the DN9002K10PCIE8T

# 3 Resources

The following electronic resources will help you during development with your board.

# 3.1 User CD

The User CD contains all the electronic documents required for you to operate the DN9002K10PCIE8T. These include schematics, the user manual, FPGA reference designs, and datasheets. The directory structure of the CD is as follows

| Config_Section_Code\ ConfigFPGA\ MCU\            | the DN9002K10PCIE8T firmware source code; these sources are not intended to be used for development                                |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Datasheets\                                      | A datasheet for every part used on the board. You will need these to interface successfully with resources on the DN9002K10PCIE8T  |
| DNMEG_Intercon_Daughtercard\                     | Daughtercard manual                                                                                                                |
| DNMEG_Observation_Daughtercard\                  | Daughtercard manual                                                                                                                |
| DNPCIE_CBL_CableAdapteraughtercard\              | Daughtercard manual                                                                                                                |
| Documentation\Manual\ Manual\ Dini_USB_Spec\     | Contains this document and USB controller Specification                                                                            |
| FPGA_Reference_Designs\ common\ DN9002K10PCIE8T\ | Contains the source and compiled programming files for the Dini group's DN9002K10-PCIe8t reference design; Also, board description |
| Programming_Files\ pcie\                         | files and simulation models                                                                                                        |

opencore\

PCIe\_Software\_Applications\Aetest\ Source and binaries for the provided PCIe-

hosted controller software

Schematics\Rev\_01\ Contains a PDF version of the board

schematic. Search the PDF using control-F. Also contains an ASCII netlist of the board.

USB\_Software\_Applications\ Contains source and binaries for the provided

USB-hosted controller applications.

USB\_Software\_Applications\
driver\
AETEST\_USB\
USBController\

# 3.2 Dinigroup.com

The most recent versions of the following documents are found on the product web page http://dinigroup.com/DN9002k10PCIe-8T.php

User's Manual (this document) Errata USB Controller executable

# 3.3 Errata and Customer Notifications

The Errata sheet (available at www.dinigroup.com) lists all cases where the DN9002K10PCIE8T is found to have failed to meet advertised specifications, or where an error in schematics or documentation is likely to cause a difficult-to-debug error by the user.

Customers are not notified when changes are made to other documents including the reference design, USB Controller and User Manual. These documents change or a weekly basis or faster. You may always request a duplicate User CD. We will also be happy to provide the latest version of documents via email to customers.

# 3.3.1 Existing Errata

At the time of print, the following errata exist.

Differential Polarity On Daughtercards

Symptom/Problem

The signal DCA1N29 connects to "P" pin on the FPGA, and the signals DCA1P29 connects to "N" pin on the FPGA. **Impact** Only customers who are using one of these three pairs as a differential signal are affected. Single-ended use of these signals is not impacted. Solution/Work-Around

When using daughtercards requiring differential signaling on these pins, then the FPGA RTL must invert the transmitted or received logic. The differential input buffer should connect so that the .I connects to a "P" pin on the FPGA, and the .IB port connects to an "N" pin on the FPGA.

#### 3.4 Schematics and Netlist

Unmodified Schematics are included in the User CD as a PDF. Use the PDF search feature to search for nets and parts.

#### 3.4.1 Netlist

In lieu of providing a machine-readable version of the schematic, the Dini Group provides a text netlist of the board. This netlist contains all nets on the board that connect to user IO on any FPGA. When interfacing with any device or connector on the DN9002K10PCIE8T you should use either the provided .ucf, or the netlist to generate the pinout. The netlist is located on the user CD at

D:\Schematics\Rev\_01\DN9002K10PCIE8T\_customer\_netlist.txt

#### 3.4.2 Net name conventions

All "power" nets begin with a +, - symbol, or GND

All clock signals begin with "CLK"

Two sides of a differential signal differ by one character "p" or "n". This character is near the end of the net name.

Active low signals end in #. In the provided UCF files, the # is replaced by an "N".

# 3.5 Datasheet Library

Datasheets for all parts used, or interfaced to, on the DN9002K10PCIE8T are provided on the user CD. In order to successfully use the DN9002K10PCIE8T, you will have to reference these datasheets. The interface descriptions given in this user manual typically end with electrical connectivity.

Especially read the Virtex-5 user guide. The copy provided on the user CD is only recent as of the DN9002K10PCIE8T product announcement.

#### 3.6 Xilinx

Virtex-5 is a brand-new device, and technical questions about getting the FPGA and ISE software to behave like you expect should be directed to a Xilinx FAE. Also use

WebCase <a href="http://www.xilinx.com/support/clearexpress/websupport.htm">http://www.xilinx.com/support/clearexpress/websupport.htm</a>

AnswerBrowser <a href="http://www.xilinx.com/xlnx/xil">http://www.xilinx.com/xlnx/xil</a> ans browser.jsp

ISE Manual <a href="http://www.xilinx.com/support/sw-manuals/xilinx82/index.htm">http://www.xilinx.com/support/sw-manuals/xilinx82/index.htm</a>
Virtex 5 Manual(s) <a href="http://www.xilinx.com/xlnx/xweb/xil-publications-display.jsp">http://www.xilinx.com/xlnx/xweb/xil-publications-display.jsp</a>

# 3.7 Dini Group Reference Designs

The source code to the reference designs are on the User CD. Please copy and use any code you would like. The reference designs themselves are not deliverables, and as such receive limited support.

# 4 Email and Phone Support

Dini Group technical support for products can be reached via email at <a href="support@dinigroup.com">support@dinigroup.com</a>. Our phone number is (USA) 858-454-3419. Please do not send .exe files, .vb files, or .zip files containing other .zip files as attachments, as we will not receive these emails. Please include the board's serial number in your email. This will allow us to reference our records regarding your board.

Before contacting support you should complete the following:

- 1) Follow the debugging steps in the troubleshooting sections at the end of the hardware chapter, and in any applicable interface sections.
- 2) Test the applicable interface(s) using the provided software and .bit files, to help rule out hardware failures.

# **Chapter 2: Quick Start Guide**

The Dini Group DN9002K10PCIE8T can be used and controlled using many interfaces. In order to learn the use of the most fundamental interfaces of the board (FPGA Configuration, USB data movement, etc.) please follow the instructions in this quick start guide. The guide will also show you how to run the board's hardware test to verify board functionality. (The board has already been tested at the factory).

# 1 Provided Materials

Examine the contents of your DN9002K10PCIE8T kit. It should contain:

DN9002K10PCIE8T board Compact Flash card containing the FPGA configuration ".bit" files required to run the hardware test.

USB Compact Flash card reader

Cable for RS232 (10-pin header to female DB9)

PCI Express "graphics power" adapter cable

PSU Starter

USB cable, black

Daughtercard mounting hardware

#### CD ROM containing:

- Virtex 5 Reference Designs
- User manual PDF
- Board Schematic PDF
- USB program (usbcontroller.exe)
- PCIe program (Aetest.exe)
- Source code for USB program, PCIe program and DN9002K10PCIE8T firmware
- Board netlist and Virtex 5 simulation model

# 1.1 System Requirements

To compile Verilog designs for Virtex 5, ISE 9.2 may be required.

To use the provided controller software, you need any Windows XP computer with USB 2.0.

Although firmware updates can be completed without a Jtag cable, board recovering after failed update required a Jtag cable for ISP. If you don't have a Jtag cable, you can ship the board back for recovery.

# 2 Warnings

#### **2.1 ESD**

The DN9002K10PCIE8T is sensitive to static electricity, so treat the PCB accordingly. The target markets for this product are engineers that are familiar with FPGAs and circuit boards. However, if needed, the following web page has an excellent tutorial on the "Fundamentals of ESD" for those of you who are new to ESD sensitive products:

http://www.esda.org/esd\_fundamentals.html



Figure 2 - Bzzzzzzt!!

There are two large grounded metal rails on the DN9002K10PCIE8T. The user should handle the board using these rails, as they are much less ESD sensitive than any other point on the board.

The 400-pin connectors are not 5V tolerant. Very few exposed surfaces on the board are tolerant of voltages greater than 4V. According to the Virtex 5 datasheets, the maximum applied voltage to any IO signals on the FPGA is VCCO. This means you should not try to over-drive IOs in an FPGA interface above the interface voltage specified in this manual.

# 2.2 Other

Some parts of the board are physically fragile. Take extra care when handling the board to avoid touching the daughtercard connectors. Leave the covers on the daughtercard connectors whenever they are not in use. Use mounting hardware to secure daughtercards.

# 2.3 Other warnings

The following unknown prohibitions apply.



# 3 Pre-Power on Instructions

The image below represents your DN9002K10PCIE8T. You will need to know the location of the following parts referenced in this chapter.



Figure 3 DN9002K10PCIE8T stuff you need to know about to get started.

The FPGAs on the board are names "FPGA A", "FPGA B" as shown in the above photo. The "FPGA Q" is Virtex 5 LX50T.

To begin working with the DN9002K10PCIE8T, follow the steps below.

# 3.1 Install Memory

The DN9002K10PCIE8T comes packaged without memory installed. If you want the Dini Group reference design to test your memory interfaces, you must install memory modules in the SODIMM slot on the board. The reference design supports DDR2 SODIMM modules in any densities up to 4 GB (more than 4 GB is not tested). Although the DN9002K10PCIE8TE8T is compatible with any DDR2 SODIMM module, support for certain addressing configurations may not have been implemented, so if you find your module doesn't work, email us the model number.

The socket DIMMB is connected to FPGA B. The socket can accept any capacity DDR2 SODIMM module. Note that DDR1 modules will not work in these slots since they are a completely different pin-out and voltage level.

# 3.2 Prepare configuration files

The DN9002K10PCIE8T reads FPGA configuration data from a CompactFlash card. To program the FPGAs on the DN9002K10PCIE8T, FPGA design files (with a .bit file extension) put on the root directory of the CompactFlash card file using the provided USB card reader.

The DN9002K10PCIE8T ships with a 256MB Compact Flash card preloaded with the Dini Group reference design. These "bit" files can also be found on the User CD. You can also compile the reference design source (provided on the CD) and place the generated .bit files on the Compact Flash card.

Insert the provided Compact Flash card labeled "Reference Design" into your USB card reader. Make sure the card contains the files:

FPGA\_A.bit (if FPGA A installed) FPGA\_B.bit (if FPGA B installed) main.txt

The files FPGA\_A-B.bit are files created by the Xilinx program bitgen, part of the ISE 9.2 tools. The file main.txt contains instructions for the DN9002K10PCIE8T configuration circuitry, including which FPGAs to configure, and to which frequency the global clock networks should be automatically adjusted.

# 3.3 Insert the Compact Flash card into the DN9002K10PCIE8T's Compact Flash slot

This step involved inserting the CompactFlash card into the DN9002K10PCIE8T's CompactFlash slot. No further advice is given.

# 3.4 Install DN9002K10PCIE8T in computer

If you are not using the DN9002K10PCIE8T in a PCIe Express slot, skip this step. You may instead choose to host the DN9002K10PCIE8T over USB.

The DN9002K10PCIE8T is compatible with PCIe-Express 1, 4 or 8-lane. Using the board in a 4x or 1x slot will require an adapter card, such as those available from Catalyst.

The rest of this chapter assumes you are installing the board into a Windows XP computer. The DN9002K10PCIE8T and provided software is compatible with other operating systems, but there is no corresponding quick start guide.

#### 3.5 Cables

#### 3.5.1 Connect RS232 Cable

The configuration circuit displays status messages to an RS232 terminal. If (when) something goes wrong with configuration, this terminal will output error messages. Normally, you would only connect this cable when something is not working and you want to debug the problem.

Use the provided ribbon cable to connect the MCU RS232 port (P2) to a computer serial port to view feedback from the configuration circuitry during FPGA configuration. Run a serial terminal program on your PC (On Windows you can use HyperTerminal Start->Programs->Accessories->Communications->HyperTerminal) and make sure the computer serial port is configured with the following options:

Bits per second: 19200

Data bits: 8 Parity: None Stop Bits: 1

Flow control: None

Terminal Emulation: VT100 (or None, if available)

#### 3.5.2 Connect USB Cable

Use the provided USB cable to connect the DN9002K10PCIE8T to a Windows computer (Windows XP is recommended).

If your board is installed in a PCIe slot, the USB host is allowed to be the same computer as the non-USB host. The two computers should be connected to the same power outlet if this is the case.

#### 3.5.3 Connect Power cable

The power cable connected to J6 is required. If you do not plug a cable in here, the board will not power on. This is true whether or not the board is installed into a PCI Express slot. Most new power supplies have a 6-pin "PCI Express Graphics" power connector. If yours does not, use the provided adapter cable. If you are operating desk-top, and not in a motherboard, then your power supply might not turn on if the 20 or 24-pin "motherboard" power connector is not connected to anything. In this case, connect the provided PSU starter to the PSU. Power On

Turn on the ATX power supply (USB Hosting) or the computer (PCIe hosting).

When the DN9002K10PCIE8T powers on, it automatically loads Xilinx FPGA design files (ending with a .bit extension), found on the CompactFlash card in the CompactFlash slot into the FPGAs, using the main.txt file as a guide.

# 3.6 View configuration feedback over RS232

As the DN9002K10PCIE8T powers on, your RS232 terminal (connected to P2) will display information about the Configuration process. If FPGAs ever fail to configure using the Compact Flash card, this is the best place to look for help.

A typical RS232 power-on session is given below.

| Rebooting from FLASHplease wait                                      | This line has to do with the firmware-update mode                                                                                                                                      |
|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Setting G0 N 01 M: 000001000 DONE Setting G1 N: 01 M: 000001000 DONE | The board is setting the global clock frequencies according to the main.txt file on the CompactFlash card. The messages here are mostly only useful to whoever programmed the firmware |
| Setting G2 N: 01 M: 000001000 DONE                                   | Prints the FPGAs the configuration circuit thinks you have on your board.                                                                                                              |

=-=- DN9002K10PCIE8T MCU FLASH BOOT -=-= -- FPGAS STUFFED --ΑВ CompactFlash card debugging information. -- COMPACTFLASH INFO --MAKER ID: EC DEVICE ID: 75 This lists the files found on the compact flash card. If this list is SIZE: 32 MB wrong there is something wrong with CompactFlash. -- FILES FOUND ON COMPACTFLASH CARD FPGA\_B.BIT FPGA\_A.BIT MAIN.TXT The MCU reads the contents of the file MAIN.TXT and executes -- CONFIGURATION FILES -each instruction line. FPGA A: FPGA\_A.BIT FPGA B: FPGA\_B.BIT Here the MCU is setting the clocks according to instructions in MAIN.TXT --OPTIONS--Message level set to default: 2 Sanity check is set to default: ON N: 00 M: 000001010 DONE Setting G0... N: 01 M: 000001100 The MCU is configuring FPGA A according to instructions in DONE MAIN.TXT Setting G1... N: 01 M: 000001000 Debugging information about the .bit file. DONE \*\*\*\*\*\*\*CONFIGURING FPGA: A\*\*\*\*\*\*\*\*\*\* -- Performing Sanity Check on Bit File ---- BIT FILE ATTRIBUTES --FILE NAME: FPGA\_A.BIT FILE SIZE: 003A943B bytes The MCU is configuring FPGA B according to instructions in PART: 4vlx100ff151317:09:38 MAIN.TXT DATA: 2005/07/25 TIME: 17:09:38 Sanity check passed .....DON E WITH CONFIGURATION OF FPGA: A \*\*\*\*\*\*\*\*\*CONFIGURING FPGA B\*\*\*\*\*\*\*\*\* The MCU is setting the temperature threshold (Causes the FPGAs -- Performing Sanity Check on Bit File -to automatically disable when overheating) -- BIT FILE ATTRIBUTES --FILE NAME: FPGA\_B.BIT FILE SIZE: 003A943B bytes PART: 4vlx100ff151317:05:01 DATA: 2005/07/19 TIME: 17:05:01 Sanity check passed



Figure 4 RS232 Output - Note, this won't be the same as the output that you get, but you will have general idea.

# 3.7 Check LED status lights

The DN9002K10PCIE8T has many status LEDs to help the user confirm the status of the configuration process.

Check the power Failure LEDs to confirm that all voltage rails of the DN9002K10PCIE8T are within tolerance. If the voltage of any critical power net on the DN9002K10PCIE8T is too high or too low, the board will be held in reset and at least one of the red LEDs will light. The LEDs are located on the top edge, near the left corner of the PCB. Each one is labeled with the voltage that it represents. Normally, all of these LEDs are off. If any of these LEDs light, there is a power problem with the board, and you should contact us. First, make sure that the output of the power supply is acceptable. If the 5V, 3.3V or 12V power fail LED is lit, you most likely have a problem with the power supply you are connected to, and less likely with the DN9002K10PCIE8T.

Reset LED. When the board is in reset for any reason, including power failure, or pressing the reset button, this LED will light RED. The LED is located below the RED voltage LEDs next to the logic-reset button.

Check the Spartan FPGA status LED located near pin 1 of the PCIe edge connector (DS66). This LED should remain BLUE as long as the board is powered on, except for a quarter second just as the board is powering on. This LED indicated the configuration and control FPGA is on. If this LED is not on, it indicates a problem with the board or firmware.

Check the "DONE" LEDs of each FPGA. When an FPGA is configured, a blue LED labeled "DONE" will glow, to the upper left of the FPGA.

Check the FPGA A user LEDs located just below the FPGA A. These LEDs should be active if the Dini Group reference design is correctly loaded. Repeat this step for FPGAs B. These Yellow LEDs are lined up below the FPGAs.

Check the CF activity LED, located just below the CompactFlash socket. When the board is reading off the CompactFlash card during configuration, this yellow LED should blink.



Figure 5: LEDs

# **4 Run USB Controller**

This section will get you started with USB and show you how to operate the provided software.

#### 4.1 Driver Installation

When the DN9002K10PCIE8T powers on, or you connect it to a USB port for the first time, the computer will ask you to install a driver.



In the window that appears, select "Install from a list or specific location". Select Next.

Click "Include this location in the search" and browse to D:\USB\_Software\_Applications\driver\windows\_wdm Select Next.

In the next window, select the item in the list "Dini Group ASIC Emulator". Click FINISH.

After Windows installs the driver, you will be able to see the following device in the "ASIC Emulators" group in the Windows device manager: "DiniGroup Product FLASH Boot".

# 4.2 Operating the USB Controller program

Run the USB controller application found on the product CD in D:\USB\_Software\_Applications\USBController\USBController.exe



Figure 6: USB Controller Window. This window will appear showing the current state of the DN9002k10PCIE8T. If FPGA configured, next to each FPGA a blue light will appear.

# 4.2.1 Configure an FPGA

Even though the reference design should already be loaded (because you had a Compact Flash card installed when the board powered on), let's configure an FPGA over USB.

Clear an FPGA of its configuration, right-click on an FPGA, and selecting from the popup menu, "Clear FPGA". The blue light above the FPGA on the GUI and on the board should turn off.

To re-configure that FPGA using the USB Controller program, right-click on the FPGA and select Configure FPGA via USB from the popup menu. The program will open a dialog box for you to select the configuration file to use for configuration. Browse to the provided user's CD "D:\FPGA\_Reference\_Designs\Programming\_Files\DN9002K10PCIE8T\MainRef\LX330 \fpga\_a.bit"

If you are configuring an LX220 or LX110 device you should select a bit file from the LX220 or LX110 directories instead. Failing to select the correct type of bit file will result in the USB

Controller program to warn you, and the FPGA fail to configure. The program will report the status of the configuration when it finishes. "DONE did not go high". This refers to the DONE selectMap signal, which is asserted by the FPGA when it is properly configured.

If you are configuring FPGA B or FPGA Q, you should select fpga\_b.bit or fpga\_q.bit instead. Should you configure the wrong FPGA with the wrong bitfile, the FPGA will succeed to configure, but probably won't function properly. This is not recommended because it could lead to bus contention and excessive heat generation.

Done

FPGA B cleared successfully.

FPGA A cleared successfully.

Doing a sanity check...Sanity Check passed. Configuring FPGA B via USB...please wait.

File

D:\\dn\_BitFiles\DN9002K10PCIE8T\MainRef\LX330\fpga\_b.bit transferred. Configured FPGA B via USB

Figure 7: USB Controller Log Output

The message box below the DN9002K10PCIE8T graphic should display some information about the configuration process. When the configuration is successful, the green LED should re-appear next to the FPGA.

# 4.2.2 Set Clock Frequencies

To change the clock frequencies of G0, G1 or G2, select the "Clock settings" option from the "Settings" menu.

A dialog box appears asking to which frequency you would like to set each clock. Enter 350, 200, 200 for G0, G1 and G2 respectively.

#### 4.2.3 Run Hardware Test (DDR2)

First, hit the "Enable USB->FPGA communication" button. This must be done before the program can interact with the reference design. You must also have the reference design loaded, and a DDR2 module installed in a memory socket connected to the FPGA using that reference design. Also, the clock settings must be correct. Follow the procedure in the previous section to accomplish this.

From the FPGA Memory menu, select Test DDR. A box will appear and ask which FPGA should be tested. "B" is the correct answer. The log window will report whether the test passed. If it fails, it will print a list of addresses and data that failed.

If you would like to simulate a failure, you can repeat this guide with the DDR2 module removed. Other tests that could be performed from the USB Controller (but aren't part of this

quick-start) are interconnect tests, Ethernet tests, and something else. For information on running these tests, see the Software chapter.

# 4.3 Getting data to and from the FPGA

The USB Controller program also allows you to easily configure and transfer data to and from the user design on the emulation board. This data transfer occurs over the boards "MainBus". This interface is described in the Hardware chapter.

Some users may choose not to implement the "MainBus" interface, and use these signals for general-purpose FPGA interconnect. To allow this, by default the main bus is disabled, and the Host interface (USB in this case) is prevented from operating it. To override this setting, hit the "Enable USB->FPGA communication" button near the top of the window.

To read data from the FPGA design (the Dini Group reference design), select from the menu MainBus->Read

In the resulting dialog box, enter "0800000000" in the "Start Address" box and "10" in the "Size" box. Press OK, and then DONE. The result of the read is printed to the USB Controller log window.

| FPGA READ |          |            |
|-----------|----------|------------|
| AD        | DDRESS   | DATA       |
| 0x0       | 08000000 | 0xdead5566 |
| 0x0       | 8000001  | 0x00000000 |
| 0x0       | 8000002  | 0x05000135 |
| 0x0       | 8000003  | 0xffffffee |
| 0x0       | 8000004  | 0x34561111 |
| 0x0       | 8000005  | 0x00000001 |
| 0x0       | 8000006  | 0x00000000 |
| 0x0       | 8000007  | 0x00000000 |
|           |          |            |

Figure 8: USB Controller Log Output

The address 0x080000000 is by "MainBus" convention assigned as part of the space available for implementation by FPGA A on the DN9002K10PCIE8T. If FPGA A is not loaded with the Dini Group reference design (or a design that implements the MainBus slave), then all address reads will return 0xDEADDEAD.

# 5 Communicating over the Serial Port

You may want to communicate with your design over the user serial port (P1). The MainRef reference design that you already loaded has an asynchronous loop back on this port. If you want to test this connection, connect an RS232 terminal to the header and type stuff. The port should echo back that very same stuff.

# 6 Run AETest wdm

The program provided to access the DN9002K10PCIE8T over PCIe is called AETest. It is located on the user CD

D:\PCIe\_Software\_Applications\Aetest\aetest\_aetest\_wdm.exe

If you are running Linux or Solaris, you must compile AETest before continuing this quick-start guide. This involves installing the kernel source packages on the computer, then loading a kernel module somehow. Details are in the Software Chapter. The rest of this guide assumes you are using Windows XP.

After you turn your computer on the computer will display a dialog asking for the driver for a "Dini Group board with Virtex 5 PCI Express"

Click "Choose a driver to install" -> Click "Have Disk" and browse to

D:\ PCIe\_Software\_Applications\Aetest\wdmdrv\drv\dndev.inf

#### 6.1.1 Use AETest

The AETest application should display its main menu.

Figure 9 start up menu

If this window says something like "GUID not found", then the driver is not installed properly. Check in the windows device manager and see if a device with VID 0x17DF and PID 0x1900 is there.

```
Shortcut to aetest_wdm.exe

-== ASIC Emulator PCI Controller Driver =-=- v19

Current Device: (0) DN9002K10PCIE8T Virtex5 PCI Express 8 lane Board Compiled on: Sep 25 2008 at 16:02:05

$\frac{\text{Source Selection}}{\text{PCI Menu}} \text{Memory Menu} \text{1} \text{Read Board Temperatures} \text{2} \text{Read Clock Frequencies A-B} \text{3} \text{Read Clock Frequencies A-B} \text{3} \text{Read Clock Frequencies Q} \text{4} \text{5et Board-Level Clocks} \text{5} \text{Config FPGA} \text{6} \text{12C Control Menu} \text{7} \text{DMA Test Menu} \text{1} \text{11 Interconnect Test Menu} \text{A} \text{DaughterCard Test (FPGA A only)} \text{B} \text{DaughterCard Test (FPGA B only)} \text{1} \text{17 Production Tests Menu} \text{9} \text{Get Board Serial Number} \text{9} \text{Quit} \text{-=-= PCI BASE ADDRESS =---} \text{0} : da800000 & 1 : da000000 & 2 : d6000000 \text{3} : d8000000 & 5 : 000000000 \text{VIII.}
```

Figure 10 main menu

This is the menu, with some things you can do. I highly recommend the fun-to-use "Production test menu". You can run the "PCIe" test. This will write stuff to the PCIe reference design that may or may not be loaded into FPGA A, and report the results.



Figure 11 Memory menu

The "memory" menu is also fun, as it lets you display PCIe memory space directly, and also allows access to the "MainBus" interface that we used a little earlier.



Figure 12 Production test menu

It is acceptable to operate the DN9002K10PCIE8T from USB and PCIe at the same time. The mutual exclusivity of all features is not finalized, but it's a safe bet that if you use the "MainBus" feature from PCIe and USB simultaneously, the board will do something other than work properly.

# 7 Scan the JTAG chain

If you wish, you can program the FPGAs using their JTAG interface. Connect a Xilinx Platform USB cable into the FPGA JTAG port (J7), and open the IMPACT program that is installed with Xilinx ISE 9.1.



When you connect the Platform USB cable for the first time, Windows will automatically install a driver three times in a row, like a retarded parrot.

The program "scans the chain" to auto-detect the type and number of FPGAs installed on your board and display them on the screen. Right click on an FPGA and select "choose configuration file". Browse to the bit files provided on the user CD. For example:

D:\FPGA\_Reference\_Designs\Programming\_Files\DN9002K10PCIE8T\MainRef\LX110\fpga\_A.bit

This JTAG port should also be used for visibility products like Xilinx ChipScope.



# 7.1 Moving On

Congratulations! You have just programmed the DN9002K10PCIE8T and learned all of the features that you have to know to start your emulation project. If you are new to Xilinx FPGA, you might want start by compiling the reference design, and adding code to the reference design, until you are comfortable with the design flow. You should also use the provided UCF constraint file as a starting point for your UCF file.

# **Chapter 3: Controller Software**

The DN9002K10PCIE8T can be hosted from USB or PCIe. As an example to hosting using these interfaces, the Dini Group provides some controller software that allows configuring FPGAs, and changing the board settings. For more complex host behavior, such as interactively transferring data to and from the board from the host computer, you may have to develop your own host software, either USB or PCIe. At the end of this chapter, there is a programmer's guide to help you interface to the DN9002K10PCIE8T. This, along with the source code of the example software should be able to get you communicating with the DN9002K10PCIE8T.

The software included with the DN9002K10PCIE8T is

USB Controller – A Windows XP only GUI application capable of configuring

FPGAs, sending data to the user FPGA core via USB, changing board settings, and running hardware tests.

AETest usb - A cross-platform (Windows, DOS, Linux, and Solaris) command-

line application capable of configuring FPGAs, sending data

via USB, and changing board settings

AETest A cross-platform (Windows XP, Windows 98, DOS, Linux,

and Solaris) command-line program capable of configuring FPGAs,

and sending data to and from user FPGA cores via PCIe

These programs and the source code for them can be found on the user CD

D:\PCIe\_Software\_Applications\Aetest\

D:\USB\_Software\_Applications\AETEST\_USB\D:\USB\_Software\_Applications\USBController\

Precompiled windows XP binaries for USB Controller, and AETest\_usb, and AETest are provided on the user CD as a Microsoft Visual Studio 6 project. Visual Studio 6 or later is required to compile these programs.

All three programs use a driver provided by the Dini Group.

The PCIe drivers can be found at PCI\_Software\_Applications\Aetest\wdmdrv PCI\_Software\_Applications\Aetest\linuxdrv-2.6 PCI\_Software\_Applications\Aetest\solaris\driver

The USB driver can be found at USB\_Software\_Applications\driver

## 1 USB Controller

The USB Controller program is intended to

- Verify Configuration Status
- Configure FPGAs over USB
- Configure FPGAs via CompactFlash card
- Clear FPGAs
- Reset FPGAs
- Set Global clocks frequency
- Update firmware (for MCU and Spartan)

The following function interface with the Dini Group reference design

- Read/Write to FPGAs see the chapter Reference Design for a description of the Main bus interface.
- Test DDRs/FLASH/Reigsters/FPGA Interconnect

### 1.1 Main Window

The main USB Controller window has the following components: a menu bar, a refresh button, a "Disable USB" button, and board graphic, and a message log. Each item in the menu bar is described later in this section.



Figure 13 Main USBController window

### 1.1.1 Refresh Button



The Refresh button updates the board graphic by querying the DN9002K10PCIE8T and reading back its status. The USB Controller program does not poll the board, and only updates the status when there is some user command. Items that may be updated when the refresh button is hit are:

- Type of board connected (DN9002K10PCIE8T in this case)
- Number of FPGAs installed
- Whether or not the FPGAs are configured (blue DONE LED on/off)
- Whether the Dini Group reference design is loaded in one or more FPGAs (disable/enable the "FPGA Reference Design" menu)
- Check whether USB is enabled

### 1.1.2 Disable/Enable USB



To communicate to the FPGA design using USB, the "Main Bus" interface is used. See the hardware chapter for more information on this interface. Some users elect not to use the Main Bus for USB communication. To allow these users to make use of the signals in the Main Bus for their own purposes, the USB Controller is careful not to use the Main Bus unless explicitly given permission by the user. The user can give permission to use Main Bus by pressing the "Enable USB->FPGA communication" button. It can revoke that permission by pressing the "Disable USB->FPGA communication" button. When the DN9002K10PCIE8T powers on, it begins in the disabled state. The state is stored on the board, so that multiple programs accessing the DN9002K10PCIE8T may prevent each other from using the Main Bus.

### 1.1.3 Log Window

This text box prints the result of each user command in USB Controller. There is a "clear log" button to clear the contents of this text box.

### 1.1.4 Board Graphic

USB Controller's main window shows a graphic representing your DN9002K10PCIE8T. The number of FPGAs that are installed on your board should appear in this graphic. If one or more

FPGAs are configured on the board, a blue LED will glow next to the FPGA in this graphic window, just like on the actual board hardware itself.

If the USB Controller could not find a DN9002K10PCIE8T connected to any USB port, this window will appear.



If the board is turned on and plugged in, the USB Controller should be able to detect it. If it does not, try opening the Device manager. You can right-click on the "My computer" icon and select "Hardware tab" and click the "Device Manager" button. This will display a list of the devices connected to your computer. If a Dini Group Product FLASH Boot appears in the USB section, then USB is working properly on the board, but the program is unable to connect to it. Select "Switch Device" from the File menu. If the board does not appear in the Hardware manager, then the DN9002K10PCIE8T may be stuck in reset. See the "Troubleshooting" section in the Hardware chapter. Also, check the red "Reset" LED.

As well as providing visual feedback, the board graphic can be used to control configuration of the FPGAs. To do this, right-click on an FPGA in the graphic to show a contextual menu with the options: Configure, Clear and reconfigure.



Configure will show an Open... dialog for you to select the bit file you wish to use with the FPGA. Clear FPGA will clear and reset the FPGA of its current configuration. Reconfigure

FPGA will configure the FPGA with whatever bit file that *this instantiation* of USB Controller used to configure that FPGA last.

# 1.2 Menu Options

The following sections describe each menu option and its function.

#### 1.2.1 File Menu

The File Menu has the following options:

**Open** – opens a file with the selected text editor (notepad by default). To change the text editor see Settings/Info Menu section

**About** – Displays USB Controller version number, along with other things.

**Switch device** – Displays a list of all Dini Group USB devices detects and allows the user to switch the "current" device. The USB Controller will behave as if the "current device" is the only attached Dini Group USB product. Under some situations, the USB Controller may automatically switch device when the "current device" is not valid.

Exit – Closes the USBController application

#### 1.2.2 Edit Menu

The Edit Menu performs the basic edit commands on the command log in the bottom half of the USBController window.

Copy, delete, and select all

### 1.2.3 FPGA Configuration Menu

The FPGA Configuration Menu has the following options:

**Refresh Window** – this menu option is equivalent to hitting the "Refresh" button in the main window. It queries the board and updates the graphic for visual feedback.

Configure Via USB (individual) – this menu option allows you to configure an FPGA. It is equivalent to selecting an FPGA by clicking on it and selecting "Configure", except that this menu option will display a dialog asking which FPGA to configure. Before any FPGA is configured in USB Controller, a "sanity check" is performed. This reads the header out of the binary bit file and determines whether the bit file is compatible with the FPGA installed on the DN9002K10PCIE8T. It will prevent configuration if the "sanity check is not passed" This check can be disabled from the "Settings/Info" menu.

**Configure via USB (using file)** – this command allows the user to configure more than one FPGA over USB at a time. To use this option you must create a setup file that contains information on which FPGA(s) should be configured and what bitfiles should be used for each

FPGA. The syntax of this file is similar or identical to the syntax of the CompactFlash main.txt interface. Details are found in the USB Controller manual on the user CD at

D:\USB\_Software\_Applications\USBController\doc\USBController\_Manual.pdf

**Configure via CompactFlash** – this command causes the FPGAs to configure based on the instructions in the main.txt file on the CompactFlash card. It will also cause the commands and settings on the main.txt file to be re-issued.

Clear All FPGAs – this command resets all FPGAs, causing them to lose their configuration.

**Reconfigure All FPGAs** – this menu command is equivalent to selecting "reconfigure FPGA" in the context menu of each of the FPGAs. Each FPGA is cleared before being configured. The last bit file that was loaded via USB for each FPGA is loaded again into the FPGA. If an FPGA has not been loaded with a bit file using *this instance* of USB controller, it is skipped.

**Reset** – this command asserts the RESET# signal to all FPGAs simultaneously. This is the same signal that is asserted when the user hits the "Soft Reset" (User Reset) button. Its function in the user design is left for the user to define. In the reference design, it causes a global, asynchronous reset. This option also causes the SYS\_RSTn signal on the daughtercards to be asserted.

### 1.2.4 FPGA Reference Design

- Single Ended Interconnect Test (slow) this menu option will run test single ended test on selected FPGAs.
- Read FPGA Clock Frequencies
   This menu option measures and reads back the frequencies of the eight global clock networks, and displays them on the message log.
- Read DDR I2C Data
   This menu option readback DDR2 information

### **1.2.5 Main Bus**

The way that user FPGA designs can communicate over USB is the "Main Bus" interface. The "Reference design" menu uses the main bus to read and write registers in the reference design to control the board tests. These tests can be done by the using these menu options without the user having to understand the Main Bus interface or the main bus memory space and it's mapping to the reference design. The Main Bus menu allows direct control of the Main Bus. This can be useful if you are using your own FPGA core that implements the main bus.

Write and Read DWORD
 this displays a dialog box for writing and reading to the Main Bus address space. It includes some debugging features. All main bus transactions are of length 4 bytes (DWORD)

### • Test Address Space

This writes and reads random data to the address range specified in a dialog box, and prints and error message when the read and write do not match.

### Read Address Space to file

this reads data from the main bus at the address specified, and writes the data to a binary file specified. Data on the main bus is in little-endian order. The address after each DWORD is implicitly incremented. This behavior can be turned off (contact support)

### • Write Address space from file

this reads data from a file and writes the data to the address on main bus specified. The data is written in little-endian order. The address is implicitly incremented after each DWORD of data. This behavior can be changed (contact support)

### • Send Command File

this read data from file name \*.do or \*.txt with following format:

AD <hex value>: Address

WR <hex data>: Data to write

RD <hex expected data>: read back data and compare to expected value.

### 1.2.6 Settings/Info Menu

### (1) Change Text Editor

This option changes the behavior or "Open" in the file menu and is otherwise undocumented.

#### (2) FPGA Stuffing information

displays a list of the FPGAs on the board, and their type and speed grade. This information is stored in the firmware flash, and is not detected on the fly.

#### (3) Turn fans on/off

This command cannot be used with the DN9002K10PCIE8T

### (4) Board/Spartan/MCU version

this option is used to read the version number of the current board's firmware. There are two types of firmware, the "Flash" and the "Prom". The two types of firmware, the reference design, and the USB Controller application are only guaranteed to work when using corresponding versions of each. If you update one, you should update the others.

#### (5) Read FPGA temperatures

Displays the current temperature of the on-die FPGA temperature sensors.

#### (6) Force Memory Menu display

When the Dini Group reference design is not loaded in at least one FPGA, the "FPGA Reference Design" menu is disabled. This menu command causes that menu to be displayed in this situation. The USB Controller determines if the Dini Group reference

design is loaded by reading a memory location on Main Bus and comparing the result to a predetermined value. This menu may also be disabled because the "USB->FPGA Communication" is disabled.

### (7) Toggle Sanity Check

This menu command changes the behavior of configuration where it reads the header in the binary bit file and determines if the file is compatible with the installed FPGA. This may be necessary if using bitstream encryption or using a custom bitfile not created by ISE 8.2 bitgen.

- (8) Setup clock frequencies this menu option displays a dialog box allowing the three global clock networks to be configured.
- (9) Global clock muxes setup This menu option display a dialog box allowing to select with output for global clocks and External clocks

### 1.2.7 Production Tests

(1) Test DDR2

this menu option displays a dialog box allowing testing of the DDR2 sockets on the DN9002k10PCIe8T. If the Dini Group reference design is not loaded, the command will automatically load them into the FPGAs. If the clocks are not set, the command will automatically set them to settings compatible with the DN9002K10PCIE8T reference design.

(2) One Shot Test

this menu option tests various functions on the board, automatically configuring the FPGAs and setting up the clocks as required.

# 1.2.8 Unsupported Features

If you somehow discover these features, they are not intended for customer use.

### 1.3 INI File

Some command considered "debugging" commands save persistence information in an ".ini" file that gets created in the same directory as the USB Controller executable. This file should not be generated for most users. If it is generated, you can safely delete it, unless you like it. Some of the settings that can be stored in this file are the Text Editor Selection settings, the location of (path to) the reference design programming files (for one-shot-test), and enabling the debug menu.

### 2 AETest USB

# 2.1 Compiling AETest usb

AETest\_usb can be compiled using Microsoft Visual Studio 6 or later, or on any version of Linux that supports the usbdevfs library.

A make file is provided, but you must un-comment one of the following lines to define which operating system you are running. In Windows, you should run nmake.

#DESTOS = WIN\_WDM #DESTOS = LINUX #DESTOS = SOLARIS

### **2.1.1 Cygwin**

Nope. VS6 only.

# **3 PCIe AETEST Application**

AETEST utility program can test and verify the functionality of the DN9002K10PCIE8T Logic Emulation board, and provide data transfer to and from the User design.

All AETEST source code is included on the CD-ROM shipped with your DN9002K10PCIE8T Logic Emulation kit. AETEST can be installed on a variety of operating systems, including:

Windows 2000/XP/Vista (Windows WDM) Linux

# 3.1 Functionality

All communication to the board using this program is over PCI express. In this way, the basic functionality of PCI Express is tested.

The AETEST utility program contains the following tests:

DMA and BAR accesses over PCI Express (When using the full function deisgn for LXT)

DDR2 Memory Test

Flash Test

Daughter Card Test (requires special fixture that we didn't give you).

AETEST also provides the user with the following abilities:

Recognize the DN9002K10PCIE8T

Display Vendor and Device ID

Set PCIe Device and Function Number

Display all configured PCIe devices

Various loops for PCIe device-function and ID numbers

Write and Read Configuration DWORD (for board settings)
Access to the "Main Bus" interface
BAR Memory operations
Configure/Save BARs from/to a file
Configure FPGAs.

# 3.2 Running AETEST

The following images show a terminal session in Windows XP.



The initial display of AETest shows the results of its scan of the PCIe bus. If the driver for the DN9002K10PCIE8T is not installed, then the software will display a message that no device was found.

# 3.3 Compiling AETEST (PCIe)

# 3.3.1 Compiling AETest for Windows XP

AETest for Windows requires visual studio 6 or later to compile.

Open the provided make file and uncomment the lines #DESTOS = WIN\_WDM Run nmake.

## **3.3.2 Cygwin**

Nope.

# 4 Rolling Your Own Software

Most customers who need to use USB or PCIe as a data interface to their FPGA designs write their own USB and PCIe controller programs, since the USBController and AETest programs do not meet their requirements.

### **4.1 USB**

The behavior of the DN9002K10PCIE8T with regard to the USB interface is given in the Hardware chapter.

### **4.2 PCIe**

The host software requirements to interface with the DN9002K10PCIE8T over PCIe are given in the Hardware chapter.

# 5 Updating the Firmware

Dini Group may release firmware bug fixes or added features to the DN9002K10PCIE8T. If a firmware update is released you will need to download this new code to the firmware flash of the DN9002K10PCIE8T. There are three firmware files that Dini Group may release: EEPROM\_FLP.iic for EEPROM; firmware.hex for FLASH and prom\_flp.mcs for Spartan PROM

The first firmware update is for EEPROM, which stands for Electrically Erasable Programmable Read-Only Memory. The Firmware Mode is booted from here. This firmware is rarely changed. Please consult with us before updating this device.

The second firmware update is Micro Controller (MCU) software that is stored in a flash memory. The User Mode is booted from here. This update can be accomplished easily from the USBController or AEtest\_USB application.

The third update that may be required is a Spartan FPGA core update. The configuration data for the Spartan FPGA is contained in a Xilinx configuration PROM. This update can be accomplished with the Xilinx JTAG programming or iMPACT programs. Either the Xilinx Platform cable USB (\$199) or the Xilinx Parallel cable IV (\$125) will help the updating faster.

If you don't have Xilinx cable and wish to update Spartan prom, you can use USBController or AEtest\_USB to program it through USB. You have to contact us for \*.xsvf file.

When updating the firmware, the "Flash", "PROM" and USBController.exe should all is updated simultaneously, since Dini Group only verifies this code using corresponding versions of each.

# **5.1 Obtaining the updates**

The firmware update files are not posted on the web site. In order to obtain them, you must request them from <a href="mailto:support@dinigroup.com">support@dinigroup.com</a>. You may be required to perform a firmware update to your board to receive support and some features. When updating firmware, you should update in the following order:

- 1) USB Controller.exe (http://www.dinigroup.com/product/common/USBController.zip)
- 2) Configuration FPGA PROM firmware
- 3) EEPROM (option)
- 4) MCU Flash
- 5) LTX Bitfile (hex file)

# 5.2 Updating the Spartan (PROM) firmware 5.2.1 Using JTAG cable (Xinlinx products)

Connect a Xilinx Platform USB configuration cable to your computer. When the cable is working properly, but not connected to a JTAG chain, the LED on the cable turns amber. When connected to the DN9002K10PCIE8T, the LED turns green.

Connect the cable to the "Firmware" header, J9



Figure 14 Firmware Update Header

Power on the DN9002K10PCIE8T; When the Platform USB cable is connected to a header, the status light turns green.

Open the Xilinx program Impact, usually found at Start->Programs->Xilinx->ISE->Accessories->impact

iMPACT Project Dialog will appear, please hit Cancel.

Choose the menu option File->Initialize Chain.

Impact should detect 2 devices in the JTAG chain: XC3S1000 and XC18V04. For each item in the chain Impact will direct you to select a programming file for each. For the XC3S1000, Press Bypass. Impact will then ask for a programming file to program the XC18V04 device, select the Spartan Firmware update file provided by Dini Group. This file should be named "prom\_flp.mcs". Hit Open.



Figure 15 Impact Window

To program the prom, right-click on the prom and select "Program..." from the popup menu. In the options dialog that follows, the options "Erase before programming" should be selected, and "Verify" should be selected. Press OK. The programming process should take about 15 seconds over "Xilinx platform cable USB."

Power cycle the DN9002K10PCIE8T. The new firmware is now loaded. You can close impact and disconnect the Xilinx JTAG cable

### 5.2.2 Using USBController

If you do not have a JTAG cable, you will need to use the following instructions to update your "Spartan PROM" firmware. This update is dependent on USBController and Flash firmware version. Please double check with us (<a href="support@dinigroup.com">support@dinigroup.com</a>) to make sure that your current version (MCU version, USBController) supports this option and request \*.xsvf file from us.

- 1. Open USBController.ini and add the line "service\_mode=1". You save and close the file.
- 2. Launch USBController, go to "Service" menu and select "Program/Update Spartan". A warning message will appear to ensure that you want to update Spartan. If you do, hit "Yes" button.
- 3. Open file Dialog will appear. Please select the \*.xsvf file that we provide you.
- 4. After selecting file, there will be debug level dialog. Please select debug level: 0
- 5. The process takes about 10-15 minutes, please leave the board and USBController alone. The process bar is on the bottom of USBController window.
- 6. When the execution is finished, power cycle the board.

### 5.2.3 Using AEtest\_USB

If you do not have a JTAG cable, you will need to use the following instructions to update your "Spartan PROM" firmware. This update is depending on AEtest\_USB and Flash firmware version. Please double check with us (<a href="mailto:support@dinigroup.com">support@dinigroup.com</a>) to make sure that your current version (MCU version, AEtest\_USB) supports this option and request \*.xsvf file from us.

- 1. Run aeusb\_wdm.exe (or aeusb\_linux).
- 2. At the main menu, please select option 3 "FPGA Configuration Menu"
- In "Flash Boot Menu", please select option '9'. Note: the option menu is not displayed for security purpose.
- 4. Please enter the full path filename for the \*.xsvf file.
- 5. Verbose level is '0'. The higher verbose level, the slower the program runs.



Figure 16 aetest\_usb window

- 6. The progress will start from 0 to 100%. This will take long time to complete (10 minutes). Please do not disturb the process.
- 7. Power cycle the board when finish.

You can also use commend line: "aeusb\_wdm\_cmd.exe -XSVF <filename.xsvf>" (or "aeusb\_linux\_cmd.exe -XSVF <filename.xsvf>").

# **5.3 Updating EEPROM firmware (not recommend)**

To protect against accidental erasure, the EEPROM firmware cannot be updated unless the board is put in firmware update mode during power-on. Find Switch S2 ("User Reset") on the DN9002K10PCIE8T.



Figure 17 Switch S2

Hold down the "User reset" button while the DN9002K10PCIE8T powers on. Or alternately, while holding down the "User reset" switch, press the "Hard reset" button. The DN9002K10PCIE8T samples the user-reset button on power on to enter into firmware update mode.

### 5.3.1 Using USBController

- 1. Put the board into Firmware Mode (see 5.3)
- 2. Open USBController.ini and add this line "service\_mode=1", save and close the file.
- 3. Run USBController. "Update Flash" dialog will appear, please select "NO" because we are doing update EEPROM
- 4. Go to "Service" menu, select "Program EEPROM". This Process will take about 1 minute. Please hit OK
- 5. Select file EEPROM\_FLP.iic. When USBController completes the update, please power cycle power the board.

### 5.3.2 Using AETest\_USB

- 1. Put the board into Firmware Mode (See 5.3)
- 2. Run aeusb\_wdm (aeusb\_linux). Select option 3 "Firmware Menu".
- 3. In EEPROM Boot Menu, please select option 1 "Update EEPROM from <filename>.iic file"
- 4. Enter filename (full path). The process should take about 2 minutes



Figure 18 aeusb\_wdm window

5. Please power cycle the board.

You can also run this on the commend line: aeusb wdm cmd.exe -EEPROM <filename.iic>

# 5.4 Updating the MCU (Flash) firmware

To protect against accidental erasure, the MCU (Flash) firmware cannot be updated unless the board is put in Firmware Mode during power-on (see 5.3). You can either use USBController or AEtest\_USB program to update MCU (Flash) firmware.

### **5.4.1 Using USBController**

- 1. Put the board into Firmware Mode (see 5.3)
- 2. Run USBController.exe, Flash Update dialog will appear, please select "Yes".
- 3. Please select firmware.hex (we provide you this file).
- 4. When finish, please recycle power the board or hit "Hard Reset" (S3) on the board to boot from User Mode.

### 5.4.2 Using AETest USB

- 1. Put the board into Firmware Mode (See 5.3)
- 2. Run aeusb\_wdm. Select option 3 "Firmware Menu".
- 3. Please select option 2 "Update Flash from <firmware>.hex"

- 4. Enter the full path filename. It should be firmware.hex that we provide you
- 5. The process will take about 2 minutes. When it finishes, please hit "Hard Reset" (S3) on the board or recycle power the board so that DN9002K10PCIE8T can boot from User Mode.

Figure 19 aeusb\_wdm window

You can also run this on the commend line: "aeusb\_wdm\_cmd.exe -FLASH <filename.hex>" (aeusb\_linux\_cmd.exe -FLASH <filename.hex>").

# 5.5 PCI Express Endpoint Firmware

Although the provided configuration files for the LXT "Q" FPGA on your board (responsible to the PCI Express endpoint) are known to be perfect in every way, Dini Group may release updates to add features or fix bugs in the PCI Express endpoint. In this case, Dini Group will provide a programming (.hex) file to reprogram the LXT FPGA. This information is stored in an SPI flash device on the board.

## 5.5.1 Using JTAG USB cable (Xilinx products)

To install this updates, plug the USB JTAG cable into the header marked "FPGA JTAG" on the left edge of the board.



When you scan the JTAG chain, you will see the entire user FPGAs of device type LX110, LX220 or LX330. In addition, the last device in the chain will be either a LX50T or FX70T device. Right click on this device and choose "select configuration file..." Dini Group will provide a file possible called "FPGA\_Q.bit". Select that thing. Then, right click on the last device again and select "add SPI or BPI prom..." Then select a firmware file that might be called "fpga\_q.mcs" that Dini Group will provide. The program will then for some reason ask for what type of prom you have. The correct answer is "AT48DB642D". Now, the picture with the six FPGAs will have a little picture of an SPI prom attached to the last FPGA. Right click on this, and hit "configure". Then wait a little while.

The SPI prom that is connected to the LX50T FPGA is where the LX50T FPGA gets its load file. The LX50T FPGA can be programmed directly (using a .bit file), but then it will lose its configuration once the board is reset. When you program the SPI flash, it will keep its configuration when the board is reset. A .bit file is used to program an FPGA; a .mcs file is used to program a SPI flash. You can use the Xilinx program Impact to generate an .mcs file from a .bit file. The SPI flash can also be updated using USB Controller. When using this method, a .hex file is required.

To generate an .mcs file from a .bit file: in Impact, select "generate prom file" and open the provided .bit file. It will ask what the target device is, and it is an SPI Flash of type AT42DB642D. Then double-click generate.

To generate an .hex file from an mcs file. Use the Xilinx program promgen promgen -w -p hex -r mcsfilename -o outputfilename

### **5.5.2 Using USBController**

You can either generate .hex file from .bit file or contact <a href="mailto:support@dinigroup.com">support@dinigroup.com</a> for new .hex file. Please plug in USB cable and turn the board on.

- 1. Open USBController.ini and add "service\_mode=1". Save and close the USBContrller.ini file
- 2. Lauch USBController.exe, the Service menu should be selectable.
- 3. Select "Service"->"ProgramV5TProm", select \*.hex file
- 4. The status bar will be on the bottom of the window. The process takes about 1-2 minutes. Please recycle power the board.

### 5.5.3 Using AETest\_USB

You can either generate .hex file from .bit file or contact <a href="mailto:support@dinigroup.com">support@dinigroup.com</a> for new .hex file. Please plug in USB cable and turn the board on.

- 1. Run aeusb\_wdm.exe (aeusb\_linux.exe). Select option '3' (FPGA Configuration Menu)
- 2. Select optin '8' (Load V5T Prom with filename.hex), and enter the file name .hex
- 3. The process takes about 1-2 minutes.

# **Chapter 4: Hardware**

# 1 General Overview

The DN9002K10PCIE8T ASIC emulation platform is optimized for providing the maximum amount of interconnect between the Virtex-5 FPGAs. It is the highest-density off-the-shelf development board using the Xilinx Virtex-5 FPGA.

Below is a block diagram of the DN9002K10PCIE8T.



# 1.1 Marketing

The following is the advertised feature list of this board. This manual is responsible for providing the information necessary to use these features.

### 1.1.1 Features

Prototyping system with one or two Xilinx Virtex-5 FPGAs XC5VLX110, XC5VLX220, or XC5VLX330 (1760-pin package)

100% FPGA resources available for user application:

- PCIe core not required for PCIe use
- Configuration and clocks are controlled off-FPGA DDR2 and Ethernet do require FPGA cores.

Nearly 4M ASIC gates (LSI measure) with 2 LX330s

FPGA-to-FPGA interconnect is single-ended or LVDS up to 900Mbs.

DDR2 SODIMM slot Connects to FPGA B 64-bit data width, 200MHz operation DDR2 modules: PC2-3200/PC2-4200

4GB maximum density per SODIMM (when available)

aggregate data transfer rate: 32GB/s

Nine board-level global clock networks (G0, G1, G2, MB48, EXT0, EXT1,P75,FBA,FBB) Three separate programmable synthesizers (configurable via CompactFlash, USB, PCIe) Global clocks networks distributed differentially and balanced Two single-step clocks
Four external differential clock inputs. (Two daughtercard and two SMA cables)

Flexible customization via daughter cards Two 400-pin Meg-Array connectors (FCI) One connected to FPGA A, one to FPGA B 93 LVDS pairs + clocks (or 186 single-ended) Some Daughtercard signals require LX330 devices 400MHz (DDR so 800Mbs) on all signal pairs Supported IO Voltages: 1.5V, 1.8V, 2.5V, 3.3V Power-over-header

Built-in FPGA configuration Compact Flash, PCIe, USB, JTAG Configuration Readback supported

One tri-mode Ethernet interface (FPGA B)

RS232, Logic Analyzer, LEDs. Support

www.dinigroup.com

# 2 Virtex 5

The DN9002K10PCIE8T allows use of each of the new features of the Virtex-5 FPGA. As well as exercises all of the external interfaces on the DN9002K10PCIE8T, the included reference design also exercises all of the new (Compared to Virtex 4) Virtex-5 features listed below.

- Greater speed logic and internal routing speed
- Built-in PLLs

Example PLL usage found in the DDR2 reference design

- 1.25 Gbs maximum IO speed

LVDS design uses high-speed IO (900Mbs currently)

- ODELAY output signal delay elements

LVDS design dynamically adjusts IDELAY to account for interfaces on the DN9002K10PCIE8T where signals are not externally length-matched (FPGA interconnect)

- 6-input lookup tables
- Larger total-density parts (in terms of total LUT gates)
- More flexible IO

# **3 Configuration Section**

Many functions on the DN9002K10PCIE8T are done by circuitry on the DN9002K10PCIE8T external to the FPGA. Collectively, these circuits are referred to in this document as the "Configuration Section". The configuration section takes care of:

CompactFlash interface
USB interface
PCIe interface
"Main Bus" interface master
Temperature sensing
Over/under voltage sensing
Clock frequency and source configuration
SelectMap configuration interface
Blinking red and green LEDs

The Configuration Section is built around a Spartan 3 FPGA and Cypress microprocessor. These ICs are used by the configuration circuit and are not intended for user design. The code running these controlling ICs is collectively referred to as the "firmware". The code for this firmware is provided, for reasons I don't know. Customer development efforts on these platforms are not supported. If you need special configuration circuit behavior, please contact Dini Group and request that we implement it and support it as a standard feature. The technical details of the configuration circuit are omitted from this manual, since the user should not require it.

# 3.1 Configuration Section Feedback

During normal operation, and in error situations, the configuration section prints messages to the RS232 terminal header. The configuration section processes that can be monitored using this header are:

Temperature sensor: FPGA overheat CompactFlash card reading USB configuration PCIe configuration Main Bus reads/writes Global clock settings





The configuration section RS232 terminal header, labeled "MCU" above, can be connected to a computer serial port, using the settings:

19200 Baud No flow control One stop bits No parity The syntax and content of the output messages changes are not given because they change rapidly. This interface is not at all fun to use, and is intended mostly for Dini Group to debug hardware or software failures.

# 3.2 FPGA Configuration

Normally, configuration of the Virtex-5 FPGA occurs over the Virtex-5 "SelectMap" interface. The only configuration method possible on the DN9002K10PCIE8T that does not use this interface is JTAG. For a description of the SelectMap interface, see the Virtex-5 configuration guide.

Typically, the user will supply a "bit" file generated by ISE, and put it on a CF card, or supply it to software over PCI or USB, and the user does not have to understand the SelectMap interface.

USB, CompactFlash and PCIe configuration occur over the SelectMap bus. The configuration section makes no modification of the "bit stream" sent to it over PCIe or USB. It only copies the data to the SelectMap interface. The "bit stream" must contain all of the SelectMap commands necessary to configure and startup the FPGA. These SelectMap commands are created automatically by Xilinx tool bitgen (part of ISE). Not all of the bitstream generation options available in bitgen are compatible with the DN9002K10PCIE8T:

Currently, before configuring the FPGA using any method (except JTAG), the configuration section asserts the PROG# signal of the FPGA to clear it. For this reason, the "disable SelectMap" option in bitgen has no effect.

On each FPGA, the DONE signal is connected to a blue LED located next to each FPGA. This signal gives a quick indication of whether each FPGA is configured or not.

The data signals, D [7-0] are dual-purpose signals and can be used as additional interconnect pins after all FPGAs have been configured. Care must be taken that the FPGA design does not drive these signals until after all FPGAs have been configured. The configuration section will assert the FPGA\_RESET# signal until this occurs (CompactFlash configuration only). If you do use the SelectMap data signals as interconnect, the provided software (USB Controller) is not guaranteed to function properly (may interfere with your design). When using these signals as interconnect, the appropriate drive standard is LVCMOS25. The IO voltage is 2.5V

The data signals D [8-15] are not used by default, and can be used by the design for interconnect between FPGAs.

SelectMap Readback is possible on the DN9002K10PCIE8T. This can be accomplished over PCIe or USB. The user interface for obtaining this data is not defined. If you need this feature contact the Dini Group.

The JTAG configuration method does not go through the configuration circuit. See the JTAG interface section for details about this.

### 3.3 USB and PCIe interfaces

The USB and PCIe interfaces can be used for both configuration (FPGA configuration, and clock settings, etc.) or for direct communication with the user design in the FPGA. These interfaces are described individually in their own sections in the hardware chapter.

# 3.4 CompactFlash Interface



Most important settings on the DN9002K10PCIE8T can be controller through the Compact Flash interface. This interface can also be used to configure FPGAs. The CompactFlash interface is not under the direct control of the user, but is accessed only by the configuration logic.

### 3.4.1 Main.txt

The main txt interface is the primary method you will use to control settings on the DN9002K10PCIE8T. From this interface, you can

- -Configure FPGAs
- -Set clock frequencies
- -Write to MainBus

Other settings on the DN9002K10PCIE8T can also be controlled via the main.txt file by accessing the configuration registers, using the MEMORY MAPPED command.

To use the main.txt interface, create a file called main.txt on the root directory of the Compact Flash card. Plug the card into the DN9002K10PCIE8T. The DN9002K10PCIE8T will execute commands contained within this file when the board powers on, when the Hard Reset button is pressed, or when instructed to do so by the USB interface (vendor request).

A main.txt file contains a list of commands, separated by newline characters. A list of valid main.txt commands is given below.

// <comment>

FPGA A: <filename>
FPGA B: <filename>
FPGA Q: <filename>

CLOCK FREQUENCY: 0 <number> [MHz] CLOCK FREQUENCY: 1 <number> [MHz] CLOCK FREQUENCY: 2 <number> [MHz]

SOURCE: G0 2 SOURCE: G1 2 SOURCE: G2 2

SANITY CHECK: <yn>
VERBOSE LEVEL: <level>

MEMORY MAPPED: 0x<SHORTADDR> 0x<BYTE>
MAIN BUS 0x<WORDADDR> 0x<WORDDATA>

- <comment> can be any string of characters except for newline.
- <filename> can be the name of a file on the root directory of the CompactFlash Card.
- <number> can be any positive number in decimal. Decimal points are allowed.
- <yn> can be the letter y or the letter n
- <level> can be 0,1,2 or 3
- <SHORTADDR> is a 2-digit number in hexadecimal (16 bits)
- <BYTE> is a 1-digit number in hexadecimal (8 bits)
- <WORDADDR> 4-digit (32 bit) number in hexadecimal representing a main bus address
- < WORDDATA > 4-digit (32 bit) number in hexadecimal containing data for a main bus transaction

The following table describes the function of each of the available main.txt commands.

| Instruction                       | Function                                                                                                                                                                    |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| // <comment></comment>            | The configuration circuitry performs no operation and moves to the next command.                                                                                            |
| VERBOSE LEVEL:<br><level></level> | This command will set the amount of output that will be produced over the RS232 port during configuration. When level is set to 0, the port will produce only error output. |
| FPGA A: <filename></filename>     | The Virtex 5 FPGA "A" will be configured with the file named by <filename></filename>                                                                                       |

| FPGA B: <filename></filename>                             | The Virtex 5 FPGA "B" will be configured with the file named by <filename></filename>                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FPGA Q: <filename></filename>                             | The Virtex 5 FPGA "Q" will be configured with the file named by <filename></filename>                                                                                                                                                                                                                                                                                                                                                                                                                      |
| SANITY CHECK: <yn></yn>                                   | If <yn> is set to y, then the MCU will examine the headers in the .bit files on the CompactFlash card before using them to configure each FPGA. If the target FPGA annotated in the .bit file header is not the same type as the FPGA the MCU detects on the board, it will reject the file and flash the error LED.</yn>                                                                                                                                                                                  |
|                                                           | Before this command is executed, <yn> is set to the default value y.</yn>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                           | If you want to encrypt of compress your bit files, you will need to set <yn> to n.</yn>                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MAIN BUS 0x <wordaddr> 0x<worddata></worddata></wordaddr> | Writes data in <worddata> to the address on the main bus interface at <wordaddr>. This command only makes sense in the context of the Dini Group reference design, unless your design implements a compatible controller on the main bus pins. The Specification for this interface is in MainBus section</wordaddr></worddata>                                                                                                                                                                            |
| MEMORY MAPPED: 0x <shortaddr> 0x<byte></byte></shortaddr> | Writes to a configuration Register. This command can be used to access features that do not have a main.txt command. Example applications include setting clock sources, settings the EXTO or EXT1 clock buffers to zero-delay mode, or setting the clocks to frequencies lower than 31MHz.                                                                                                                                                                                                                |
| SOURCE: G0 2<br>SOURCE: G1 2<br>SOURCE: G2 2              | The SOURCE instructions cause the global clock networks to output a clock from an alternate source. When source of G0 is set to "2", then the global clock G0 becomes a step clock, which can be accessed through config register 0xDF23. When source of G1 is set to "2", the global clock network G1 becomes a step clock which can be toggled by writing to config register 0xDF23. When Source of G2 is set to "2", then the source of the G2 clock network becomes FPGA A, using the "FBACLK" signal. |

| CLOCK FREQUENCY:        | The MCU will adjust the clock synthesizer producing clock   |
|-------------------------|-------------------------------------------------------------|
| <clockname></clockname> | <clockname> to the frequency <number>.</number></clockname> |
| <number> MHz</number>   |                                                             |
|                         |                                                             |
|                         |                                                             |
|                         |                                                             |
|                         |                                                             |
|                         |                                                             |
|                         |                                                             |

Figure 20 Main.txt Commands

An example main.txt file is given below.

#### **VERBOSE LEVEL:0**

 $\ensuremath{/\!/}$  This will prevent the MCU output over RS232 to speed up configuration

**FPGA A:a.bit** 

//this will load the configuration a.bit into FPGA A CLOCK FREQUENCY: G0 300MHz

MAIN BUS: 0x08000000 0x00000001

//Writes to a register in FPGA A.

Even if you are not planning to configure your Virtex 5 FPGAs using a CompactFlash card, you may want to leave a CompactFlash card in the socket to automatically program your global clock. (Clocks may also be programmed using the provided USB application, or over the PCIe bus.)

### 3.4.2 Hardware

The Compact Flash interface is hot-swappable.

An activity LED, DS147, located next to the Compact Flash slot indicates activity on this interface.

Please contact <a href="mailto:support@dinigroup.com">support@dinigroup.com</a> if you find an incompatible card, so that we can add software support for it.

Also, the board only accepts CompactFlash cards formatted in the FAT file system. Most new compact flash cards come pre-formatted with the FAT32 file system. In this case, the DN9002K10PCIE8T will not be able to recognize files on the card.

# 3.5 Configuration Registers

The configuration control on the DN9002K10PCIE8T is controlled by setting "configuration registers". Basically, these are just locations in the memory space of the on-board micro controller that controls the board's function. A full description of the function of this micro controller is omitted, but some of the registers in this space are required to be accessed over USB or PCIe to control the board. For information on how to access this address space over USB or PCIe, see the corresponding section in this chapter.

| REGISTER         | ADDRESS | FUNCTION                                                  |
|------------------|---------|-----------------------------------------------------------|
|                  |         | Bit0 is for G0, Bit1 is for G1, Bit2 is for G2. Setting a |
|                  |         | bit to "1" will cause the global clock network G0, G1     |
|                  |         | or G2 to use its "alternate" source. For G0 this is step  |
|                  |         | clock 0, for G1, this is step clock 1. For G2, this is    |
| CLOCK SOURCE     | DF16    | FPGA A.                                                   |
| FPGA_RESET       | DF22    | Write 0x2 to hold reset. 0x0 to release                   |
| G0 FREQUENCY LO  | DFC0    | Sets the divider value of G0                              |
| G0 FREQUENCY HI  | DF30    | Sets the 8442 multiplier of G0                            |
| G1 FREQUENCY LO  | DF31    | Sets the 8442 divider value of G1                         |
| G1 FREQUENCY HI  | DF32    | Sets the 8442 multiplier of G1                            |
| G2 FREQUENCY     | DF33    | Sets the 8442 divider value of G2                         |
| G2               | DF34    | Sets the 8442 multiplier of G2                            |
|                  |         | When high, each bit causes the configuration circuit to   |
|                  |         | update the represented clock frequency with the           |
| UPDATE_CLOCK_FLA | L       | current M and N values. 0x01 is G0, 0x02 is G1, 0x04      |
| G                | DF40    | is G2                                                     |
| FPGA_COMMUNICAT  | I       |                                                           |
| ON               | DF39    | Disables Main Bus interface                               |
| TEMP_SENSOR_A    | DF50    | Temperature of FPGA A                                     |
| TEMP_SENSOR_B    | DF51    | Temperature of FPGA B                                     |
| SERIAL_NUMBER    | DFFA    |                                                           |
| BOARD_TYPE       | DFFE    |                                                           |

### 3.5.1 Undocumented controls

Most of the accessible registers to control board function (used by the AETest\_usb and USB Controller programs) are not documented in the table above. This is because we do not anticipate a need for customer use. If there are board features that are accessible through USB Controller or AETEST programs that you feel you need access to in your own PCIe or USB applications, contact <a href="mailto:support@dinigroup.com">support@dinigroup.com</a> and we will provide details on using the interface you require. A list of these features is provided below

G0, G1, G2 frequencies below 31 MHz Single-step clocking on G0, G1, G2 clock networks. Zero-Delay Daughtercard clock network External clock source selection Readback of G0, G1, G2 frequency measurements MainBus error counter

### 3.6 Firmware

A Spartan 3 FPGA and a Cypress micro controller control the configuration circuitry. The programming data for the FPGA is stored on a flash device, and the code for the micro controller is stored on a separate flash device. The instructions for updating the firmware are given in the software section. The flash that stores the Spartan FPGA programming information is made available via a JTAG header, which can be used with the Xilinx program impact. The Dini Group does not recommend doing any sort of development on this FPGA, because if you add custom code, you will not be able to use firmware updates from Dini Group without merging it with your custom code.

### 4 Clock Network

### 4.1.1 GC Pins

When this manual refers to a "clock input" of an FPGA, it means the "GC" pin described in the Virtex-5 user manual. These pins have the capability of driving a DCM, PLL, or BUFG input with a known (accounted for) delay within the FPGA.

### 4.2 Global Clocks

All of the "global clock networks" on the DN9002K10PCIE8T are LVDS, point-to-point signals. The arrival times of the clock edges at each FPGA are phase-aligned (length-matched on the PCB) within about 100ps. These clocks are all suitable for synchronous communication among FPGAs.

Since LVDS is a very low voltage-swing differential signal, you cannot receive these signals without using a differential input buffer. Single-ended inputs will not work. An example Verilog implementation of a differential clock input is given below.

```
Wire aclk_ibufds;
IBUFGDS G0CLK_IBUFG (.O(g0clk_ibufg), .I(GCLK0p), .IB(GCLK0n));
always@(g0clk_ibufg) begin
// Registers
end
```

Either in the UCF or using a synthesis directive, you should turn the DIFF\_TERM attribute of the IBUFGDS to TRUE. This is recommended because there are no external termination resistors on the DN9002K10PCIE8T.

All global clock networks have a differential test point. The positive side of the differential signal is connected to pin 1 (square) and the negative side is connected to pin 2 (circular).



A diagram of the global clock network is shown above. Each of the eight clock outputs of the clock network is distributed to both FPGAs.

# 4.3 G0, G1, G2 Clocks

The G0, G1 and G2 clocks are the primary clock resource for your FPGA design. Each of these clocks can be set to a wide range of frequencies between 0.125 MHz and 550 MHz.

On the schematic, these signals are named  $CLK_G*_*p$ 

where \* is 0,1 or 2 and \* is the name of the FPGA connected to that signal.

The possible source of G0 and G1 clock is either Si5326 synthesizer or a "step clock". The "step clock" is driven by the configuration circuit and can be toggled over USB or PCIe by writing to the correct configuration register. 0xDF23[0], 0xDF23[1]. Before the Synthesizer or step clock drives the network, the correct source setting must be made in the GUI or in the main.txt file. By default the source is the synthesizer.

The configuration register that sets the source of the clocks is at location 0xDF16. bit 0 corresponds to G0, bit 1 corresponds to G1 and bit 2 corresponds to G2. To change the source to the stop clock, write a '1 to the bit location corresponding to the clock network. Then write a '1 to the bit corresponding to the clock network in the "update" register, 0xDF40. Writing to this register will cause a glitch in the clock.

www.dinigroup.com

From the compact flash card, source can be set by using the source instruction:

```
source: G0 2 # sets G0 to step clock 0 source: G1 2 # sets G1 to step clock 1 source: G2 2 # sets G2 to "feedback A"
```

In USB Controller, from the settings menu, select DN9002K10PCIE8T clock source settings

The possible sources of the G2 clock are the synthesizer, or FPGA A (using the CLK\_FBA\_INT signal. FPGA drives this 3.3V, LVCMOS clock signal. From the USB Controller program you can select CLK\_FBA\_INT from the settings->DN9002K10PCIE8T clock source dialog. This setting can also be achieved over PCIe or USB, using the "configuration registers".

### 4.3.1 Clock Synthesizers

The G0, G1, and G2 clock synthesis source is driven by an si5326 clock synthesizer chip. This chip is capable of driving a wide range of output frequencies. The "configuration register" that allows selecting the output frequency supports each multiple of 0.125MHz up to 550MHz. If the desired frequency is between one of these steps, or in the Khz range, then you will have to use a compact flash card to set the frequency.

On the provided compact flash card there is a table giving the command to set a clock to any of a large number of intermediate frequencies. The main.txt syntax is

Source: G1 1 
$$<$$
a $>$   $<$ b $>$   $<$ c $>$   $<$ d $><$ e $>$ 

Where <a>, <b>, <c>, <d> and <e> are arbitrary parameters given in the table. The correct value of the five parameters for select frequencies are given below.

| 96999<br>48499<br>44035 |
|-------------------------|
|                         |
| 44035                   |
| 77033                   |
| 22453                   |
| 21651                   |
| 13455                   |
| 15787                   |
| 9997                    |
| 9185                    |
| 9699                    |
| 11547                   |
| 10777                   |
| 7015                    |
| 5613                    |
| 4849                    |
|                         |

| # | 0.150000 MHz 0  | 4041   | 79   | 4  | 4041 |    |
|---|-----------------|--------|------|----|------|----|
| # | 0.176400 MHz 3  | 72667  | 2516 | 3  | 3927 |    |
| # | 0.192000 MHz 4  | 3157   | 124  | 4  | 3157 |    |
| # | 0.220000 MHz 7  | 1377   | 74   | 4  | 2755 |    |
| # | 0.325000 MHz 3  | 13857  | 479  | 3  | 2131 |    |
| # | 0.440000 MHz 7  | 1377   | 74   | 4  | 1377 |    |
| # | 0.455000 MHz 3  | 13857  | 479  | 6  | 1065 |    |
| # | 0.880000 MHz 7  | 1377   | 74   | 0  | 1377 |    |
| # | 1.843199 MHz 4  | 15791  | 624  | 3  | 375  |    |
| # | 2.457600 MHz 4  | 15791  | 624  | 3  | 281  |    |
| # | 3.276800 MHz 4  | 47487  | 1874 | 3  | 211  |    |
| # | 3.579545 MHz 5  | 7909   | 351  | 2  | 225  |    |
| # | 3.686399 MHz 4  | 15791  | 624  | 3  | 187  |    |
| # | 4.096000 MHz 7  | 2303   | 124  | 7  | 107  |    |
| # | 4.194304 MHz 6  | 36307  | 1790 | 6  | 115  |    |
| # | 4.433617 MHz 6  | 49867  | 2462 | 0  | 273  |    |
| # | 4.915200 MHz 7  | 2303   | 124  | 7  | 89   |    |
| # | 6.144000 MHz 4  | 631    | 24   | 1  | 157  |    |
| # | 7.372799 MHz 4  | 15791  | 624  | 3  | 93   |    |
| # | 8.192000 MHz 7  | 2303   | 124  | 7  | 53   |    |
| # | 8.867238 MHz 1  | 2153   | 52   | 7  | 49   |    |
| # | 9.216000 MHz 7  | 2303   | 124  | 7  | 47   |    |
| # | 9.830400 MHz 4  | 15871  | 624  | 4  | 61   |    |
| # | 10.160000 MHz   | 2      | 507  | 14 | 6    | 47 |
| # | 10.245000 MHz 3 | 23221  | 799  | 3  | 67   |    |
| # | 11.059200 MHz 7 | 2303   | 124  | 7  | 39   |    |
| # | 11.228000 MHz 5 | 5613   | 249  | 5  | 47   |    |
| # | 11.289600 MHz 3 | 3611   | 124  | 1  | 85   |    |
| # | 12.288000 MHz 7 | 2303   | 124  | 7  | 35   |    |
| # | 14.318181 MHz 3 | 2549   | 87   | 6  | 33   |    |
| # | 14.745599 MHz 7 | 2303   | 124  | 7  | 29   |    |
| # | 16.384000 MHz 4 | 383    | 14   | 6  | 29   |    |
| # | 16.934400 MHz 5 | 14111  | 624  | 5  | 31   |    |
| # | 17.734475 MHz 0 | 190485 | 3735 | 2  | 45   |    |
| # | 17.900000 MHz 0 | 6085   | 119  | 4  | 33   |    |
| # | 18.432000 MHz 7 | 2303   | 124  | 7  | 23   |    |
| # | 19.200000 MHz 4 | 383    | 14   | 4  | 31   |    |
| # | 19.440000 MHz 5 | 269    | 11   | 1  | 49   |    |
| # | 19.531250 MHz 1 | 31249  | 767  | 1  | 49   |    |
| # | 19.660800 MHz 4 | 15871  | 624  | 0  | 61   |    |
| # | 22.118400 MHz 7 | 2303   | 124  | 7  | 19   |    |
| # | 24.576000 MHz 7 | 2303   | 124  | 7  | 17   |    |
| # | 26.562500 MHz 1 | 3909   | 95   | 0  | 45   |    |
| # | 32.768000 MHz 4 | 383    | 14   | 1  | 29   |    |
| # | 33.330000 MHz 7 | 605    | 31   | 1  | 29   |    |
|   |                 |        |      |    |      |    |

| # | 38.880000 MHz 5  | 1133   | 49   | 5 | 13 |
|---|------------------|--------|------|---|----|
| # | 66.660000 MHz 7  | 403    | 19   | 6 | 7  |
| # | 74.175824 MHz 7  | 6749   | 363  | 7 | 5  |
| # | 76.800000 MHz 4  | 383    | 14   | 4 | 7  |
| # | 77.760000 MHz 5  | 575    | 24   | 4 | 7  |
| # | 98.304000 MHz 4  | 383    | 14   | 1 | 9  |
| # | 122.880000 MHz 4 | 383    | 14   | 6 | 3  |
| # | 124.416000 MHz 5 | 575    | 24   | 6 | 3  |
| # | 133.330000 MHz 0 | 26665  | 479  | 6 | 3  |
| # | 155.520000 MHz 5 | 575    | 24   | 4 | 3  |
| # | 156.256000 MHz 4 | 9765   | 374  | 4 | 3  |
| # | 159.375000 MHz 1 | 509    | 11   | 4 | 3  |
| # | 160.380000 MHz 7 | 485    | 24   | 4 | 3  |
| # | 161.130000 MHz 0 | 10741  | 199  | 4 | 3  |
| # | 161.132800 MHz 4 | 50353  | 1874 | 4 | 3  |
| # | 164.360000 MHz 3 | 1173   | 39   | 1 | 5  |
| # | 166.630000 MHz 0 | 33325  | 639  | 1 | 5  |
| # | 166.667000 MHz 0 | 333333 | 6399 | 1 | 5  |
| # | 167.331600 MHz 5 | 92961  | 3999 | 1 | 5  |
| # | 172.640000 MHz 0 | 2157   | 39   | 1 | 5  |
| # | 173.370000 MHz 3 | 11557  | 399  | 3 | 3  |
| # | 176.100000 MHz 3 | 1173   | 39   | 3 | 3  |
| # | 176.840000 MHz 3 | 8841   | 299  | 3 | 3  |
| # | 184.320000 MHz 4 | 671    | 24   | 3 | 3  |
| # | 195.312500 MHz 3 | 6249   | 191  | 3 | 3  |
| # | 311.010000 MHz 3 | 2961   | 99   | 4 | 1  |

# **4.4 Ext Clocks**

There are two clock networks on the DN9002K10PCIE8T that are designed to provide clocks from an external frequency reference EXT0 and EXT1. Each of these clocks is delivered synchronously to all 2 FPGAs and is suitable for synchronous communication among the FPGAs.

#### 4.4.1 EXT0

This clock can be sources from either the external clock input SMAs connectors or daughtercard A.

By default, EXT0 is set to be sourced from the daughtercard A. The source setting can be made from the USB Controller by selecting settings->DN9002K10PCIE8T clock source.

To make the setting from the compact flash card, in the main.txt file, use the MEMORY MAPPED: command to write to the EXT0 register 0xDF27 or the EXT1 register 0xDF28. The register bit map is as follows:

0xDF28[4:0] = S23, S1, S0, PLLSEL, CLKSELWrite value 0x02 to select the daughtercard Write value 0x01 to select the FBA clock.

#### 4.4.2 EXT1

This clock can be sourced only from daughtercard B. By default, EXT1 is set to be sourced from the daughtercard B.

## 4.4.3 Daughtercard zero-delay mode

EXT0 and EXT1 can be set to zero-delay mode, where each FPGA is able to receive the clock synchronous to the daughtercard. This feature requires configuring the clock distribution network with the frequency of the clock. The interface by which the user can do this is not defined. Contact <u>support@dinigroup.com</u> if you require this feature.

Before you attempt to implement this daughtercard clocking method, consider using the DCA and DCB clock pins on each daughtercard to directly clock the daughtercard's associated FPGA, rather than to drive the global network.

## 4.4.4 SMA input

The EXT0 clock can be sourced from a pair of SMA inputs, J11, J13. These SMAs connectors are designed to connect to a differential clock source.



The inputs are AC-coupled. This limits the minimum possible frequency of the clock input to around 4 kHz. If you require an external clock with a frequency lower than this, you should modify the board by removing the 4.7uF resistors shown above and replacing them with 0-ohm resistors. The maximum recommended swing on the differential inputs is 3.3V.

To connect a single-ended clock source, you can connect to one of the SMA connectors, and leave the other unconnected. The other side of the signal is properly biased.

## 4.5 PCIe Refclock

A clock network driven from the FPGA "Q" is called "REFCLK". When the Dini Group PCI Express endpoint bitfile is loaded into the FPGA "Q", and the board is linked to a motherboard over PCI Express, then this network will be driven with a 250MHz clock which is equal to 250/100 times the PCI Express REFCLK in frequency.

The clock is a differential LVDS signal which should be received on each FPGA with a differential clock input buffer with DIFF\_TERM set to enable.

# 4.6 Non-Global Clocks

The following sections describe clocks that are not considered "global" because they do not distribute to both FPGAs on the board. These clocks may be used for specific interfaces and details on the clocking required for those interfaces are found in a different section in the hardware chapter.

#### 4.6.1 Clock TP

Each FPGA is connected to a two-pinned test point. This test point can be used to input a differential clock from off-board. Each of these test points has a 100-Ohm jumper installed shorting the negative and positive signals. To input or output differentially, you must remove this resistor.



The schematic clipping above shows FPGA B's the schematic clipping



This signal can also be used as an external feedback path for a DCM. When connecting the output of a DCM to K14, the DCM FB input can be connected to K15. Using this configuration, output flip-flops connected to CLK0 of the DCM will have an effective clock-to-out time of less than zero.

#### 4.6.2 Ethernet Clock

The VSC8601 Ethernet PHY device outputs a 125MHz clock. The signals in the schematic are CLK125\_ETH. This signal is LVCMOS25, single-ended signals. The frequency is fixed. Details about appropriate clock methodology for the Ethernet interface is in the Ethernet section.

#### 4.6.3 DDR2 Clocks

The CK signals in the DDR2 interface are described in the DDR2 interface section.

#### **OUTPUTS**

CLK\_DIMMB\_CK2p AC33 CLK\_DIMMB\_CK2n AD32

## **INPUTS**

CLK\_DIMMB\_CK2p AM28 CLK\_DIMMB\_CK2n AN28

Note that on the netlist, these signals connect to the FPGA twice: once on the DDR2 interface bank (1.8V), and once on the global clock input bank (2.5V). The 2.5V, clock bank connections should be used as inputs and the 1.8V bank signals should be configured as outputs. For input signals, use the LVDSEXT standard with the DIFF\_TERM attribute set to TRUE.

### 4.6.4 SMA Clock A

FPGA A has a pair of SMA connector connected directly to global clock inputs (AM28, AN28). The bank connected to these signals is a +2.5V bank. Allowed input standards are LVCMOS25, SSTL25, LVDS, and DIFF\_SSTL18.





These connections are DC-coupled, meaning the user must ensure that the levels received on this input are within the limits of the Virtex-5 device to prevent damage to the part.

This pair of SMA connectors can also be used as outputs, as single-ended inputs or for non-clock signals.

# 5 Test points

This section lists all of the test points on the DN9002K10PCIE8T. A more detailed description may be found in the section about the system that the test point is part of, but all test points are listed here for reference.

### **5.1 Power Thru-hole**

Each power rail requiring more than 100mA on the DN9002K10PCIE8T has a dedicated test point associated with it. This test point is a through-hole, two-pin location, where pin one is the power rail, and pin two is a ground connection. These test point locations are suitable for supplying at least 2A, regardless of the power requirements or capabilities of the power net.





Pin one is a square. Pin two is circular.

| TP14 | 0.9V_B |
|------|--------|
| TP16 | 1.0V_A |
| TP18 | 1.0V_B |
| TP23 | -12V   |
| TP10 | 1.8V   |
| TP9  | 2.5V   |
| TP22 | 1.2V   |
| TP15 | 3.3V   |

TP7

Power for the -12V, +5.0V and +3.3V nets are generated off-board.

These test-points are suitable for wiring to if power is needed off-board for some reason or maybe you need to bring power in from an external source.

# **5.2 Power TP**

5.0V

The following test-points are located along the left edge of the board, next to an LED associated with that power net. These test points are square pads. They are not suitable for supplying power to the board, or off the board.

# **Power Fail LEDs**





The test point reference designator is not visible on the silkscreen of the DN9002K10PCIE8T. Instead, there is a label indicating which power net the test point is connected to. These test points are connected by thin traces that are not capable of conducting more than 100mA of current. You should only use these test points for probing. For noise measurements, it is better to use the test points next to each power supply.

## **5.3 DIMM Power**

As described in the DDR2 Interface section, provisions have been made for the use of  $\pm 2.5 \text{V}$  modules in the memory sockets of the DN9002K10PCIE8T. To allow this, a jumper point is provided for each DDR2 memory power net.



The DN9002K10PCIE8T comes with a jumper installed in each of the "1.8V" test points, shorting the DIMM power supplies to the +1.8V power supply.

1.8V 2.5V DIMM

TP12 TP13 B JP1 1.8V\_ADJ

If you require power on any DIMM other than +1.8V, you must remove the installed jumper and instead install a different jumper to connect the DIMM power to +2.5V. If you require

+3.3V on this power net, no jumper point is provided, and you will have to run a wire.

# 5.4 "GC" Test points

Each FPGA is connected to a two-pin test point for debugging purposes. This test point is the same as the ones used for the "Power Thru-hole" test points. Each test point is connected to a "GC" pin on the FPGA, meaning it can be used as a differential clock input to the FPGA. By connecting a reference voltage to the "N" pin (circular), this test point can be used to input a single-ended signal.



TP21 A TP20 B

Note that the signals connected to either side of these test points are shorted together by a 5-ohm resistor. This connection allows the use of external clock feedback. If you need to use these test points as two separate IOs, this resistor would have to be removed.

The reference design uses this connection for external clock feedback. The register is calleed "TPP"

# **5.5 Clock Test points**

Each of the "Global clock" networks has a test point. These points are not length-matched with the global clock network, so there may be some phase offset between this point and the FPGA input.



All of test points output LVDS signaling. LVDS test points have the "p" signal connected to pin 1 (square) and "n" connected to pin 2 (circular).

A 100-ohm resistor connects the P and N side of these clock signals. This is excellent for probing with a high-impedance probe, but not so good for connecting wires. You can remove this resistor if needed.

# 5.6 DIMM Signals

Some key signals on each DDR2 interface are connected to test points for debugging. The test point pad used is the same as on the "Power TP" test points.

The test points are not labeled with their reference designators. Instead, they are labeled with the signal name.



# 6 USB interface

The DN9002K10PCIE8T allows the user FPGA to communicate to a host PC over USB. The configuration circuitry allows this by bridging USB to the Main Bus interface. For most users, implementing USB communication will be as simple as making a Main Bus controller. In the reference design, there is an example Main Bus controller. See the Main Bus section of this chapter for more information on the Main Bus.



USB on the DN9002K10PCIE8T also allows control of the configuration circuitry from a host PC. This includes configuring FPGAs, setting clock frequencies and others

This section will describe the software interface required to communicate to the DN9002K10PCIE8T. In addition to reading this section, you may choose to modify the provided software (USB Controller and AETest\_usb). The source code for these programs is on the user CD. These programs collectively implement all of the available controls on the DN9002K10PCIE8T.

# 6.1 Connecting to the DN9002K10PCIE8T

Depending on the operating system, there are different methods of obtaining a software handle to the DN9002K10PCIE8T in order to access it from software.

#### 6.1.1 Windows XP

What driver is this? It's the EzUSB driver.

```
HANDLE handle = CreateFile("\\\.\\Ezusb-0", GENERIC_WRITE, FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, NULL);
```

The "EzUsb-0" device name is registered with Windows when installing the EzUSB device driver. The .ini file provided with the driver causes the driver to be assigned to any USB device with VendorID=0x1234 and ProductID=0x1234.

The HANDLE object returned by CreateFile is suitable for use with DeviceIoControl().

#### 6.1.2 Windows Vista

Testing was not complete at print time. support@dinigroup.com

#### 6.1.3 Linux

To use USB in Linux, use the provided usbdrvlinux.c file provided on the user CD in AETest\_usb/driver

Connecting to the device occurs using the driver's usb open function.

int handle =  $usb_open(0x1234, 0x1234, 0)$ ;

#### **6.1.4 Communication**

The USB interfaces that the DN9002K10PCIE8T presents are separated into two types: The Vendor requests, and the Bulk Transfers. All other types of USB transactions are not supported. The vendor requests are low-bandwidth control signals used for controlling the board settings. The Bulk Transfers are used for configuring and reading back FPGAs and reading and writing to the main Bus interface.

# **6.2 Vendor Requests**

Most of the "control" functions available over USB are accomplished using a "vendor request". Programming a USB vendor request is out of the scope of this document, but you can copy the code provided in the USB Controller program.

The following table describes the USB interface presented to the host by the MCU micro controller.

| Vendor Request Name                        | ID   | Description                                                                                                                                                                          |
|--------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VR_GET_FLASH_REV                           | 0xA6 | Returns a revision code of the "MCU" firmware                                                                                                                                        |
| VR_GET_FPGA_INFO                           | 0xA7 |                                                                                                                                                                                      |
| VR_CONFIG                                  | 0xAF | Causes MCU to go through configuration sequence (Media Card)                                                                                                                         |
| VR_CHECK_FPGA_CONFIG                       | 0xB5 | Returns a string representing if the selected FPGA is configured                                                                                                                     |
| VR_SET_EP6TC                               | 0xBB | Sets the size of the bulk transfer (Read) buffer. You must set this to a value equal to the SIZE field of the USB Bulk transfer                                                      |
| VR_SETUP_CONFIG                            | 0xB7 | This vendor request must be called to select an FPGA for configuration prior to a bulk transfer containing the configuration stream for that FPGA.                                   |
| VR_END_CONFIG                              | 0xBD | This vendor request de-selects an FPGA after configuration and returns the configuration status of that FPGA (DONE signal)                                                           |
| VR_MEM_MAPPED (Config Read) (Config Write) | 0xBE | This vendor request reads or writes to the address space of the MCU. This vendor request can be used with the configuration register map above to accomplish any configuration task. |
| VR_CLEAR_FPGA                              | 0x90 | Clears the selected FPGA of configuration data.                                                                                                                                      |
| VR_BOARD_VERSION                           | 0xB9 | Returns a byte representing the type of board                                                                                                                                        |

Each vendor request has a direction, request type, request, and value, size and buffer pointer fields. The request type is always TYPE\_VENDOR. The request field is the ID listed in the table above. The value and data in the buffer pointer fields are vendor-request specific. The size field is the number of bytes in the buffer. The details of how to implement a vendor request are outside the scope of this manual.

www.dinigroup.com

### 6.2.1 VR\_CLEAR\_FPGA

This vendor request clears an FPGA.

Direction is OUT. Size is 0. Value represents which FPGA should be cleared. 0 is FPGA A. 1 is FPGA B... and so on.

### 6.2.2 VR SETUP CONFIG

This vendor request must be called before sending configuration data to an FPGA. It tells the DN9002K10PCIE8T which FPGA should receive the next configuration stream sent over USB. It also clears that FPGA of its current configuration.

Direction is OUT. Size is 1. In the buffer is a number representing which FPGA should be selected. 0 is FPGA A, 1 is FPGA B, 2 is FPGA C... and so on.

## 6.2.3 VR\_END\_CONFIG

This vendor request de-selects and FPGA (so that configuration data sent will go to no FPGA) and checks the configuration status of an FPGA.

## **6.2.4 VR\_SET\_EP6TC (Read buffer size)**

The SetReadBufferSize vendor request must be used before any "bulk read" bulk transfer. This sets the size (in bytes) of the data that will be requested by the bulk transfer. If this vendor request is not sent before the bulk read, the behavior is undefined.

The direction is OUT. The size is 0. The value is the number of bytes required for the next bulk transfer.

# **6.2.5 VR\_MEM\_MAPPED (Configuration Registers)**

Some of the controls on the DN9002K10PCIE8T do not have their own Vendor Request. These functions include setting the clock frequencies. In order to accomplish these tasks, you must use the "Configuration Registers". The full list of registers is in the "Configuration Section" section. To write to a configuration register, use the VR\_MEMORY\_MAPPED vendor request.

The direction is OUT. The value field is the address you wish to write to (example 0xDF39, the disable Main Bus register). The size field should be 1. The buffer should contain a single byte containing the byte to be written to the Configuration Register. All configuration registers are one byte.

### **6.2.6 Other Vendor Requests**

Many of the Vendor requests used by the USB Controller program are not documented. Dini Group does not support these requests for users. If you need a function that you feel is not described here, contact <a href="mailto:support@dinigroup.com">support@dinigroup.com</a>

#### **6.3 Main Bus accesses**

The USB Controller control the DN9002K10PCIE8T reference design using USB vendor requests and bulk transfers that access the configuration FPGAs registers. These registers cause

"Main Bus" transactions with the user FPGAs. The host computer initiates all Main Bus transactions. To see a specification of the Main Bus interface, see *Reference Design*.

To request a Main Bus interface write transaction, the USB Controller program sends a USB bulk write to EP2 (endpoint 2). The first byte contains a code, either 0x00 or 0x01, determining whether the next 4 bytes contain an address or a datum. If this byte is a 0x00, the next 4 bytes in the bulk transfer are stored into an address register. All data transferred to and from the main bus is LSB first. The address 0x12345678 should be sent as a bulk transfer of 5 bytes: 0x00, 0x78, 0x56, 0x34, 0x12. To send a datum, send the code 0x01, followed by 4 bytes, LSB first. When the DN9002K10PCIE8T receives a data word, it sends it onto the main bus interface to the address in the address register. It then increments the address register. Therefore, to send two words over main bus, 0x000000001 to address 0x00000001 and 0x000000002 to address 0x000000002, the USB Controller would send the following 15 bytes to USB EP2:

Note that the number of bytes sent to EP2 must be divisible by 5.

To request a main bus read operation, the USB Controller sends a USB bulk write to EP2 to set the address register, as described in the above paragraph. Then, the USB Controller sends a bulk read to EP6 (endpoint 6), with the USB bulk request SIZE field set to the number of bytes requested. The number requested must be divisible by 4. After the bulk read is complete, the address register is incremented by SIZE/4. Read and write transactions use the same

Before starting a USB read using a bulk transfer, you must tell the DN9002K10PCIE8T how many bytes are going to be read by using the VR\_SET\_EP6TC (0xBB) vendor request described in the *Vendor Requests* section.

# **6.3.1 Important Note about Endpoints**

There is only one endpoint that the user should use: endpoint 2. Note that an endpoint is bidirectional. Using the driver that Dini group provides, the endpoint and direction fields are stuffed within the same byte. To write to endpoint 2, this byte should be 0x02. To read, it should be 0x08. Some people refer to these as uni-directional endpoints 2 and 8.

#### 6.3.2 Performance

Main Bus over USB runs at a maximum speed of 80Mbs for reads, and 32Mbs for writes. These numbers assume that the FPGA operates the Main Bus interface with zero wait cycles. If the FPGA design has more wait cycles, this speeds decreases. The approximate speed of Main Bus over USB is given below as a function of Main Bus wait states.

| 0 cycles | 80Mbs read | 32Mbs write |
|----------|------------|-------------|
| 1 cycle  | 76Mbs read | 31Mbs write |
| 5 cycles | 64Mbs read | 29Mbs write |

| 30 cycles  | 32Mbs read | 16Mbs write |
|------------|------------|-------------|
| 100 cycles | 13Mbs read | 11Mbs write |
| 250 cycles | 6Mbs read  | 5Mbs write  |

# **6.4 FPGA Configuration**

The following procedure is used by software on the host computer to configure an FPGA over USB. This procedure is followed by the USBController program and AETest\_usb program on the user CD.

- 1) USB Software gets a handle to a USB device with VID 0x1234 PID 0x1234.
- 2) USB host software sends vendor request VR\_SETUP\_CONFIG 0xB7 (see *Vendor Requests*) with 1 byte in the data buffer representing which FPGA to configure. (A is 0x01, B is 0x02, C is 0x03...)
- 3) The configuration circuit on receiving this vendor request asserts the PROG signal of the selected FPGA. This resets the FPGA and clears any configuration data it may already have. This Vendor request also selects the FPGA, so that SelectMap bus activity only affects the selected FPGA. Bulk transfers initiated after this command to endpoint 2 are interpreted as SelectMap transfers, rather than Main Bus transfers (See *Main Bus access* above). This will be so until vendor request VR\_SETUP\_END (0xBD) is called.
- 4) USB host software sends a bulk write USB request to EP2. Each byte of data in the bulk write is sent to the selected FPGA over the SelectMap bus, and the FPGA signal CCLK is pulsed once for each byte of data sent. Note that the LSBit in the USB transaction is sent to the LSBit in the SelectMap interface, so bit swapping as described in the Virtex 5 Configuration Guide is not required. A standard .bit file from Xilinx bitgen can be transferred in binary over this USB interface to correctly configure an FPGA on the DN9002K10PCIE8T.. Make sure CCLK is selected as the startup clock in the bitgen settings. This is the default setting.
- 5) After an FPGA configures, the DONE signal will go high, lighting the blue LED next to the FPGA (labeled "DONE").
- 6) The USB Controller sends a vendor request out VR\_SETUP\_END (0xBD). This request deselects the FPGA, so that further bulk requests are interpreted as Main Bus transactions.

#### 6.4.1 Readback

This section should be updated when Readback is enabled. If this sentence is here, it means this section has not been verified yet. When the DINI.H API is made available, this section should be removed completely.

Readback is performed in the same way that configuration, except that the direction of the bulk transfer is BULK\_READ instead of BULK\_WRITE. The commands required by the SelectMap interface to start a Readback must be sent using the configuration interface. For this

reason, it is the programmer's responsibility to understand and implement the SelectMap protocol.

### 6.5 USB Hardware

The actual hardware associated with performing USB communication with the DN9002K10PCIE8T is briefly described here. Since the user is not required to understand how to operate the hardware from the FPGA, much detail is omitted.

# 6.5.1 Cypress CY7C68013A

A Cypress Micro controller (MCU) with a built-in USB controller provides the USB interface of the DN9002K10PCIE8T. For a low-level understanding of the way the DN9002K10PCIE8T communicates over USB, you should see the Cypress CY7C68013A datasheet. The driver that Dini Group provides is the free Cypress EzUSB driver, with customizations to the corresponding .ini file to identify the board as a "Dini Group Emulator" product.

As with all USB devices, communication with the DN9002K10PCIE8T is initiated by the host (PC) and can be either a USB "vendor request" or "Bulk transfer". All other types of USB transactions are not supported or documented with the DN9002K10PCIE8T. In general, Bulk transfers are used for high-bandwidth data and vendor requests are used for all other control functions.

#### **Bulk Transfer Functions:**

Configure FPGA (SelectMap) Readback FPGA (SelectMap) MainBus read MainBus write

Vendor requests can contain short (512Byte) messages in either direction, and cause the MCU to execute code. In response to most vendor requests, the MCU will modify or read values in the Configuration memory space (see next section).

Since vendor requests can contain only a limited amount of data, USB Bulk transfers are used to send configuration data to the DN9002K10PCIE8T. The MCU is too slow to process USB 2.0 data at full speed, and so the bulk transfer data is sent to external pins on the Cypress MCU (see Cypress datasheet) and to the configuration FPGA (next section). Currently, this data is only used to configure FPGAs, and so the data is sent to the SelectMap pins of the Virtex 5 FPGAs.

To begin communication with the DN9002K10PCIE8T, the USB Controller program creates a USB connection object in the host operating system, by opening Vendor ID 0x1234 product ID 0x1234. (For the purposes of updating the firmware, the DN9002K10PCIE8T can come up in "EPROM" mode, where it loads a program capable of connecting over USB to a host, downloading firmware and writing it to the MCU flash memory, U201. The check the MCU makes on reset to determine which mode it should start in is the firmware update switch, S1 #4. This EPROM code is stored in the EPROM DIP installed in U203. When the MCU is in this mode, it registers itself to the operating system as Vendor ID 0x1234, product ID 0x1233. For

firmware update instructions, see *USB Software: Firmware Update*. For information about the MCU boot up sequence, see *Hardware: Configuration Circuit: MCU*)

The source code for the MCU firmware ("Flash") is provided in D:\Source Code\MCU\FLASH as a Keil Studios MicroVision 2.11 project file.

# 6.5.2 Activity LED

A yellow LED located next to the USB connector flickers when there is USB activity.

# **6.5.3 Configuration FPGA**

The MCU unit controls all of the configuration circuits on the DN9002K10PCIE8T, but it does not have sufficient IO to access all of the configuration signals. For IO expansion, the MCU's external memory bus is connected to a Virtex 5 LX40 FPGA. This FPGA provides a memory-mapped interface to all of its IO. This bus is called the 'Configuration Bus'.

The configuration FPGA is connected to all of the configuration signals of the Virtex 5 FPGAs, the temperature sensors, status LEDs, SmartMedia card, CompactFlash card, reset buttons, Main Bus switches, RS232 ports, clock synthesizer control signals, global clock multiplexer control signals, FPGA clock inputs, the Main Bus, and an 300-pin expansion header.

The source code for the Configuration FPGA is provided in D:\Source Code\ConfigFPGA this project can be compiled using Xilinx ISE version 7.1i SP4 or later. Your board may have been build using an LX80 FF1148 or an LX40 FF1148 for the configuration FPGA.

#### **6.5.4 Power**

The DN9002K10PCIE8T does not draw any power from the USB connector. Hot-plugging the DN9002K10PCIE8T is acceptable.

# **6.6 Troubleshooting**

If you cannot get USB to communicate with your design over Main Bus, please try using the USB Controller software with your design, and using the Dini Group reference design with your software. This will help determine whether the software or the hardware is causing the error.

#### **6.6.1 USB Controller Freezes**

The Vendor requests on the DN9002K10PCIE8T are blocking. Only one can be completed at a time. This includes vendor requests that take a very long time like "Configure from CompactFlash" (10 seconds). During this time USB Controller, a single-threaded application, freezes when any Vendor Request is issued. (All the time).

The only way to work-around this issue is to create a separate board-interaction thread.

# 6.6.2 Main Bus always returns 0x\_\_\_\_ (Error Codes)

#### 0xDEADDEAD

Main Bus timeout; The VALID signal on Main Bus was never asserted. See the Main Bus section for details. Your FPGA may not be configured.

#### 0x12345678

This error code may mean the "Enable USB->FPGA Communication" button in USB Controller has not be pressed (the Main Bus disable register is set)

#### 0xDEAD5566

this error code is returned by the Dini Group reference design when there is a Main Bus read to a register that is not defined (Default Main Bus output). This code is specific to the reference design.

#### 0xDEAD1234

this sentinel value should not be returned.

#### 0xABCDABCD

this error code is returned when a MainBus register corresponding to a memory is read, but the memory is not implemented in the Reference Design

# 7 PCIe interface

The DN9002K10PCIE8T can be installed in a PCIe slot. 16x or 8x slots are acceptable. The board will work in a 1x, 2x, or 4x slot, if you can physically manage to install them there (using an adapter such as the ones available from Catalyst enterprises).

The board can support 2.5Gb PCI Express 1.1-compliant signaling, or "Gen2" PCI Express 2.0 compliant signaling at 5.0 Gbs.

PCI Express interface is provided by FPGA Q, a Xilinx Virtex-5 LXT or FXT FPGA. For Gen 2 speeds, FX70T part is required.



Figure 21 - PCI Express block diagram

Normally, a user will place his PCI Express endpoint IP in FPGA Q, and his high-density logic in FPGA A. A large amount of interconnect is provided between FPGA A and Q to easily keep up with a full-speed, 8-lane PCI Express endpoint.

The user can provide his own PCI Express IP, he can use the Xilinx PCI Express endpoint hard macro, or he can use the free, provided "full function PCI Express endpoint now with DMA<sup>TM</sup>" core.

# 7.1 Host Interface, Electrical

The PCI Express signals from the host computer are connected directly to the LXT RocketIO IOs. As required by PCI express standard, the transmit signals (from the FPGA) are passed through ac-coupling capacitors. For fun, the receive signals (from the host) are also passed through ac-coupling capacitors.

The RocketIO requires a reference clock frequency to operate. On boards with an LX50T, this clock is provided on the MGTREFCLKP\_112 pin at 100 MHz. As required by Xilinx, this frequency is identical to the frequency supplied by the host connector on the PCI Express REFCLK signal. On boards with an FX70T, the clock frequency is instead 250 MHz, exactly 2.5 times the frequency of the REFCLK signal provided by the host connector.

When creating a core using the Xilinx PCI Express core generator, you must tell the wizard program the frequency of this clock, and to which pins it connects.

There is also a Synthesizer that can generate 100 or 250 MHz for use with RocketIO. This synthesizer is described in another section. Xilinx does not recommend synthesizing a reference clock frequency for use with PCI Express because it is not a supported use model.

The order of the lanes is as shown above. Oh, also none of the lanes have inverted polarity, and you are required to support that if you are writing your own PCI Express endpoint.

We can run the PCI SIG electrical compliance test for you if you want.



Figure 22 - PCI Express eye diagram

Here is the board installed with an FX70T passing the PCI Express electrical compliance test.

#### 7.1.1 Power

The DN9002K10PCIE8T current capacity greatly exceeds the maximum allowed power requirements for a PCIe card (35W). As a result, the external power cable is required for operation, regardless of whether the board is installed into a PCI Express slot. The only voltage that is required for operation is 12V. All other voltages used on the board are regulated from this source.

The DN9002K10PCIE8T is designed to operate in hot-plug environments; however, most motherboards are not hot-plug capable. (They do not shut off 12V and 3.3V power signals

when physical connections are lost). Therefore, a hot plug extender will be required for hot plug. Additionally we don't know how the provided "full function PCI Express endpoint now with DMA<sup>TM</sup>" will behave, or how the Xilinx PCI Express endpoint hard macro will behave.

#### 7.1.2 PCI-X

We assume you know the difference between PCIX and PCI Express. This board is designed to burst into flames when installed in a PCIX slot.

# 7.2 Host Interface, Mechanical

The form factor of the DN9002K10PCIE8T exceeds the allowable form factor for PCI Express in the vertical direction. This means that you will likely have to design the case for your system around the DN9002K10PCIE8T. Additionally, many "ATX" type computer cases do not fit the DN9002K10PCIE8T in the horizontal direction. If you are married to your computer case and motherboard, you can get one of these:

http://www.adexelec.com/pciexp.htm#PEX8LX

Otherwise, just get a case that fits the board.

# 7.3 Provided "Full-Function PCI Express endpoint"

Unless you need to prototype and test PCI Express logic, we recommend that you just use our provided PCI Express endpoint bit file. The provided bit file contains a high-speed implementation of the Xilinx PCI Express hard macro, adds a high-speed DMA engine, FPGA-initiated posting, implements high-speed IO between FPGAs A and Q at any frequency, allows PCI Express control of board functions such as configuration and clock settings, and comes with a working Windows and Linux driver. It will save you an approximate man month of work and writing and fully testing a custom implementation of a PCI Express Endpoint.



Figure 23 - Full function design block diagram

Access to FPGA A is through an allocation of memory space in the BAR regions of BAR1, 2, 3, 4 and 5.

BAR0 is used for control of the DMA engine, for MainBus accesses to all FPGAs, and for board control and FPGA configuration.

Two DMA channels allow communication to FPGA using the full PCI Express bus bandwidth.

The best resource for using this endpoint (both from a host software and FPGA implementation standpoint) is the document provided at

FPGA\_Reference\_Designs\common\PCIE\_x8\_Interface\pcie8t\_user\_interface\_manual.pdf

The BAR resources available are given below. These cannot be changed through any settings made available to the user.

Bar0: 0x0-0x1ff: PCI-E FPGA registers; rest is Configuration FPGA registers (8MB)

Bar1: 32-bit BAR, for User FPGA (8 MB)

Bar2-3: 64 bit BAR, for User FPGA (32MB)

Bar4-5: 64 bit BAR, for User FPGA (32MB)

By default, prefetch is turned off on 32-bit BARs it may be on for the 64-bit bars.

The back end (FPGA A) interface is fixed at 64-bit.

In a 32-bit addressing machine, it will appear as if BAR2 is configured as a 32-bit bar and BAR3 will not be implemented. BAR4 will appear as a 32-bit bar, and BAR5 will not be implemented.

### **7.3.1 BAR 0 Access**

The "Bar 0" accesses are reserved for board settings, FPGAs configuration and "Main Bus" communication. User-mode programs can access these registers to control the board from the PCI Host. Some of the useful offsets are given below:

| Byte  | Size | Name         | Description                                                        |
|-------|------|--------------|--------------------------------------------------------------------|
| 0x000 | 31:0 | Version      | Contains a version code for the firmware of LXT device (Read only) |
|       |      |              | * */                                                               |
| 0x008 | 31:0 | ID           | Always returns 0x4675_6C6C for "full function" design (Read only)  |
| 0x020 | 31:0 | DMA0         | Lower 32 bit byte address of physical address where the DMA0       |
|       |      | Base Address | descriptor chain starts. This address must have the lower bytes    |
|       |      |              | cleared to match the DMA0 Address Mask register.                   |
| 0x024 | 31:0 | DMA0         | Upper 32 bits of Base Address[63:0], to form a 64 bit address.     |
|       |      | Base Address | Set to 0 if using 32 bit addressing.                               |
| 0x02C | 31:0 | DMA0 Contro  | 1                                                                  |
| 0x030 | 31:0 | DMA0 Poll Im | nmediate                                                           |

www.dinigroup.com

| 0x040 | 31:0 | DMA1           |                                                                                     |
|-------|------|----------------|-------------------------------------------------------------------------------------|
|       |      | Base Address   |                                                                                     |
| 0x04C | 31:0 | DMA1 Control   | l                                                                                   |
| 0x050 | 31:0 | DMA1 Poll Im   | mediate                                                                             |
| 0x98  | 357  | Scratch Pad    | Read/Write space for user having fun and exercise Byte imaginations                 |
| 0x208 | 6:0  | Config Control | Selects and FPGA and returns the value of these FPGA's PROG, INIT and DONE signals. |
| 0x210 | 31:0 | Config Data    | Sends the given configuration word to the selected FPGA                             |
| 0x238 |      | FPGA Stuffing  |                                                                                     |
| 0x240 |      | Main Bus ADD   | DR .                                                                                |
| 0x248 |      | MainBus Write  |                                                                                     |
| 0x250 |      | MainBus Read   |                                                                                     |
| 0x258 |      | "Config Space" | Write                                                                               |

#### 7.3.2 BAR 1-5 Access

PCI Express reads and writes in the BAR1 – BAR5 memory space result in communication to FPGA A over the PCIE\_IN\* and PCIE\_OUT\* signals on FPGA A. This should be used in conjunction with the provided PCIe\_interface module in FPGA A.

See source code here:

D:\FPGA\_Reference\_Designs\common\PCIE\_x8\_Interface

#### 7.3.3 DMA Channels 0 and 1

There are two independent DMA controllers that are capable of descriptor chaining in the full-function endpoint. The register interface is described on the user CD in the documents at

D:\FPGA\_Reference\_Designs\common\PCIE\_x8\_Interface

It is best that you read the details there. Most users will not need to understand the control of DMA because the driver source code and binary in Windows and Linux is provided and works. There are two software interfaces to DMA.

#### 7.3.3.1 Scatter/Gather

The DMA controller is capable of fetching descriptors from the host memory, allowing the DMA engine to follow scatter/gather chains.

The driver hooks for this weren't written yet when I wrote this. You might have to call for an update.

#### 7.3.3.2 Large Buffers

In large buffers mode, the segment list is fixed and points to a ring of buffers in pre-allocated, locked driver memory space. The user has unsynchronized access functions that allow copying

to and from these fixed buffers. The DMA engines loop around the fixed buffers constantly completing the DMA on the buffers. The user has access to controls that turn on and off the DMA when not in use.

Example use of this code is provided in the AETEST program in the file pcie\_functions.cpp

#### 7.3.4 DMA Posted Mode

Posted mode allows the FPGA A to initiate DMA transactions to and from the host memory space. This mode is possible using the Dini Group full-function DMA endpoint, but is not enabled in the user interface module due to lack of interest. Contact us to get access to posted mode.

#### 7.3.5 DMA Main Bus

Main Bus is already pretty fast (100MB/s), however, if you really more over main bus then we can tell you how to do DMA on Main Bus. You might have to deal with synchronization issues on your own (read/write ordering).

### 7.3.6 Electrical

The electrical input and output characteristics are based on the PCI Express revision 1.1 and 2.0 requirements. The transmitted signal is slightly higher amplitude than that allowed by the specification in order to allow more flexible connection options (cabling or adapters) without compromising reliability. In addition, Pre-emphasis in the transceivers is set to ultra, which is not optimal, but will improve reliability in crappy systems.

If you need to pass PCI Express compliance electrical test with your board, please request the PCI Express compliance bit files from support. They are identical in function, but will pass compliance tests.

# **7.3.7 Timing**

The provided module for FPGA A takes care of the external interface timing, so you can probably skip this section.

When using the full-function PCI Express endpoint, a source-synchronous communication technique is used between FPGA A and FPGA Q. Since the FPGAs both have zero-hold-time inputs, the optimal phase alignment between clock and data is when they are perfectly in phase. Therefore, the clock for FPGA A (PCIE\_PCLK\_A) is driven from the IOs of FPGA Q in the exact same manner as the IOs, and the clock for FPGA Q (PCIE\_PCLK\_Q) is driven from FPGA A in the exact same manner as the IOs. On the board, the data and clock lines are all phase-matched.



Figure 24 - FPGA A to Q clocking diagram

Driving clocks from IOs is best accomplished using a ODDR flip-flop. If you don't know what I am talking about, there is a description of exactly what to do elsewhere in this manual.

#### 7.3.8 FPGA Interface

A Verilog module is provided that correctly implements the interface between the FPGA and the FPGA Q for PCI Express communication. The source for this module is provided on the user CD in the following location.

D:\FPGA\_Reference\_Designs\common\PCIE\_x8\_Interface\

A module, contained in the provided source file pcie\_x8\_user\_interface.v, is an implementation of the interface that must be included in the FPGA A user design.

The user ("FPGA") interface presents 6 separate interface ports: Target Write, Target Read, DMA R0, DMA R1, DMA T0, and DMA T1. The Target Write and Target Read interfaces share BAR and address lines, as target reads and writes cannot happen simultaneously. Each interface has its own "enable", "accept", and "data" ports. Read interfaces also have a "data\_valid" port. The "enable" signals are held active until the associated "accept" signal goes active. The "accept" signal for an interface may be tied high if it is guaranteed that transfers for that interface can be accepted every clock cycle (i.e. if the interface is connected to a block RAM). "Data\_valid" can be pulsed with the "accept" signal, or any time after- this allows reads to be pipelined.

For the purposes of simulation, a model of low synthesizability of the LXT is provided.

#### 7.3.8.1 **LED**s

Six LEDs are controlled by the PCI Express FPGA: Activity, Link1, Link4, Link8, and PERSTn, GEN2, and LOS

PERSTn directly shows the state of the PCI Express reset signal from the host. This is typically only during power-on. Activity is generated by the PCI Express FPGA whenever a packet is received. This signal on certain Intel-based hosts may blink constantly because of some mysterious configuration register read that gets generated all the time.

The Link1 LED will only be active when the PCI Express LED is communicating without error to a link partner, with a 1x negotiated lane width.

The Link4 LED will only be active when the PCI Express LED is communicating without error to a link partner, with a 4x negotiated lane width.

The Link8 LED will only be active when the PCI Express LED is communicating without error to a link partner, with a 8x negotiated lane width.

When the PCI Express LED has negotiated a 2x link, both Link 1 and Link8 will light. How did you manage to link in 2x mode? Send your interesting anecdotes to <a href="mailto:support@dinigroup.com">support@dinigroup.com</a>

The LOS LED will light when there is no receiver detected on lane 0, or when some other thing isn't working.

Gen 2 will light if the design has linked at 5.0 Gbs.

#### 7.3.8.2 FPGA-initiated DMA

The DMA controller is capable of issuing PCI Express transactions initiated from the FPGA A. The FPGA interface module does not have this interface exposed at the moment. Ask us how to do this.

### 7.3.9 Host Interface, Software

Example software capable of configuring FPGAs, communicating over MainBus and DMA transfers to FPGA A is provided (AETest). You may wish to copy this code and use it as a starting point.

To communicate with the DN9002K10PCIE8T, you will need to find the device on the PCIe Bus with VendorID=17DF and DeviceID=1900. The device will register itself with the operating system as "Dini Group ASIC Emulator with Virtex 5 PCI Express" (OS dependant).

Note that many Dini Group products use this vendor and device ID, so differentiating between boards requires you to read at a minimum, the board type register and the board serial number register.

#### 7.3.9.1 **Driver**

The source code for the DN9002K10PCIE8T's PCIe driver is provided.

#### Windows XP/Vista

Binaries for 32-bit windows, 64-bit windows (Itanium) and 64-bit windows (AMD/Pentium) are provided as a binary. Use the windows hardware manager to install these drivers. Source is provided, but shouldn't be required by most of you.

#### Linux

Source is provided for the linux driver. Compilation is probably required. (Provided binaries are unlikely to work). Also, source is only tested with the latest version of Linux, and may not be compatible with older version. To compile you will need the kernel source module installed on your computer. The executable created by the source is a kernel module which is loaded dynamically. A kernel module load script is provided.

#### DOS

Under DOS, only direct device access is supported. The DOS version of AETest program does not use a driver. You therefore need to figure out how to configure and access a device on the PCI subsystem. DMA is not supported.

#### **Solaris**

The Solaris driver does not support DMA.

#### 7.3.9.2 Configuration Register writes

Board settings (clocks, FPGA temperatures, etc.) can be changed over PCIe by accessing the "Configuration Register" interface. A description of the registers in this interface is in the Configuration Section of this chapter.

#### Writes

To write to a configuration register, write to BAR0, offset 0x258. Send a 32-bit word of data. This data is encoded as follows

Bits 31-16: "Configuration Register" address in (only addresses 0xDF00-0xDFFF are valid. See the "Configuration Register" map in the "Configuration Section" section)

Bits 15-8: Ignored

Bits 7-0: The Data value to write to the register

#### Reads

To read from a configuration register, read one byte from PCIe at an address within Bar0, encoded as follows:

Bits 31-24: The DN9002K10PCIE8T's BAR0

Bits 23-16: the lower 8 bits of the address of the configuration register you would like to read. (The upper 8 bits must be 0xDF, or the read will not be valid).

Bits 15-0: 0x0260

#### 7.3.9.3 Main Bus

The Main Bus interface is how you can communicate to all FPGAs on the DN9002K10PCIE8T over PCIe (not just FPGA A). The bandwidth available over the Main Bus is much lower than that of PCIe, so performance is not as great using this method. For details about the Main Bus, see the Main Bus section in this chapter. Expected speeds will be 30 to 80 MB/sec.

To write to Main Bus over PCIe, write to BAR0 at the address QLPCI\_REG\_MBADDR with the 32-bit value representing the main bus address you would like to write to. Then, write a second PCIe write to address QLPCI\_REG\_MBWRDATA with 32-bit data representing the data that you would like to write to main bus. After the Spartan 3 has received a write to both the MBADDR and MBWRDATA registers, it will write to the main bus interface.

To read from the Main Bus over PCIe, first write to BAR0 address QLPCI\_REG\_MBADDR with the 32-bit value representing the main bus address you would like to read from. Then, read from BAR0, QLPCI\_REG\_MBRDDATA. The returned value will be the value read off the main bus at the selected address. When an error has occurred (No FPGA responded to the read request) the read will return the value 0xBBBBBBBB. If all you get is 0x1234567 this means the main bus is being used by USB at the moment.

| QLPCI_REG_MBADDR   | 0x240 |
|--------------------|-------|
| QLPCI_REG_MBCTRL   | 0x270 |
| QLPCI_REG_MBWRDATA | 0x248 |
| QLPCI_REG_MBRDDATA | 0x250 |

#### 7.3.9.4 FPGA Configuration

The sequence required to configure FPGAs over PCI Express is given in the Configuration Section.

#### 7.3.9.5 Direct PCIe to FPGA, DMA

Detail about the software required by the host of the DN9002K10PCIE8T can be found in

D:\FPGA Reference Designs\common\PCIE x8 Interface\pcie8t user interface manual.pdf

This document should be used to design software to access the user design in FPGA A. DMA in particular requires accessing the LX50T registers (in BAR0) to setup each transaction.

Using the device driver provided use the dma\_scatter\_gather\_read() and dma\_scatter\_gather\_write() functions.

Performance has been characterized using the DN9002K10PCIE8T reference design on Windows XP on a MSI MS6728 motherboard using the AETest application. The speeds are:

Read (DN9002K10PCIE8T to software): I have not yet performed this test. Write (software to DN9002K10PCIE8T): I have not yet performed this test.

### 7.3.9.6 Direct PCIe to FPGA A, Target access

If DMA is not required, accessing FPGA A from the host software is super simple. Simply read or write to an address in BAR 1,2,3,4 or 5. In Linux this can be performed by mapping a page of memory in a user mode program to the physical address of a DN9002K10PCIE8T bar. In Windows driver, an IOCTL code is provided that will read and write individual bytes to the DN9002K10PCIE8T bar address range, or a block or memory.

#### 7.3.9.7 Performance

Using the provided "Full function PCI Express endpoint now with DMA" the following speed measurements were taken:

| DMA from host to FPGA <sup>1</sup> | 510 MB/s             |
|------------------------------------|----------------------|
| DMA from FPGA to host <sup>1</sup> | $350  \mathrm{MB/s}$ |

Target access from host to FPGA<sup>2</sup> 66 MB/s
Target access from FPGA to host<sup>2</sup> 4 MB/s

Main Bus to FPGA from host<sup>3</sup> 11 MB/s Main Bus from FPGA to host<sup>3</sup> 2.4 MB/s

Note 1: Using the "large buffers" DMA method in the driver. This method eliminates driver overhead.

Note 2: This speed can be increased by 2x using double-double word writes.

Note 3: This speed can be increased to the Target access speed in FIFO mode.

Note 4: Picasso's full name was, "Pablito Diego Jose Santiago Francisco de Paula Juan Nepomuceno Crispin Crispiniano de los Remedios Cipriano de la Santisima Trinidad Ruiz Blasco y Picasso Lopez"

#### 7.3.9.8 64-bit addressing

64-bit addressing has no effect on operation.

# 7.4 Other Provided Designs for the LXT

If you are not testing PCI Express endpoint logic specifically, you most likely want to use the provided "full function PCI Express endpoint now with DMA" design. Otherwise, you have the following options

# 7.4.1 No design

You can implement your design directly within the LXT, connecting directly to the Xilinx MGT. In this case, you will have to learn the peculiarities of the MGTs, and you will have to

convert the output of the MGT into PIPE (fairly easy). You can also use the LXT as an additional FPGA in the case that you are not operating in a PCI Express slot at all.

#### **7.4.2 PIPE**

The "PIPE" bitfile provides the ability to have a standard, 125 MHz, 16-bit PIPE interface. Like the full-function design, you are required to use in FPGA a provided interface module. This module takes care of translating from the native GTP back end into a standard PIPE interface. It also takes care of external bus timing and clocking.



Figure 25 - PIPE design block diagram

We can also provide 8-bit, 250 MHz PIPE or PIPE that takes in an external clock. These modifications are not on the user CD but can be generated to suit your needs on request.

#### 7.4.3 Slowdown PIPE Core

It can be challenging to place-and-route a PCI Express MAC in an FPGA which is capable of 8x operation and runs with a 125 MHz or even 250 MHz system clock. The PIPE slowdown core reduces the system clock "PCLK" frequency from full frequency to either 2, 4 or 8 times slower.



Figure 26 - PIPE Slowdown block diagram

Using this core, a PCI Express controller can interact with a real, full-speed link partner and test control paths that a non-interactive simulation might never test.

There is a fee for use of the PIPE slowdown core.

# 7.5 Troubleshooting

In PCI or PCI Express, when a bus master does not receive a responds for a read request within a certain timeout period, it will return 0xFFFFFFF to the upstream requestor. This can happen for various reasons:

- The board has lost its configuration data (the PCI configuration space registers are not programmed)
- The FPGA on BAR

# 8 Unusable pins

## 8.1.1 Configuration

The following pins (All FPGAs) are the SelectMap data pins, used to configure the FPGAs. These pins are connected to both Virtex-5 FPGAs. Using these signals for FPGA interconnect is possible, but may interfere with the configuration circuitry on the DN9002K10PCIE8T.

AJ13 AK13 AJ28 AK29 AL15 AL14 AJ26 AJ27 AK28 AK27 AL16 AK17 AM29 AN30 AN16 AM16

# 9 System Monitor/ADC

The new Virtex 5 feature System Monitor allows the FPGA to use some of its IO as analog-to-digital inputs.



The voltage measurements at these inputs are referenced to the voltage on the pin VREFP. On the DN9002K10PCIE8T, this voltage is generated by a high-precision external voltage reference IC.

The primary ADC input is routed to a differential test point. There is one test point labeled "ADC" for each FPGA.

Some of the auxiliary inputs to the ADC are routed to the Mictor connector on FPGA B. This could be used for something I guess.

# 10Reset

There are two reset circuits on the DN9002K10PCIE8T. One is the power-on reset, or "Hard Reset", that holds the board, including the configuration circuitry in reset until all power supplies on the board are within their tolerances. The second reset circuit is the user reset, or "Soft reset".

## **10.1 Power Reset**

The power-reset signal holds the configuration circuit (including a micro controller and Spartan 3 FPGA) in reset. It also causes the FPGAs to become un-configured, and causes the RSTn signal on the daughtercards to be asserted. When the board is "in reset", the "Hard Reset" LED, DS85, is lit red. It is located about an inch above the USB connector.

When the board is in reset, FPGAs cannot be configured, USB does not function (the host computer will not be able to communicate with the device), PCIe cannot access the FPGA or configuration functions (the device will still be accessible from PCIe, and LX50T registers can still be read and written). When in reset, the Spartan configuration FPGA remains configured, but all of the logic in the device is cleared.

Pressing the "HARD RESET" button, S1, located near the ATX power connector, can trigger the Power reset. This reset cannot be triggered over PCIe or USB. It is also triggered with one or more voltages on the board fall below, or above a certain threshold. These thresholds are given below:

| Min   | Max                                     |
|-------|-----------------------------------------|
| 0.94V | 1.1V                                    |
| 0.94V | 1.1V                                    |
| 1.67V | 3.8V                                    |
| 2.7V  | 3.8V                                    |
| 4.0V  | 5.6V                                    |
|       |                                         |
| 2.25V | 2.7V                                    |
|       | 0.94V<br>0.94V<br>1.67V<br>2.7V<br>4.0V |

When the board comes out of reset, the micro controller goes through an initialization process that will cause all current settings to be lost, including clock settings. Also, the configuration circuit will act as if the board has just powered on and read from the main.txt file to configure FPGAs.

When reset is triggered, it remains triggered until 55us after all trigger conditions are removed. This behavior prevents USB from behaving in such a way to permanently disable USB on the host machine.

Under some conditions, the DN9002K10PCIE8T can fail to be responsive after rapidly asserting and de-asserting reset, or if the board is powered off and back on very quickly. This behavior is caused due to a flaw in the micro controller used for the DN9002K10PCIE8T configuration circuit. This flaw is believed to be mitigated by the reset circuitry on the DN9002K10PCIE8T. If you experience the behavior please report it to support@dinigroup.com

# 10.2 User Reset

The "USER RESET" circuit is intended for use by the user. When this reset is asserted, the RESET\_\*# signal (from the schematic), is asserted to each FPGA. After at least 200ns, this signal is de-asserted simultaneously to each FPGA. This signal is connected to a regular user IO on the FPGA, so it is up to the FPGA designer to implement reset correctly within his design.

The User Reset is asserted whenever the "User Reset" button is pressed. This button, S2, is located just above the USB connector. There is no LED indicating the state of user reset. User reset is also asserted when the reset vendor request is sent over USB.

When User reset is asserted, the RSTn signal to each daughtercard is also asserted.

The rise time of the reset signal is fairly slow (10s of nanoseconds), and the delay within the FPGA of the reset signal cause the actual de-assertion time of the logic within the FPGA to be uncertain by as many as 20ns (the timing of a synchronous reset within a single FPGA is guaranteed) This means that if this signal is used to reset circuitry used for inter-FPGA communication, care needs to be taken that a synchronous reset is not required for the multiple-FPGA system to operate correctly. Alternately, you design can re-generate a synchronous reset and distribute this signal using a MB\* signal.

# 11JTAG

There are two JTAG headers on the DN9002K10PCIE8T. The first is used only to update the board's firmware. The second, J1 is connected to the JTAG port of the Virtex-5 FPGAs. This interface can be used for configuring the FPGAs, or using debugging tools like ChipScope or Identify.

## 11.1 FPGA JTAG

The connector for FPGA JTAG is shown below.



Note that the signal "TDO" on the header and in the schematic refers to the "TDO" port of the FPGA, not the connector.

The order of the FPGA JTAG chain is FPGA A->FPGA B->FPGA Q. There are no other components in the chain. If you received your board with fewer than two FPGAs installed, then the chain will be shorter.

The voltage of the JTAG chain is fixed at 2.5V and cannot change. Hot-plug on this header is allowed. The header is a 2mm pin grid dual row with shroud and polarization key.

### 11.1.1 Compatible Configuration Devices

The JTAG header is designed to work with the Xilinx Parallel IV or Platform USB cable. The JTAG chain is tested at manufacture using a Platform USB cable at 12MHz.

The driver installation process for the Platform USB cable is relatively difficult for a USB device. Follow the instructions carefully.

In order to achieve high-speed configuration using a Parallel IV cable, you need to enable ECP mode on your parallel port. This is probably a BIOS setting on your computer.

# 11.1.2 ChipScope

In order to use JTAG debugging tools on the DN9002K10PCIE8T, you do not need to configure via JTAG.

## 11.2 Firmware Update Header

The firmware update JTAG header J16, should not be used unless you are updating the DN9002K10PCIE8T firmware. This header is used with a Xilinx Platform USB or Parallel IV cable. The instructions for updating the firmware are in the Controller software chapter.

## 11.3 Troubleshooting

If you are having problems getting JTAG to work, try connecting the Xilinx Platform USB cable to the JTAG header and running the Xilinx program Impact. Impact will generate a failure log that you can email to <a href="mailto:support@dinigroup.com">support@dinigroup.com</a>. If you have an upgraded board, please mention this in your email.

## 12RS232 Interface

RS232 access is available to all FPGAs through the header P1 "FPGA RS232". To connect to this header, use the provided .1" header-to-DB9 cable to connect to a PC's serial port.

The RS232 transmit and receive signals are connected to each FPGA's pins:

AM13 (TX from FPGA) AM14 (RX to FPGA)

The TX and RX signals use the RS232 data protocol, so the FPGA will have to implement a UART in its logic.

All FPGA share the same RX and TX signals, so only one FPGA should use the interface at a time. RS232 requires a 12V to -12V signaling level, which is not available on Virtex5 FPGAs, so an external RS232 buffer is used.





One the board, pin 1 is marked with a big, unmistakable, white circle dot. On the provided cable, pin one is marked with a red stripe on the cable. Hot-plugging this connector is acceptable and encouraged.

The port settings required on the serial ("COM") port of your computer are dependent on the UART in the FPGA. Since the flow-control signals on the serial cable are not connected to the FPGA, you cannot use "hardware handshaking".

The other port settings, parity, stop bits, speed and data bits are user design dependent.

## 12.1.1 Configuration RS232

A second RS232 header (P2) is for the configuration circuitry to give feedback to the user. It is described in the section "Configuration Section".

# **13Temperature Sensors**

Each FPGA is connected to a temperature monitor. This monitor can internally measure the temperature of the FPGA silicon die. The maximum recommended operating temperature of the FPGA is 85 degrees. The accuracy of the temperature sensor is about +0 to +5 degrees. When the configuration circuitry measures the temperature of any FPGA rise above 80 degrees, it will immediately un-configure the hot FPGA, and prevent it from re-configuring. When the temperature drops below 80, the configuration circuitry will again allow the FPGA to configure.

When this occurs a message will appear on the CONFIG RS232 port (P3). An example test output is given below.

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

TEMPERATURE ALERT: FPGA A

CURRENT TEMPERATURE: 81 DEGREES C THRESHOLD TEMPERATURE: 80 DEGREES C THE FPGA IS BEING CLEARED IN AN ATTEMPT TO PREVENT HEAT DAMAGE. SOFTWARE WILL PREVENT RECONFIGURATION UNTIL THE TEMPERATURE DROPS A FULL DEGREE BELOW THE THRESHOLD TEMPERATURE.

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

TEMPERATURE ALERT: FPGA A

CURRENT TEMPERATURE: 79 DEGREES C

THRESHOLD TEMPERATURE: 80 DEGREES C

THE FPGA HAS DROPPED BELOW THE ALARM THRESHOLD

AND MAY NOW BE RECONFIGURED.

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

The FPGA can safely operate as hot as 120 degrees, but timing is not guaranteed. You can use the temperature setting in the ISE place and route tool to make timing allowances for operating the FPGA out-of-range. If you want to disable the temperature limit on the DN9002K10PCIE8T, you can do that using a menu option in the configuration RS232 interface.

# **14Encryption Battery**

The Virtex5 FPGA supports bit stream encryption. When using encryption, the FPGA must decode the bitstream using a secret key that is stored in a persistent memory in the FPGA. When the DN9002K10PCIE8T is powered off, a voltage is supplied to the FPGA by a battery installed in socket X2.

X2 is designed to house a CR1220-type lithium coin-cell battery. Typically, these batteries produce 3.0V. The socket may also work with battery types DB-T13, L04, PA. These however, have not been tested. Insert the battery positive side up.





The same battery is used for both FPGAs. Removing the battery will cause the FPGAs to lose their encryption memories, and will have to be re-programmed before they can work with encrypted bitfiles again.

To create encrypted bitfiles, turn on the "encryption" option in bitgen. The program will produce an additional output file with an .nky extension. Use the program impact with a Platform USB JTAG cable (plugged into the FPGA JTAG connector on the DN9002K10PCIE8T) to load this .nky file into each FPGA.

When using a bitfile with encryption enabled, the DN9002K10PCIE8T will not be able to read the FPGA type out of the bitstream. It will therefore prevent your FPGA design from loading into the FPGA. To disable this behavior, you must disable sanity check. Adding the following line to your main.txt file can do this

Sanity check: n

Also, when using encryption, you must be careful to correctly set the "startup clock" option correctly in bitgen, or the FPGA will fail to configure, and won't tell you why.

Whatever you do, if you love your FPGAs, do not disable the "CRC Check" option in bitgen. They should have called this option "Do you want your FPGAs to *not* catch on fire?"

## 15LED Interface

This section lists all of the LEDs. More detailed explanations of the LED functions may be in the sections describing the board system that contains the LED.

# **15.1 Configuration Section LEDs**

These LEDs are controlled by the configuration section and give the status of the board.

| LED Reference | LED    | Signal Name  | The LED indicates the following when ON.      |
|---------------|--------|--------------|-----------------------------------------------|
| Designator    | Color  |              |                                               |
| DS16          | GREEN  | ON (3.3V)    | The board is powered on                       |
| DS66          | GREEN  | SPARTAN_DONE | Configuration circuit is on (Firmware loaded) |
|               |        |              |                                               |
| LED Reference | LED    | Signal Name  | The LED indicates the following when ON.      |
| Designator    | Color  |              |                                               |
| DS17          | GREEN  | A DONE       | FPGA A is configured                          |
| DS20          | GREEN  | B DONE       | FPGA B is configured                          |
| DS21          | YELLOW | USB ACT      | There is USB activity                         |
| DS65          | YELLOW | CF ACT       | There is CompactFlash activity                |
| DS1           | YELLOW | PCIe_ACT     | There is PCIe activity                        |
| DS2           | RED    | PCIe_LOS     | PCI Express has lost link                     |
| DS3           | GEEN   | PCIe_x1      | PCI Express has negotiated a 1x link          |

| DS4  | GREEN | PCIe_x4      | PCI Express has negotiated a 4x link       |
|------|-------|--------------|--------------------------------------------|
| DS5  | GREEN | PCIe_x8      | PCI Express has negotiated an 8x link      |
| DS14 | RED   | DIMM_VOLTAGE | EThe DIMM voltage is not 1.8V              |
| DS27 | RED   | PCIe PERSTN  | The "PCI Express Reset" signal is asserted |

### 15.2 User LEDs

These LEDs are connected to an FPGA and are controller by the user. The meaning of the LED is design-dependent. Below is the general circuit used to connect user LEDs. To turn the LED on, drive the signal low. To turn off, tri-state or drive-high the signal.



The user LEDs are connected to banks where the daughtercards are connected. The "Bank Voltage" may not match the LED's current source voltage. In this case, use the drive standard corresponding to the bank, and not the LED. For example, when a LVCMOS25 daughtercard is attached, and all other signals on the bank are using the LVCMOS25 standard, then use the LVCMOS25 standard for the LED on that bank. Do not use DCI on LED signals. You can control the brightness of LEDs by either using a low-drive setting (DRIVE=2ma in the .ucf file), or by making the output bounce rapidly high and low like my "special" sister, who is now a ward of the state.

| LED Reference                                                                            | LED           | Signal Name        | The LED indicates the following when ON.      |  |
|------------------------------------------------------------------------------------------|---------------|--------------------|-----------------------------------------------|--|
| Designator                                                                               | Color         |                    |                                               |  |
| DS28-51                                                                                  | YELLOW        | LED A              | User LEDs. Drive with LVCMOS                  |  |
| DS52-62                                                                                  | YELLOW        | LED B              | User LEDs. Drive with LVCMOS                  |  |
| The number of LE                                                                         | EDs available | for the user on FP | GA A is 24. FPGA B has 11 LEDs. User          |  |
| LED's on FPGA                                                                            | A and B are r | numbered 0 to 23.  | The location of the IOs to use for these LEDs |  |
| can be found in the provided UCF file or the netlist. The name of each LED is labeled in |               |                    |                                               |  |
| silkscreen next to t                                                                     | he LED.       |                    |                                               |  |

### 15.3 Ethernet LEDs

These LEDs are controlled by the Ethernet PHYs connected to FPGA B. They can also be user-controller by setting registers in the serial interface of the PHYs.



T1 and T2 are the RJ45 jacks on the top edge of the board. There is a yellow and a green LED embedded in this connector, facing the board edge.

| LED Reference | LED    | Signal Name  | The LED indicates the following when ON.      |
|---------------|--------|--------------|-----------------------------------------------|
| Designator    | Color  |              |                                               |
| T1            | GREEN  | ETH_LINK1000 | Ethernet PHY has established link, 1000Base-T |
| T1            | YELLOW | ETH_ACT      | Ethernet PHY has detected activity            |
| DS18          | GREEN  | ETH LINK100  | Ethernet PHY has established link, 100Base-   |

## 15.4 Power LEDs

These LEDs indicate is one or more power supplies fail, either outputting a voltage that is too high or too low. The voltage that the LED indicates is marked in silkscreen near the LED.



| LED Reference | LED   | Signal Name | The LED indicates the following when ON.   |
|---------------|-------|-------------|--------------------------------------------|
| Designator    | Color |             |                                            |
| DS6, DS5      | RED   | POWER_FAIL  | One of the 1.0V power supplied has failed  |
| DS1,2,3,4     | RED   | POWER_FAIL  | One of the board power supplied has failed |
| DS14          | RED   | RESET       | The board is in "reset"                    |

## 15.5 Unused LEDs

These LEDs are controlled by the configuration circuitry. One GREEN LED is always on. One yellow one flickers when something undefined is happening. Two RED ones signal which FPGA is undergoing some sort of configuration operation, and will pause with that indication if there is an error.

The primary purpose of these LEDs if for Dini Group to debug it's software, so I wouldn't be surprised if this information were outdated already.



| LED Reference | LED      | Signal Name | The LED indicates the following when |
|---------------|----------|-------------|--------------------------------------|
|               |          |             | ON.                                  |
| Designator    | Color    |             |                                      |
| DS22-25       | RED,GREE | NMCU        | No meaning.                          |
| DS26          | YELLOW   | HOST_ACT    | No meaning.                          |
| DS70-73       | GREEN    | LED_SPARTAN | No meaning.                          |
| DS12          | RED      | ERR_TEMP    | FPGA over temperature                |
| DS13          | RED      | ERR_CONF    | No meaning.                          |

## **16DDR2**

There is one "DDR2" memory socket interfaces on the DN9002K10PCIE8T.. By convention, the name of this interface is DIMMB. In this section, the interfaces may be called "DIMM", "SODIMM" or "DDR2" interface interchangeably.

Signal names given in this section, and in other documentation (ucf files) are given in the form DIMMB\_<signal name>.

#### **16.1 Power**

Each DDR2 SODIMM is capable of drawing 5A of current when in auto-precharge mode.

The DN9002K10PCIE8T is capable of providing this amount of current.

### 16.1.1 Interface Voltages

The "standard' DDR2 interface voltage is +1.8V. The banks that connect to the DIMM interface are powered by 1.8V, and the power pins on the socket is connected to this same power net. In a DDR2 interface, these signals are driven using the SSTL18\_DCI drive standard. There are some exceptions, listed below.

DIMM\_SDA, DIMM\_SCL, DIMM\_CK2

These signals are connected to a 2.5V clock bank on the FPGA. DIMM\_SDA and DIMM\_SCL should be driven using the LVCMOS25 standard. For details on the DIMM\_C2 signal, see the clocking section below.

The DIMM interfaces are not designed for hot-plug.

## 16.1.2 Changing the DIMM voltage

If you need to change the voltage of the DIMM interface, there is a set of jumper points provided for each interface allowing power to be redirected from a source other than the onboard 1.8V power supply. When the DN9002K10PCIE8T is shipped, a jumper is installed connecting the DIMM/FPGA Bank power to the 1.8V power rail. Next to each of these jumpers is a 2.5V test point suitable for jumper-ing to the DIMM power rail, if necessary. Some Dini Group products (DNSODM\_SDR, DNSODM\_DDR1) require this jumper to be installed. When installing this jumper, remove the 1.8V jumper to prevent shorting 1.8 and 2.5V supplies together.



For example, to change the DIMMD interface to 2.5V, remove the jumper installed in TP12 and install a jumper from TP12.2 to TP13.1

## 16.2 Clocking

The data signals in the DDR2 interface are clocked source-synchronously. In order to clock in and out the "DQ" data signals, the DQS signal are used as a clock using the Virtex-5 "BUFIO" clock driver. Details on how to implement a DDR2 controller are in the Xilinx application note XAPP858. You can also see the provided DDR2 reference design for example code.

A basic block diagram of the clocking is given below.



Note that the DIMM\_CK2 signal is driven by the FPGA from a 1.8V bank. The output should be a DIFF\_SSTL18. It is received by a global clock ("GC") pin on the Virtex-4 device. To receive the signal, use an LVDS\_EXT input with DIFF\_TERM attribute set to TRUE.

The CK0, CK1 and CK2 signals are length-matched, so this input should be synchronous to the clock input of the DIMM module.

The DQ and DM signals are synchronous to the DQS signals in each bank. See the DDR2 SODIMM module specification for information on the timing of this interface.

### DQS timing

In order to clock the DQ and DM inputs using the DQS signal, you must use a BUFIO clock buffer on the DQS signal.

# 16.3 Signaling

#### 16.3.1 Standards

DQ, and DM signals should use the SSTL18\_II\_T\_DCI drive standard. The required VREF, VRP and VRN connections required for this standard are provided on all DIMM interface banks.

DQS signals should use the DIFF\_SSTL18\_II drive standard. External differential termination is provided on these signals at the FPGA.

DDR2 clock signals should be driven by the DIFF\_SSTL18\_II standard.

DDR2 "Control" signals (Address, BA, S#, RAS#, CAS#, WE#) should be driven by the SSTL18\_I\_DCI standard. The following signals are exceptions to this requirement. On four of the DIMM interfaces, external termination resistors are provided. The signals with external termination are listed below.

DIMMB\_A00 DIMMB\_A01 DIMMB\_A02 DIMMB\_A03 DIMMB\_A04 DIMMB\_A05 DIMMB\_A06 DIMMB\_A07 DIMMB\_A08 DIMMB\_A09 DIMMB\_A10 DIMMB\_A11 DIMMB\_A12 DIMMB\_A13 DIMMB\_A14 DIMMB\_A15 DIMMB\_CAS# DIMMB CS#0

DIMMB\_ODT0

For signals in this list, use the SSTL18\_II drive standard.

#### 16.3.2 Serial Interface

The SDA and SCL interfaces are connected to 2.5V LVCMOS buffers. External pull-ups are provided on these signals. The address of all DIMMs on the DN9002K10PCIE8T is set to zero.

### 16.3.3 **Timing**

The length matching of the DDR2 interface signals includes all signals except for DIMM\_SCL and DIMM\_SDA signals.

Due to the source-synchronous clocking techniques used by the DDR2 interface, the delay from FPGA to DIMM should not be needed, but is provided here anyway.

DIMMB

Length 90mm Delay 510ps The trace impedance to each of the connectors is controlled to 50-ohms. All signals in the interface are ground-referenced. Note that this is contradictory to the recommendations of the DDR2 SODIMM specification.

To increase the setup time available for control signals, modules may be set into T2 mode. In the reference design, the modules are in T1 mode.

Address Control signals:

#### FPGA:

Assume a DCM in system-synchronous mode.

Worst clock-to-out time of Virtex 5: 3.37 with DCM. No phase-shift.

Worst setup time: 0.097 Worst hold time: 0.21

#### DIMM:

setup 600ps hold 600ps

#### DQ signals:

DIMM:

DQS must be within 350ps of DQ, DM setup 400ps Hold 400ps

FPGA: IDELAY setup –1.23 hold 2.14

clock-to-out 5.34

# **16.4 Compatible Modules**

The DDR2 interfaces are compatible with standard PC2-2700 or faster memory modules up to a capacity of 4GB. The greatest capacity modules available at print time are 2GB. The interface has been tested with modules with a CAS latency of 3. The interface is characterized to 250MHz, although faster designs may be possible. Xilinx is advertising a maximum DDR2 interface for the Virtex-5 of 333MHz.

The DDR2 memory interface can also be used with SRAM, Flash and other types of memory modules. See the chapter on Ordering Options for a list of compatible memory modules.



The interface implementation on these modules is not provided. The customer must design the memory interface including timing and clocking.

## 16.5 Test points

Each DDR2 interface exposes five signals as test points, located on the bottom of the PCB right under the SODIMM connector. These signals are DQ0, DQS0p, CK0p, RAS# and CAS#. The test points are labeled in silkscreen. The test points near DIMMA implicitly are part of the DIMMA interface, and so on.



## 17FPGA Interconnect.

The point-to-point interconnect on the DN9002K10PCIE8T is designed to operate at the maximum switching frequency possible on the DN9002K10PCIE8T. The fastest switching standard available on the Virtex 5 FPGA is LVDS. Using this standard on the interconnect of a DN9002K10PCIE8T, we have demonstrated switching frequencies as high as 950Mbs.

A block diagram of the point-to-point interconnect is below.



The interconnect in the above diagram is confusingly described as sets of two busses. Marketing explained why this was, but I forget the rationale now. "DE" is the bus between FPGA D and FPGA E. It contains 120 "p" signals and 120 "n" signals. This means there are 240 total signals between D and E. If you use LVDS and pain the "p" and "n" signals, you would have 120 LVDS signals between these two FPGAs.

The above diagram is only valid when the board is install with only LX330 FPGAs (the largest available size). When any LX220 or LX110 FPGAs are installed, the interconnect available between FPGAs drops significantly. In the "Ordering Information" chapter of this manual, there is a block diagram showing the available features on a board loaded with LX220 or smaller FPGAs. If the board has mixed LX220 and LX330 FPGAs, then the interconnect available between any two FPGAs is the lesser of the signal counts shown in these diagrams.

Each FPGA-to-FPGA interconnect signal is tested at 700Mbs prior to shipping, no matter which speed grade is installed on your board. Higher speeds are possible, given appropriate IO timing methodology and speed grade parts. The theoretical limitation imposed by the DN9002K10PCIE8T is 1.1Gbs, the limit of the Virtex 5's internal clock network. Dini group has demonstrated speeds up to 0.95Gbs on each pair of interconnect signals.

Information on how to achieve this interconnect switching speed can be obtained by examining the Xilinx application note XAPP855. Other methods of implanting high-bandwidth interconnect are described in XAPP860.

The Dini Group reference design uses an older method designed for Virtex-4.

In a synchronous system between two FPGAs and a DCM in zero-delay mode, the following timing is possible.

| Clock to Out         | 3.37 | NS |
|----------------------|------|----|
| Trace Delay          | 1.70 | NS |
| Rise-time adjustment | 0.30 | NS |
| Clock skew           | 0.20 | NS |
| duty cycle           | 0.05 | NS |
| iitter               | 0.05 | NS |

#### HARDWARE

| setup time    | 1.00 | NS  |
|---------------|------|-----|
| Min Period    | 6.67 | NS  |
| Max Frequency | 0.15 | GHZ |

If LVDS is used, make sure to assign the DIFF\_TERM attribute to the IBUFDS in the receiver FPGA.

As the frequency of synchronous communication between FPGAs increases, the user must implement more difficult techniques. As a general guide, these techniques are described below.

| 0   | MHz |                                                                                 |
|-----|-----|---------------------------------------------------------------------------------|
| 20  | MHz | The user should use the "Pack the IOBs" by using synthesis attributes. The      |
|     |     | output delay for each output and setup time for each input is a known value.    |
| 100 | MHz | Use DCMs in each FPGA to eliminate the variation of clock network skew          |
|     |     | internal to each FPGA. The clock must be free-running                           |
| 250 | MHz | Use DDR clocking, and DDR IO buffers                                            |
| 300 | MHz | Use source-synchronous clocking between FPGAs. The clock is driven with the     |
|     |     | data for each bus. The receiving FPGA uses the clock signal, received on a      |
|     |     | "CC" pin to clock the IOs in the bus. An IDELAY element on the CC pin           |
|     |     | input delays the clock with respect to the data by a fixed amount to allow some |
|     |     | setup time.                                                                     |
| 550 | MHz | Use the Virtex 5 build in ISERDES and OSERDES modules.                          |
| 600 | MHz | Use Virtex 5 PLL devices to reduce cycle-to-cycle jitter on the clocks.         |
| 700 | MHz | Individually de-skew each bit using IDELAY elements. Use a training pattern     |
|     |     | or hard-code the correct delay values for each input.                           |
| 800 | MHz | Use LVDS signal standard                                                        |
| 900 | MHz | dynamically de-skew each bit to account for temperature and voltage variation   |
| 1+  | GHz | Highest speed grade parts are required.                                         |

Note that for speeds above 550MHz, you must use the ISERDES and OSERDES modules, adding latency to your interconnect. (At speeds greater than 500MHz, there is more than one clock-cycle of latency in board trace delay alone).

For the maximum bandwidth, use single-ended signaling at 700MHz. For single-ended signaling, an IOSTANDARD of LVCMOS25 is appropriate. Use drive strength of 6mA or 8mA.

## 18Main bus

Main Bus is the interface that the DN9002K10PCIE8T uses to bring USB and PCIe access to both of the Virtex-5 FPGAs. If you want to use USB in your design, or want PCIe access without implementing PCIe in FPGA, then you must implement a Main Bus slave in your FPGAs. The reference designs include one such controller, and you are free to use it.

Drive strength.

Please use the highest drive strength IOs available (24mA)

## 18.1 MB Signals

The DN9002K10PCIE8T, in addition to the dense interconnect available between FPGAs in a point-to-point topology, provides a 36-signal-wide "MB" bus that is connected to both Virtex-5 FPGAs.



These signals are reserved

#### 18.1.1 Disambiguation

The "MainBus" has two meanings. In this document it usually refers to the interface connecting the FPGAs to USB and PCIe via the configuration circuitry. It can also mean the group of 36 signals on the DN9002K10PCIE8T that connects both Virtex-5 FPGAs. It just so happens that the "MainBus" interface is implemented using 36 of the "MB\* signals". In this document "MB" will be used when referring to the signals themselves, and "MainBus" when referring to the Dini-Group-defined, 36-signal interface description.

#### 18.1.2 Electrical

The MB signals are fixed at a 2.5V signaling level. LVCMOS25 is an appropriate singling standard. Due to very heavy capacitive loads on the MB signals, you must use drive strength of 24mA to use main bus. DCI should not be used because the signals are not impedance-controlled. Although not required, by convention, data on the MB signals is synchronous to the MB48 clock. In order to use the "Main Bus" interface to communicate with USB or PCIe, you must use the MB48 clock. This clock runs at a fixed 48MHz.

Note that as well as the 36 "MB" signals, there are also 16 signals in the "Selectmap\_D [15:0]" that connect to all FPGAs that could be used for user data. Dini Group does not directly support using these signals. If you chose to use these signals, note that the FPGA design can interfere with the programming of FPGAs. You would have to keep the outputs on these signals tri-stated until all FPGA configurations are complete.

### **18.1.3** Timing

As described above, the MB signals are typically run synchronous to the 48MHz MB48 bus. This is the highest speed that the MB signals are guaranteed to run using a system-synchronous clocking method. You may be able to achieve performance from FPGA-to-FPGA on this bus as high as 75MHz, if you adjust input and output clocks and perform a timing analysis. Using LVCMOS25 with a drive strength of 24mA, you can assume there is a 10ns rise time/flight time for signals on this bus.

No length matching is done on the MB signals.

Virtex 5 clock-to-out time: 3.37ns with DCM

Virtex 5 setup time: 0.97ns

Flight time: 10ns (includes rise-time adjustment for capacitive load)

Total: 14.34ns (69 MHz)

The MB\* signals are tested at 48MHz

### 18.2 Error Codes

The Main Bus interface has no way of signaling an error condition on read requests, but some errors will result in the same sentinel values being returned. Following is a list of these values.

0xABCDABCD: The Main Bus read timed out. (PCIe only)

0xDEADDEAD: The Main Bus read times out (USB only); When this condition occurs, a register, accessible as part of the "configuration register" space, gets incremented; In this way, it is possible for a Main Bus access program to verify that a MainBus transaction has succeeded

0xFFFFFFF: The PCIe bus timed out. This is not a value returned by the DN9002K10PCIE8T. The PCIe request was not returned. The LX50T may not be configured correctly

0xDEAD5566: This value is returned by the Dini Group reference design as a default value, when a read request is to an address that has no registers associated with it.

0xBABABABA: <unknown. Contact support>

0x12345678: The Main Bus is disabled. This is the default state of the DN9002K10PCIE8T when it powers on. To set the DN9002K10PCIE8T to enable, a configuration register must be

written. This behavior is intended to protect users who do not wish to implement Main Bus interface, but who wish to use the MB0-MB35 signals for their own purposes.

### 18.3 FPGA Interface

All memory-mapped transactions in the reference design occur over the MB bus. This 36-signal bus connects to all Virtex 5 FPGAs and to the Spartan 3 configuration FPGA. The Configuration circuit (Spartan 3) is the master of the bus. All access to the MB bus (reads and writes) is initiated by the Spartan 3 FPGA when the reference design is in use.



All transfers a synchronous to the USB\_CLK (or SYS\_CLK) signal. This clock is fixed at 48MHz, and cannot be changed by the user. This clock is LVCMOS, single-ended. When the configuration circuit asserts the ALE signal, the slave device on the bus (the FPGA) is required to register the data on the AD bus. This is the "main bus address". All future transfers over the main bus are said to be at this address, until a new address is latched. On a later clock cycle, the master may assert the "RD" signal. Sometime after this, (within 256 clock cycles), the FPGA should assert DONE for one clock cycle. On this cycle, the master (Spartan) will register the data on the AD bus, and that will be the read data. If DONE is not asserted, then a timeout will be recorded and the transaction cancelled.

Here is a write transaction:



When the Spartan asserts the "WR" signal, the FPGA should register the data on the AD bus.

Sometime after this, the FPGA should assert the DONE signal. This will allow the Spartan to begin more transactions. The FPGA may delay this for up to 256 clock cycles before a timeout is recorded and the transaction is cancelled.

Main bus can be controlled from the USB Controller program. (Read and write single addresses, or to/from files) It can also be written from the main.txt configuration method. The main.txt syntax is

MAIN BUS 0x<address> 0x<data>

Where <address> and <data> are 8-digit (32-bit) hexadecimal numbers.

### 18.3.1 Conventional Memory map

By convention, FPGAs on the main bus interface are assigned address ranges. Assigning address ranges is required because the "FPGA sourced" signals (DONE) need to be driven by only one FPGA at a time.

The convention that Dini Group uses is to reserve the upper four bits in the address as an FPGA-select address. The address range (hex) 0x00000000 - 0x0FFFFFFF is reserved for FPGA A, 0x10000000 - 0x1FFFFFFF is reserved for FPGA B, and so on.

The user need not follow this convention, but unless you really need 32-bit addresses, we recommend using it. Only one FPGA has "control" of the DONE signal. If the last address latched by ALE was not for a given FPGA, it should tri-state the output. Before tri-stating any

signal with a pull-up or pull-down resistor, it is good practive to drive the signal to the DC value before tri-stating. (So that simulation will match emulation result).

### 19Ethernet

An Ethernet interface is available to FPGA B. It is provided by a Vitesse VSC8601 tri-mode Ethernet PHY. The RJ45 connector can be used to connect to a regular 10Base-T, 100Base-TX, or 1000Base-T Ethernet network connection.



The VCS8601 device does not contain an Ethernet MAC. The FPGA must implement a complete network stack to make use of the Ethernet connection. Sorry! I know that's retarded, and the DN10,000K10PCI will be better. Until then, check out OpenCores Tri-mode Mac controller

http://www.opencores.org/projects.cgi/web/ethernet\_tri\_mode/overview

#### 19.1 MII

The 4-bit GMII interface is the only required interface on the PHY device. The EEPROM, MDIO, and other signals are only required if you want to put the PHY into a mode that is not default.

The SMI (MDC, MDIO signals) address is set to 0000. Each Ethernet interface (one for FPGA D, one for F) is on its own SMI interface.

#### 19.1.1 Electrical

The appropriate electrical standard to use is LVDCI\_25. In Gigabit mode (default), the MII interface runs at 125MHz, DDR.

The CLK\_ETH125. Signal should use the SSTL\_II\_25\_DCI signaling standard.

### 19.1.2 **Timing**

The board is designed such that when using a DCM in zero-delay mode on the clock, CLK125\_ETH, the interface will meet timing, clocking all IOs on this clock. Alternately, you can use the CLK\_ETH\_RX to clock inputs using a BUFIO and clock CLK\_ETH\_TX on the same clock as the rest of your transmit signals.

By default, the 8601's internal clock compensation mode is enabled. This causes the timing of the device to be based on a clock that is delayed 2ns from the clock on the external TX\_CLK and RX\_CLK pins. This makes synchronous operation of the interface possible.

Length-Matched: 500ps

FPGA:

Assume a DCM in system-synchronous mode. Worst clock-to-out time of Virtex 5: 3.37 (with DCM.) No phase-shift. Worst setup time: 0.097 Worst hold time: 0.21

PHY: (clock measured at PHY pin) clock-out 2ns setup 2ns valid: 1.2ns



The EEDAT and EECLK signals are intended to connect the PHY to an EPROM that would contain configuration settings for the device (LED behavior, MII timing, Link speed, duplex, auto negotiation, etc.). Since the MDIO interface is connected to the FPGA, it is unlikely you would ever use these signals, unless you just like emulating EPROMs on weekends and vacations.

If you do not implement the MDIO interface, then the default settings are used for the device. This includes settings that are specified by multi-level inputs connected to resistors.

The CMODE options of the Ethernet PHYs has been set as follows

CMODE0 - 0100 (8.25K resistor)

CMODE1 – 0000 (0 Ohm resistor)

CMODE2 – 0001 (2.2K resistor)

CMODE3 – 0000 (0 Ohm resistor)

This results in the following settings

ADDR = 00000 MDIO address

CLKOUT = TRUE Drives the CLK\_ETH\_125 signal

PAUSE = 00 I don't know

| DOWNSHIF        | ['=    | FALSE  |   |    | I don't know |
|-----------------|--------|--------|---|----|--------------|
| SPEED           | =      | 00     |   |    | Gigabit mode |
| <b>ACTIPHY®</b> | =      | FALSE  |   |    |              |
| SKEW            | =      | 11     |   |    | ETH125 clock |
| MAC CALIBR      | RATION | N MODE | = | 00 | ???????      |

The LEDs on the RJ45 connector are controlled by the PHY. The Amber LED indicates activity and the Green LED indicates link in gigabit. The LED, DS64, located next to the RJ45 connector, indicates link in 100Mbit mode. The 10Mb link LED is not configured.

Hot plug is acceptable on a 1000Base-T connection.

The Ethernet PHY works with the Xilinx Ethernet IP, but only in 10 and 100Mbit modes.



The above schematic clipping is useless but looks cool and technological.

### **19.2 JTAG**

The VSC8601 device is attached to a JTAG chain. The schematic clipping showing this connection is given below.



I don't know why you would need access to this. It isn't tested or thought about ever. This JTAG chain does not connect to the FPGA JTAG chain

## **20EPROM**

A small EPROM (1K) is attached to FPGA B. These devices are intended to store identification data for generating a unique MAC address for the Ethernet interfaces. However, the EPROM can be used for any user-defined purpose requiring static-memory intensive tasks, like remembering your name and birthday.

The interface to the EPROM is a standard IIC at 1.8V. The IIC address of the devices is (binary)  $1010\ 000$ 

The maximum clock speed of the IIC interface is 400 kHz



The pins used to access the EPROM are given below

ETH\_IIC\_SCL AE42 ETH\_IIC\_SDA AE41

## **21Mictor Connectors**

There are two Mictor, 38-pin connectors on the board for the purpose of using a logic analyzer. If you need to use a logic analyzer, be sure to consider using an embedded logic analyzer instead like ChipScope or Identify. These logic analyzers place-and-routes within your design and are more flexible than a stand-alone analyzer.

## 21.1 FPGA B Mictor

J16 is a Mictor connector whose signals all connect directly to FPGA B's IOs. This Mictor can be used for a logic analyzer, as probe points (using a Mictor breakout), or to cable to another system.



By default, the signaling level on the Mictor connector is CMOS, 2.5V. Removing R134 and installing a zero-ohm resistor on R135 can change all the IOs associated with this connector changed to +3.3V CMOS signals instead.



Hot-plugging a Mictor connector is generally safe. When connected to a logic analyzer, signals MICTOR32 and MICTOR33 should be used as trigger signals.

Signals connected to the Mictor are 50-ohm. DCI and SSTL (referenced input) can be used on the Mictor interface.

Note the connector is mixed-voltage. The odd pins 13-37 follow the daughter card's B0 voltage and the even pins 12-38 follow the daughter cards B1 voltage.

## 21.2 MainBus Mictor

A second Mictor connector, on the backside of the board, is connected to the MainBus and SelectMap interfaces of the DN9002K10PCIE8T.



Most of the signals attached to the Mictor are accessible from both FPGAs on the DN9002K10PCIE8T. Since these signals are heavily loaded, this connector is not suitable for high-speed signaling.



The "clock" or "trigger" signals on this connector, CLK\_48\_MIC and MICTOR\_CLK\_E are driven at a fixed 48 MHz. If you need to use a logic analyzer, this is the only available trigger.

If you use the signals SELECTMAP\_D[7:0] for any purpose other than configuration, care must be taken to prevent the FPGAs from driving these signals before all FPGAs are configured, or else risk interfering with the configuration process.

Some SelectMap control signals are connected to this connector, but are not user-accessible. This connector could potentially be used for configuring daughtercards. You would have to contact us for information about that possibility.

## 22Power

The power used by the DN9002K10PCIE8T is derived from an external 12V voltage supply. The current at these voltages is supplied through the PCI Express power connector, J3.

NO power is taken from the PCIe edge connector. Therefore, if installed in a PCI Express slot with no power connector, the board will not power on.



Figure 27 - Board power topology diagram

The maximum power draws on each of these rails is given below.

| +12V     | 9A   |
|----------|------|
| +1.0VA   | 15A  |
| +1.0VB   | 15A  |
| +2.5V    | 20A  |
| +3.3V    | 6A   |
| +5.0V    | 9A   |
| +VDIMM_A | 2A   |
| +VDIMM_B | 2A   |
| +1.2V_S  | 0.2A |
| +0.9VA   | 0.2A |
| +0.9VB   | 0.2A |

#### **22.1 Power 12V**

The 12V rail is used to generate most other voltages on the board. The only places where 12V is used directly are the daughtercards.

Below is a list of the maximum power draw of each of the 12V loads on the DN9002K10PCIE8T.

| Rail          | Max Current | Uses                | 12V current |
|---------------|-------------|---------------------|-------------|
| 1.0V_A        | 25          | Internal FPGA power | 2.3A        |
| 1.0V_B        | 25          | Internal FPGA power | 2.3A        |
|               |             |                     |             |
| 1.8V          | 2.5         | DIMM B              | 0.3A        |
|               | 2.5         | DIMM A              | 0.3A        |
| 2.5V          | 9           | Spartan 3 (1.2V)    | 2.6A        |
|               |             | FPGA IO             |             |
|               |             | FPGA Aux power      |             |
| Daughtercards | 10W         |                     | 1.2A        |
| TOTAL         |             |                     | 9.0A        |

The total possible power requirement of the DN9002K10PCIE8T is 9A on 12V (108W).

More typically, each FPGA would only use 10W, and daughtercards would use little power (2W). Under these conditions, the 12V power requirement is only 2.5A (25W). Under these conditions use in a server rack would work.

#### 22.2 Power 3.3V

3.3V is used by the DN9002K10PCIE8T to supply the clock distribution network, the configuration logic (Micro controller and Spartan 3 FPGA), and daughtercard power.

The maximum power requirement for the DN9002K10PCIE8T on 3.3V is 1A. 3.3V is taken directly from the ATX power supply or from the PCIe slot.

## 22.3 Power 2.5V

2.5V power is generated from the 5.0V using a 30A power supply.

#### **22.4** Ground

All ground (0V) voltages on the DN9002K10PCIE8T are shared. A monolithic ground design strategy was used. The nets GND\_SHIELD and GND\_ANALOG are directly connected to the ground plane.

#### 22.5 Power Connections

The primary sources of power for the DN9002K10PCIE8T are the PCI Express "graphics" power connector. From these two sources, the DN9002K10PCIE8T draws current at 12V; all other voltages on the board are generated.



This connector will work with a standard ATX power supply. Any supply rated above 300W is likely to be suitable for use with the DN9002K10PCIE8T.

If no 6-pin PCI Express "graphics power" connector is available, you may use an adapter cable (provided). Most new power supplies now have this connector available.

Note that only a 6-pin "PCI Express graphics" cable should be used. This is easily confused with the now-defunct "AUX POWER" connector (also 6-pin) and the 4-and 6-pin EPS "server motherboard" connections. The connector is keyed, so the wrong connectors will have difficulty fitting properly into the board.

Fittings are supplied such that the board can be powered from the PCI Express slot if this feature is desired; however this operation is not recommended because it can easily overload the motherboard.

## **22.6 Power Monitors**

The DN9002K10PCIE8T monitors the voltage levels on the board to ensure they are within tolerance. If they fall out of tolerance (above or below voltage) the board will enter a reset state. These tolerance ranges are listed below.

www.dinigroup.com

1.0V (0.95 to 1.21) 1.8V (1.65 to 3.00) 2.5V (2.20 to 2.90) 3.3V (2.89 to 4.00) 5.0V (3.99 to 6.02)

The voltage monitors filter the voltage at a frequency of about 1KHz.

The following voltages are not monitored.

1.2, VCCO\_B0, VCCO\_B1, VCCO\_B2, DIMM\_VTT, DIMM\_VREF

When a power supply voltage falls out of tolerance, the board is put in reset (the SYS\_RST# signal is asserted), and SYS\_RSTn LED glows, and an LED along the right hand side of the board will light to indicate which power rail has failed.

The voltage levels are measured with a RC filter "time constant" of around 1KHz. This means transient voltage spikes may not trigger a board reset.

### **22.7 Heat**

The maximum power dissipation supported for each FPGA is 25W. Using the provided heat sink and fan assemblies, FPGAs will remain under the maximum recommended junction temperature (85 degrees C). If your design exceeds this limit, you can assume the temperature of the device rises 2 degrees for each watt above this amount your design uses. Put this number in the settings of the timing analyzer.

Power requirements of a design can be estimated using the power estimator tool in ISE 9.1.

For this calculation the board is assumed to be in an ambient temperature of 35 degrees. In a closed computer case, the ambient temperature will increase.

#### 22.7.1 Fans

The fan units attached above the heat sinks are powered by 5V. Each fan has its own power connector.



### 22.7.2 Removing Heatsinks

The heat sink/fan assemblies are attached using a plastic clip. There is a thermal interface material between the FPGA and heat sink that is slightly adhesive. Forcibly removing the heat sink will not damage the FPGA.

#### 22.7.3 Fan Tachometers

Each FPGA fan has a tachometer connected to it for the detection of fan failure. If you intend to use this system in a rack or production system, you may want to monitor the fans.



The fan tachometer inputs (AH16) can be LVCMOS25. The fan will produce 2 rising edges per revolution. You may need to de-bounce the signal if you intend to count the fan frequency.

## 23Connectors

This section provides a list of all connectors on the DN9002K10PCIE8T. Items considered "test points", including the "clock TP" points are listed in the test point section.

## 23.1 FPGA User Interface Connectors

The following connectors are directly connected to the FPGA, and the user needs to know the interface requirements in detail. All of these connectors should be fully described in the manual section indicated below.

#### FPGA Interface Connectors

| Reference | e Manufacture | r Part Number      | Connector description           | FPG/ | Manual Section |
|-----------|---------------|--------------------|---------------------------------|------|----------------|
| J2, J1    | Lighthorse    | LTI-SASF546-P26-X1 | I SMA Jacks (differential)      | A    | Clocks         |
|           |               |                    | ,                               |      |                |
| J16       | AMP           | 2-767004-2         | Mictor logic analyzer connector | В    | Mictor         |

| J17      | AMP        | 2-767004-2               | Mictor logic analyzer connector                  | ALL    | Mictor                         |
|----------|------------|--------------------------|--------------------------------------------------|--------|--------------------------------|
| P5<br>P6 | FCI<br>FCI | 84520102LF<br>84520102LF | MEG-Array 400-pin plug<br>MEG-Array 400-pin plug | A<br>B | Daughtercards<br>Daughtercards |
| J4       | JAE        | MM50-200B2-1E            | DDR2 200-pin SODIMM socke                        | et B   | DDR2                           |
| P2       | Samtec     | TSM-136-01-T-DV          | Dual-row 0.1" RS232-header                       | ALL    | RS232                          |
| J9       | Molex      | 22-27-2031               | 3-pin Fan Power                                  | A      | Power                          |
| J15      | Molex      | 22-27-2031               | 3-pin Fan Power                                  | В      | Power                          |
| S2       | Omron      | B3S-1002                 | "Reset" Pushbutton                               | ALL    | Reset                          |

#### 23.1.1 Comments

If you have a board with fewer than two FPGAs installed, connectors associated with the missing FPGA will be not be installed.

- P2 Connections to this RS232 header are through a 12V buffer
- J9,15 Pin 1: GND, Pin 2: 5V, Pin 3: Tachometer

## 23.2 Non-FPGA User Interface Connectors

The following connectors are not directly connected to FPGA IO, and therefore the user does not need to know detailed information about them. The interfaces relating to these connectors are functionally described in the manual section indicated. The FPGA indicated is used to access the connector's interface, but is not directly connected to the connector pins.

# Non-User

#### connectors

| Reference Manufacturer Part Number |            | er Part Number     | Connector description   | FPGA | Manual Section |
|------------------------------------|------------|--------------------|-------------------------|------|----------------|
| J12,13                             | Lighthorse | LTI-SASF546-P26-X1 | SMA Jack (differential) | ALL  | Clocks         |
| J14                                | Molex      | 538-53856-5070     | CompactFlash socket     |      | CompactFlash   |

| J11 | Molex    | 67068-8000      | USB Type B female              |     | USB        |
|-----|----------|-----------------|--------------------------------|-----|------------|
| S1  | Omron    | B3S-1002        | "Hard Reset" Pushbutton        |     | Reset      |
| J7  | Molex    | 87832-1420      | 14Pos 2MM JTAG header          | ALL | JTAG       |
| X2  | Keystone | 3001            | Coin Batter retainer           |     | Encryption |
| T1  | Belfuse  | 0826-1X1T-23-F  | RJ45 w/ LEDs                   | В   | Ethernet   |
|     |          |                 |                                |     |            |
| J6  | NONE     | NONE            | 0.1" pitch mounting positions  |     | Ethernet   |
| P4  | NONE     | NONE            | PCIe 64-bit edge connector     | A   | PCIe       |
| J10 | Molex    | 87832-1420      | 14Pos 2MM header               |     |            |
| Р3  | Samtec   | TSM-136-01-T-DV | Dual-row 0.1" RS232 header     |     | RS232      |
| J8  | AMP/Tyco | 1-641737-1      | 20-pin Vertical "ATX"          |     | Power      |
| P1  | Molex    | 39-29-9202      | 4-pin Right angle "Hard drive" |     | Power      |
|     |          |                 |                                |     |            |

### 23.2.1 Comments

If you have a board with fewer than 2 FPGAs installed, connectors with missing FPGAs as associated FPGA will also not be installed.

## 23.3 Not-For-Use Connectors

The following connectors are not intended for use by the user.

#### Not-for-use

Connectors

| Reference Manufacturer Part Number |                    |                                    | Connector description                            |                                                        |  |
|------------------------------------|--------------------|------------------------------------|--------------------------------------------------|--------------------------------------------------------|--|
| Y5                                 | Gompf              | 93340115                           | PCIe Bracket                                     |                                                        |  |
| JP1                                | NONE               | NONE                               | 1.8V adjust                                      | 1.8V adjust                                            |  |
| TP12                               | Mill-Max           | 999-11-210-10-0                    | Jumper                                           | 1.8V connects to DIMMS                                 |  |
| X1                                 | AMP/Tyco           | 2-641260-1                         | 8-pin DIP socket                                 | Used by the DN9002K10PCIE8T to store firmware data     |  |
| MP2<br>MP1<br>M1-3                 | CCI<br>CCI<br>NONE | B-250-6-1.5<br>B-250-6-1.5<br>NONE | Board Stiffeners<br>Board Stiffeners<br>M3 Holes | Board stiffeners<br>Board stiffeners<br>Mounting Holes |  |

#### 23.3.1 Comments

The pins of Y3 are part of the "DN9002K10PCIE8T mechanical drawing" in the Mechanical section. The two pins are grounded.

JP1 JP1 can be installed to change the 1.8V power rail on the DN9002K10PCIE8T to

2.5V

TP12 These jumpers connect the DIMM interfaces to the 1.8V rail. They can be removed to change the DIMM voltage

M1-3 These are connected to GND

## 24Mechanical

The DN9002K10PCIE8T is larger than the PCIe specification allows, and is not guaranteed to fit into any ATX case. It will certainly fail to fit into a rack mount server enclosure. The vertical clearance with the fans installed and the ATX power connector not connector is 30mm. Lower-profile fans are available (14mm) but they may not have enough thermal performance for very power-hungry designs.



Mounting holes are all over the place. These are grounded.

Metal runners are along both edges of the board. These are for ground oscilloscope probe ground clips. You should also handle the DN9002K10PCIE8T by its ground bars to help prevent ESD damage to the FPGAs.



# **25Daughtercard Headers**

The daughter card expansion capability of the DN9002K10PCIE8T is provided by two FCI 'MEG-Array' family connectors. Even though it uses the same FCI connector, it is NOT compatible with the 300-pin MSA standard.



Each daughtercard connector provides 186 signals (plus 4 clocks) to its associated FPGA. The signals can be used with just about any setting of IOSTANDARD, and can be used differentially.



The daughter card interface includes a 400-pin MEG-Array connector, made by FCI. The daughter card header is arranged into three "Banks", correlating to the banks of IO on the Virtex 5 FPGA. Each of these banks connects to one or more "IO Banks" on the Virtex 5 FPGA. This allows three different sets of voltage or timing requirements to be met on a single daughter card simultaneously. Each Bank on the daughter card is 62 signals.

Other connections on the daughter card connector system include three dedicated, differential clock connections for inputting global clocks from an external source, power connections, bank VCCO power, a buffered power on reset signal.

# **25.1 Daughter Card Physical**

The connectors used in the expansion system are FCI MEG-Array 400-pin plug, 6mm, part #84520-102. This connector is capable of as much as 10Gbs transmission rates using differential signaling.

All daughter card expansion headers on the DN9002K10PCIE8T are located on the bottom side of the PWB. This is done to eliminate the need for resolving board-to-board clearance issues, assuming the daughter card uses no large components on the backside.

The "Plug" of the system is located on the DN9002K10PCIE8T, and the "receptacle" is located on the expansion board. This selection was made to give a greater height selection to the daughter card designer.

### 25.1.1 Daughter Card Locations and Mounting

The 400-pin daughtercard header is located on the bottom (solder) side near the right side of the board. Each MEG-Array header on a Dini Group product has four standard-position mountain holes. The drawing below shows the location of the daughter card header and it's associated mounting holes.



This view of the DN9002K10PCIE8T daughter card locations is from the top of the PCB, looking through to the bottom side. The Dini Group standard daughtercard, DNMEG\_OBS400 is compatible with the DN9002K10PCIE8T.

The mounting holes are designed to be used with 14mm, M3 standoffs. Dini Group has available appropriate mounting hardware on request:

#### Standoffs (Male-to-Female), Part 1789:

Harwin R30-3001402

(Mouser 855-R30-3001402)

"M3 x 14mm HEX 5mmA/F Harwin Metric Spacers RoHS: Compliant. Box/100"

Big Round Nuts, Part 1787:

LMI HN4600300

"M3 x 0.5mm

#### Screws, Part 1788:

MPMS 003-0005-PH

(Digi-key H742-ND)

"SCREW MACHINE METRIC PH M3x5MM"

With this host-plate-daughter card arrangement, there is a limited Z dimension clearance for backside components on the daughter card. This dimension is determined by the daughter card designer's part selection for the MEG-Array receptacle.



Note that the components on the topside of the daughter card and DN9002K10PCIE8T face in opposite directions.

### 25.1.2 Standard Daughtercard Size

The daughtercard mechanical provisions on the DN9002K10PCIE8T are designed to mount a hypothetical daughtercard with the dimensions given below. The "observation daughtercard", DNMEG400\_OBS product conforms to these dimensions.



The board edge constraints given above allow one daughtercard to be installed on all positions of the DN9002K10PCIE8T simultaneously.

#### 25.1.3 Insertion and removal

Due to the small dimensions of the very high speed Meg Array connector system, the pins on the plug and receptacle of the Meg Array connectors are very delicate.

When plugging in a daughter card, make sure to align the daughter card first before pressing on the connector. Be absolutely certain that both the small and the large keys at the narrow ends of the Meg Array line up BEFORE applying pressure to mate the connectors!



Place it down flat, then press down gently.



The following two excerpts are taken from the FCI application guide for the Meg Array series of connectors.

A part can be started from either end. Locate and match the [triangle] connector's A1 position marking for both the Plug and Receptacle. (Markings are located on the long side of the housing.) Rough alignment is required prior to connector mating as misalignment of >0.8mm could damage connector contacts. Rough alignment of the connector is achieved through matching the Small alignment slot of the plug housing with the Small alignment key of the receptacle housing and the large alignment slot with the large alignment key. Both connector housings have generous lead-in around the perimeter and will allow the user to blind mate assemble the connectors. Align the two connectors by feel and when the receptacle keys start into the plug slots, push down on one end and then move force forward until the receptacle cover flange bottoms on the front face of the plug.

Like mating, a connector pair can be unmated by pulling them straight apart. However, it requires less effort to un-mate if the force is originated from one of the slot/key ends of the assembly. (Reverse procedure from mating) Mating or un-mating of the connector by rolling in a direction perpendicular to alignment slots/keys may cause damage to the terminal contacts and is not recommended.

# **25.2 Daughter Card Electrical**

The daughter card pins out and routing were designed to allow use of the Virtex 5's 1 Gbps general purpose IO. All signals on the DN9002K10PCIE8T are all routed as differential, 50-Ohm (signal-to-ground) transmission lines. Signals can be used as single-ended also. Proper electrical levels are explained in the VCCO section.

No length-matching is done on the PCB for daughter card signals, (except between two ends of a differential pair). However, the Virtex 5 is capable of variable-delay input or output using the built-in IDELAY or ODELAY modules. A signal delay report is available here. Each delay is relative to the shortest delay and given in picoseconds.

| Signal Name | Reletive Delay (ps) | IO Delay Tap Value |
|-------------|---------------------|--------------------|
| CLK_DCA_0N  | 589                 | 0x4                |
| CLK_DCA_0P  | 588                 | 0x4                |
| CLK_DCA_1N  | 788                 | 0x1                |
| CLK_DCA_1P  | 780                 | 0x1                |
| CLK_DCB_0N  | 411                 | 0x6                |
| CLK_DCB_0P  | 411                 | 0x6                |
| CLK_DCB_1N  | 267                 | 0x8                |
| CLK_DCB_1P  | 267                 | 0x8                |
| DCA0N00     | 169                 | 0x9                |
| DCA0N01     | 201                 | 0x9                |
| DCA0N02     | 179                 | 0x9                |
| DCA0N03     | 116                 | 0xA                |
| DCA0N04     | 103                 | 0xA                |
| DCA0N05_V   | 254                 | 0x8                |
| DCA0N06     | 229                 | 0x8                |
| DCA0N07     | 116                 | 0xA                |
| DCA0N08_V   | 106                 | 0xA                |
| DCA0N09_V   | 248                 | 0x8                |
| DCA0N10     | 257                 | 0x8                |
| DCA0N11     | 128                 | 0xA                |
| DCA0N12_V   | 169                 | 0x9                |
| DCA0N13_C   | 190                 | 0x9                |
| DCA0N14     | 370                 | 0x7                |
| DCA0N15     | 122                 | 0xA                |
| DCA0N16_C   | 108                 | 0xA                |
| DCA0N17_C   | 154                 | 0x21<br>0x9        |
| DCA0N18     | 294                 | 0x9<br>0x8         |
| DCA0N19     | 82                  | 0xA                |
| DCA0N20_C   | 104                 | 0xA                |
| DCA0N21     | 403                 | 0x6                |
| DCA0N22     | 316                 | 0x7                |
| DCA0N23     | 142                 | 0xA                |
| DCA0N24     | 99                  | 0xA                |
| DCA0N25     | 293                 | 0x8                |
| DCA0N26     | 132                 | 0xA                |
| DCA0N27     | 253                 | 0x8                |
| DCA0N28     | 159                 | 0x9                |
| DCA0N29     | 187                 | 0x9                |
| DCA0N30     | 267                 | 0x8                |
| DCA0P00     | 174                 | 0x9                |
| DCA0P01     | 198                 | 0x9                |
| DCA0P02     | 180                 | 0x9                |
| DCA0P03     | 117                 | 0xA                |
| DCA0P04     | 107                 | 0xA                |
| DCA0P05     | 239                 | 0x8                |
| DCA0P06     | 228                 | 0x8                |
| DCA0P07     | 115                 | 0xA                |
| DCA0P08     | 99                  | 0xA<br>0xA         |
| DC/101 00   | //                  | UA/1               |

| DCA0P09   | 241 | 0x8 |
|-----------|-----|-----|
|           |     |     |
| DCA0P10   | 253 | 0x8 |
| DCA0P11   | 124 | 0xA |
| DCA0P12   | 164 | 0x9 |
| DCA0P13 C | 185 | 0x9 |
| _         |     |     |
| DCA0P14   | 377 | 0x7 |
| DCA0P15   | 122 | 0xA |
| DCA0P16 C | 112 | 0xA |
| _         |     |     |
| DCA0P17_C | 151 | 0x9 |
| DCA0P18   | 296 | 0x8 |
| DCA0P19   | 87  | 0xA |
|           |     |     |
| DCA0P20_C | 107 | 0xA |
| DCA0P21   | 411 | 0x6 |
| DCA0P22   | 322 | 0x7 |
| DCA0P23   | 137 | 0xA |
|           |     |     |
| DCA0P24   | 102 | 0xA |
| DCA0P25   | 299 | 0x8 |
| DCA0P26   | 122 | 0xA |
|           |     |     |
| DCA0P27   | 256 | 0x8 |
| DCA0P28   | 161 | 0x9 |
| DCA0P29   | 191 | 0x9 |
|           |     |     |
| DCA0P30   | 259 | 0x8 |
| DCA1N01   | 206 | 0x9 |
| DCA1N02   | 259 | 0x8 |
|           |     |     |
| DCA1N03   | 283 | 0x8 |
| DCA1N04   | 152 | 0x9 |
| DCA1N05   | 175 | 0x9 |
|           |     |     |
| DCA1N06   | 0   | 0xB |
| DCA1N07_V | 163 | 0x9 |
| DCA1N08   | 122 | 0xA |
| DCA1N09   | 34  | 0xB |
|           |     |     |
| DCA1N10_V | 21  | 0xB |
| DCA1N11_V | 303 | 0x8 |
| DCA1N12   | 123 | 0xA |
| DCA1N13   |     |     |
|           | 48  | 0xB |
| DCA1N14_V | 100 | 0xA |
| DCA1N15_C | 166 | 0x9 |
| DCA1N16   | 274 | 0x8 |
|           |     |     |
| DCA1N17   | 231 | 0x8 |
| DCA1N18_C | 12  | 0xB |
| DCA1N19_C | 117 | 0xA |
|           |     |     |
| DCA1N20   | 150 | 0x9 |
| DCA1N21   | 111 | 0xA |
| DCA1N22 C | 24  | 0xB |
| DCA1N23   | 179 | 0x9 |
|           |     |     |
| DCA1N24   | 140 | 0xA |
| DCA1N25   | 83  | 0xA |
| DCA1N26   | 23  | 0xB |
|           |     |     |
| DCA1N27   | 81  | 0xA |
| DCA1N28   | 179 | 0x9 |
| DCA1N29   | 80  | 0xA |
| DCA1N30   | 99  | 0xA |
|           |     |     |
| DCA1N31   | 45  | 0xB |
| DCA1P01   | 205 | 0x9 |
| DCA1P02   | 255 | 0x8 |
|           |     |     |
| DCA1P03   | 292 | 0x8 |
| DCA1P04   | 148 | 0xA |
| DCA1P05   | 181 | 0x9 |
| DCA1P06   | 7   | 0xB |
|           |     |     |
| DCA1P07   | 152 | 0x9 |
| DCA1P08   | 119 | 0xA |
| DCA1P09   | 36  | 0xB |
|           |     |     |
| DCA1P10   | 14  | 0xB |
| DCA1P11   | 304 | 0x8 |
| DCA1P12   | 120 | 0xA |
|           |     |     |
| DCA1P13   | 42  | 0xB |
| DCA1P14   | 93  | 0xA |
| DCA1P15_C | 169 | 0x9 |
|           |     | JAJ |
|           |     |     |

| DCA1P16   | 266 | 0x8 |
|-----------|-----|-----|
|           |     |     |
| DCA1P17   | 234 | 0x8 |
| DCA1P18_C | 14  | 0xB |
| DCA1P19 C | 118 | 0xA |
| _         |     |     |
| DCA1P20   | 144 | 0xA |
| DCA1P21   | 115 | 0xA |
| DCA1P22 C | 24  | 0xB |
| _         |     |     |
| DCA1P23   | 177 | 0x9 |
| DCA1P24   | 140 | 0xA |
|           |     |     |
| DCA1P25   | 85  | 0xA |
| DCA1P26   | 24  | 0xB |
| DCA1P27   | 83  | 0xA |
|           |     |     |
| DCA1P28   | 176 | 0x9 |
| DCA1P29   | 82  | 0xA |
| DCA1P30   | 101 | 0xA |
|           |     |     |
| DCA1P31   | 45  | 0xB |
| DCA2N01   | 488 | 0x5 |
|           |     |     |
| DCA2N02   | 578 | 0x4 |
| DCA2N03   | 556 | 0x4 |
| DCA2N04   | 366 | 0x7 |
|           |     |     |
| DCA2N05_V | 555 | 0x4 |
| DCA2N06   | 629 | 0x3 |
| DCA2N07   | 450 | 0x6 |
|           |     |     |
| DCA2N08_V | 425 | 0x6 |
| DCA2N09 V | 674 | 0x3 |
| _         |     |     |
| DCA2N10   | 396 | 0x6 |
| DCA2N11   | 433 | 0x6 |
| DCA2N12 V | 783 | 0x1 |
| _         |     |     |
| DCA2N13_C | 490 | 0x5 |
| DCA2N14   | 388 | 0x6 |
|           | 328 |     |
| DCA2N15   |     | 0x7 |
| DCA2N16_C | 361 | 0x7 |
| DCA2N17_C | 539 | 0x4 |
| _         |     |     |
| DCA2N18   | 783 | 0x1 |
| DCA2N19   | 751 | 0x2 |
| DCA2N20_C | 741 | 0x2 |
| _         |     |     |
| DCA2N21   | 376 | 0x7 |
| DCA2N22   | 811 | 0x1 |
| DCA2N23   | 340 | 0x7 |
|           |     |     |
| DCA2N24   | 253 | 0x8 |
| DCA2N25   | 579 | 0x4 |
|           |     |     |
| DCA2N26   | 448 | 0x6 |
| DCA2N27   | 661 | 0x3 |
| DCA2N28   | 778 | 0x1 |
|           |     |     |
| DCA2N29   | 729 | 0x2 |
| DCA2N30   | 966 | 0x0 |
| DCA2N31   | 953 | 0x0 |
|           |     |     |
| DCA2P01   | 490 | 0x5 |
| DCA2P02   | 576 | 0x4 |
|           |     | 0x4 |
| DCA2P03   | 551 |     |
| DCA2P04   | 368 | 0x7 |
| DCA2P05   | 553 | 0x4 |
|           |     |     |
| DCA2P06   | 637 | 0x3 |
| DCA2P07   | 451 | 0x6 |
| DCA2P08   | 409 | 0x6 |
|           |     |     |
| DCA2P09   | 668 | 0x3 |
| DCA2P10   | 389 | 0x6 |
| DCA2P11   | 434 | 0x6 |
|           |     |     |
| DCA2P12   | 773 | 0x1 |
| DCA2P13 C | 481 | 0x5 |
| DCA2P14   | 388 | 0x6 |
|           |     |     |
| DCA2P15   | 332 | 0x7 |
| DCA2P16_C | 365 | 0x7 |
| _         |     |     |
| DCA2P17_C | 534 | 0x5 |
| DCA2P18   | 776 | 0x1 |
| DCA2P19   | 749 | 0x2 |
|           |     |     |
| DCA2P20_C | 739 | 0x2 |
| DCA2P21   | 375 | 0x7 |
|           |     |     |

| DCA2P22                                  | 804                    | 0x1                      |
|------------------------------------------|------------------------|--------------------------|
|                                          |                        |                          |
| DCA2P23                                  | 337                    | 0x7                      |
| DCA2P24                                  | 255                    | 0x8                      |
| DCA2P25                                  | 573                    | 0x4                      |
|                                          |                        |                          |
| DCA2P26                                  | 456                    | 0x6                      |
| DCA2P27                                  | 670                    | 0x3                      |
| DCA2P28                                  | 773                    | 0x1                      |
|                                          |                        |                          |
| DCA2P29                                  | 719                    | 0x2                      |
| DCA2P30                                  | 962                    | 0x0                      |
| DCA2P31                                  | 958                    | 0x0                      |
|                                          |                        |                          |
| DCB0N00                                  | 269                    | 0x8                      |
| DCB0N01                                  | 275                    | 0x8                      |
| DCB0N02                                  | 234                    | 0x8                      |
|                                          |                        |                          |
| DCB0N03                                  | 211                    | 0x9                      |
| DCB0N04                                  | 145                    | 0xA                      |
| DCB0N05_V                                | 257                    | 0x8                      |
| _                                        |                        |                          |
| DCB0N06                                  | 294                    | 0x8                      |
| DCB0N07                                  | 171                    | 0x9                      |
| DCB0N08_V                                | 113                    | 0xA                      |
| _                                        |                        |                          |
| DCB0N09_V                                | 230                    | 0x8                      |
| DCB0N10                                  | 261                    | 0x8                      |
| DCB0N11                                  | 113                    |                          |
|                                          |                        | 0xA                      |
| DCB0N12_V                                | 143                    | 0xA                      |
| DCB0N13_C                                | 191                    | 0x9                      |
| _                                        | 132                    | 0xA                      |
| DCB0N14                                  |                        |                          |
| DCB0N15                                  | 138                    | 0xA                      |
| DCB0N16_C                                | 76                     | 0xA                      |
| _                                        |                        |                          |
| DCB0N17_C                                | 199                    | 0x9                      |
| DCB0N18                                  | 129                    | 0xA                      |
| DCB0N19                                  | 116                    | 0xA                      |
| DCB0N20 C                                | 63                     | 0xB                      |
| _                                        |                        |                          |
| DCB0N21                                  | 246                    | 0x8                      |
| DCB0N22                                  | 270                    | 0x8                      |
| DCB0N23                                  | 93                     | 0xA                      |
|                                          |                        |                          |
| DCB0N24                                  | 37                     | 0xB                      |
| DCB0N25                                  | 337                    | 0x7                      |
| DCB0N26                                  | 267                    | 0x8                      |
|                                          |                        |                          |
| DCB0N27                                  | 226                    | 0x9                      |
| DCB0N28                                  | 418                    | 0x6                      |
| DCB0N29                                  | 67                     | 0xB                      |
|                                          |                        |                          |
| DCB0N30                                  | 137                    | 0xA                      |
| DCB0P00                                  | 267                    | 0x8                      |
| DCB0P01                                  | 284                    | 0x8                      |
| DCB0P02                                  | 241                    |                          |
|                                          |                        | 0x8                      |
| DCB0P03                                  | 212                    | 0x9                      |
| DCB0P04                                  | 144                    | 0xA                      |
| DCB0P05                                  | 254                    | 0x8                      |
|                                          |                        |                          |
| DCB0P06                                  | 286                    | 0x8                      |
| DCB0P07                                  | 170                    | 0x9                      |
|                                          |                        |                          |
| DCB0P08                                  | 106                    | 0xA                      |
| DCB0P09                                  | 216                    | 0x9                      |
| DCB0P10                                  | 273                    | 0x8                      |
| DCB0P11                                  |                        |                          |
|                                          | 115                    | 0xA                      |
| DCB0P12                                  | 136                    | 0xA                      |
| DCB0P13 C                                | 187                    | 0x9                      |
| DCB0P14                                  | 133                    | 0xA                      |
|                                          |                        |                          |
| DCB0P15                                  | 141                    | 0xA                      |
| DCB0P16_C                                | 78                     | 0xA                      |
| DCB0P17 C                                | 204                    | 0x9                      |
| - · · · · · - · · - · · · · · · · · · ·  |                        |                          |
| DCB0P18                                  | 131                    | 0xA                      |
| DCB0P19                                  | 121                    | 0xA                      |
| DCB0P20_C                                |                        | 0xB                      |
|                                          | 67                     |                          |
| _                                        | 67                     |                          |
| DCB0P21                                  | 67<br>251              | 0xB                      |
| _                                        |                        |                          |
| DCB0P21<br>DCB0P22                       | 251<br>272             | 0x8<br>0x8               |
| DCB0P21<br>DCB0P22<br>DCB0P23            | 251<br>272<br>90       | 0x8<br>0x8<br>0xA        |
| DCB0P21<br>DCB0P22<br>DCB0P23<br>DCB0P24 | 251<br>272<br>90<br>39 | 0x8<br>0x8<br>0xA<br>0xB |
| DCB0P21<br>DCB0P22<br>DCB0P23            | 251<br>272<br>90       | 0x8<br>0x8<br>0xA        |
| DCB0P21<br>DCB0P22<br>DCB0P23<br>DCB0P24 | 251<br>272<br>90<br>39 | 0x8<br>0x8<br>0xA<br>0xB |

| DCB0P27   | 227 | 0x8 |
|-----------|-----|-----|
| DCB0P28   | 410 | 0x6 |
| DCB0P29   | 70  | 0xB |
| DCB0P30   |     |     |
|           | 143 | 0xA |
| DCB1N00   | 92  | 0xA |
| DCB1N01   | 216 | 0x9 |
| DCB1N02   | 184 | 0x9 |
| DCB1N03   | 226 | 0x9 |
| DCB1N04   | 246 | 0x8 |
| DCB1N05   | 96  | 0xA |
| DCB1N06   | 73  | 0xA |
|           |     |     |
| DCB1N07_V | 328 | 0x7 |
| DCB1N08   | 106 | 0xA |
| DCB1N09   | 114 | 0xA |
| DCB1N10_V | 162 | 0x9 |
| DCB1N11_V | 307 | 0x7 |
| DCB1N12   | 149 | 0x9 |
| DCB1N13   | 331 | 0x7 |
|           |     |     |
| DCB1N14_V | 85  | 0xA |
| DCB1N15_C | 141 | 0xA |
| DCB1N16   | 369 | 0x7 |
| DCB1N17   | 303 | 0x8 |
| DCB1N18 C | 95  | 0xA |
| DCB1N19 C | 152 | 0x9 |
| DCB1N20   | 397 | 0x6 |
| DCB1N21   |     | 0x0 |
|           | 102 |     |
| DCB1N22_C | 43  | 0xB |
| DCB1N23   | 475 | 0x5 |
| DCB1N24   | 111 | 0xA |
| DCB1N25   | 100 | 0xA |
| DCB1N26   | 75  | 0xA |
| DCB1N27   | 228 | 0x8 |
| DCB1N28   | 93  | 0xA |
| DCB1N29   | 148 | 0xA |
|           |     |     |
| DCB1N30   | 105 | 0xA |
| DCB1P00   | 94  | 0xA |
| DCB1P01   | 221 | 0x9 |
| DCB1P02   | 186 | 0x9 |
| DCB1P03   | 219 | 0x9 |
| DCB1P04   | 248 | 0x8 |
| DCB1P05   | 100 | 0xA |
| DCB1P06   | 76  | 0xA |
|           |     |     |
| DCB1P07   | 329 | 0x7 |
| DCB1P08   | 114 | 0xA |
| DCB1P09   | 115 | 0xA |
| DCB1P10   | 154 | 0x9 |
| DCB1P11   | 290 | 0x8 |
| DCB1P12   | 147 | 0xA |
| DCB1P13   | 327 | 0x7 |
|           |     |     |
| DCB1P14   | 69  | 0xB |
| DCB1P15_C | 139 | 0xA |
| DCB1P16   | 377 | 0x7 |
| DCB1P17   | 301 | 0x8 |
| DCB1P18_C | 90  | 0xA |
| DCB1P19 C | 148 | 0xA |
| DCB1P20   | 388 | 0x6 |
| DCB1P21   | 110 | 0xA |
|           |     |     |
| DCB1P22_C | 43  | 0xB |
| DCB1P23   | 486 | 0x5 |
| DCB1P24   | 113 | 0xA |
| DCB1P25   | 102 | 0xA |
| DCB1P26   | 74  | 0xA |
| DCB1P27   | 234 | 0x8 |
| DCB1P28   | 90  | 0xA |
|           |     |     |
| DCB1P29   | 151 | 0x9 |
| DCB1P30   | 105 | 0xA |
| DCB2N00   | 371 | 0x7 |
| DCB2N01   | 166 | 0x9 |
|           |     |     |

| DCB2N02   | 399 | 0x6 |
|-----------|-----|-----|
| DCB2N03   | 696 | 0x2 |
| DCB2N04   | 151 | 0x9 |
| DCB2N05 V | 522 | 0x5 |
| _         |     |     |
| DCB2N06   | 585 | 0x4 |
| DCB2N07   | 319 | 0x7 |
| DCB2N08_V | 112 | 0xA |
| DCB2N09_V | 405 | 0x6 |
| DCB2N10   | 463 | 0x5 |
| DCB2N11   | 298 | 0x8 |
| DCB2N12_V | 212 | 0x9 |
| DCB2N13 C | 236 | 0x8 |
|           |     |     |
| DCB2N14   | 225 | 0x9 |
| DCB2N15   | 276 | 0x8 |
| DCB2N16_C | 226 | 0x9 |
| DCB2N17_C | 345 | 0x7 |
| DCB2N18   | 281 | 0x8 |
| DCB2N19   | 245 | 0x8 |
| DCB2N20_C | 163 | 0x9 |
| DCB2N21   | 269 | 0x8 |
|           |     |     |
| DCB2N22   | 448 | 0x6 |
| DCB2N23   | 262 | 0x8 |
| DCB2N24   | 222 | 0x9 |
| DCB2N25   | 160 | 0x9 |
| DCB2N26   | 114 | 0xA |
| DCB2N27   | 350 | 0x7 |
| DCB2N28   | 367 | 0x7 |
| DCB2N29   | 512 | 0x5 |
| DCB2N30   | 142 | 0xA |
| DCB2P00   | 378 | 0x7 |
| DCB2P01   | 165 | 0x9 |
|           |     |     |
| DCB2P02   | 406 | 0x6 |
| DCB2P03   | 708 | 0x2 |
| DCB2P04   | 155 | 0x9 |
| DCB2P05   | 524 | 0x5 |
| DCB2P06   | 574 | 0x4 |
| DCB2P07   | 312 | 0x7 |
| DCB2P08   | 105 | 0xA |
| DCB2P09   | 406 | 0x6 |
| DCB2P10   | 467 | 0x5 |
| DCB2P11   | 303 | 0x8 |
| DCB2P12   |     | 0x9 |
|           | 207 |     |
| DCB2P13_C | 238 | 0x8 |
| DCB2P14   | 226 | 0x9 |
| DCB2P15   | 280 | 0x8 |
| DCB2P16_C | 224 | 0x9 |
| DCB2P17_C | 341 | 0x7 |
| DCB2P18   | 279 | 0x8 |
| DCB2P19   | 246 | 0x8 |
| DCB2P20_C | 158 | 0x9 |
| DCB2P21   | 262 | 0x8 |
| DCB2P22   | 441 | 0x6 |
|           |     |     |
| DCB2P23   | 263 | 0x8 |
| DCB2P24   | 227 | 0x8 |
| DCB2P25   | 161 | 0x9 |
| DCB2P26   | 115 | 0xA |
| DCB2P27   | 352 | 0x7 |
| DCB2P28   | 359 | 0x7 |
| DCB2P29   | 501 | 0x5 |
| DCB2P30   | 143 | 0xA |
|           |     |     |

# 25.2.1 Pin assignments

The pin out of the DN9002K10PCIE8T expansion system was designed to reduce cross talk to manageable levels while operating at full speed of the Virtex 5. The ground to signal ratio of the connector is 1:1. General purpose IO is arranged in a GSGS pattern to allow high speed single-

ended or differential use. On the DN9002K10PCIE8T (host), these signals are routed as loosely-coupled differential signals, meaning when used differentially, they benefit from the noise-resistant properties of a differential pair, but when used single-ended-ly, do not interfere with each other excessively.





All high-speed signals on the DN9002K10PCIE8T, including daughter card signals, are routed against a ground potential reference plane. When creating a daughter card, it is recommended that these signals remain against a ground plane to maintain trace impedance.

The central columns of the connector pin out use a closely coupled, differential pair pin arrangement, which is uniformly surrounded by ground pins.

Below is a graphic representation of the pin assignments for the 400-pin connectors. Note that this is a view from the backside of the connector. The green boxes represent ground connections.

Special purpose pins are described below.

### 25.2.2 CC, VREF, DCI

Some of the signals connected to the daughter card expansion headers are "clock-capable"; the inputs on the Virtex 5 FPGA can be used for source-synchronous clocking. In the schematic and customer netlist on the user CD, these pins contain a "\_C" in the pin name.

Pins declared in the above diagram that are underlined are connected to "VREF" pins on the Virtex 5 FPGA. These FPGA pins are used to supply a voltage reference used as the threshold voltage for the signals on that bank. The use of these pins is only necessary when using threshold standards, such as SSTL.

DCI is used on all FPGA IO banks connected to a daughter card header. The reference resistance is 50 Ohms. Each Virtex 5 bank that is connected to a header DCI in enabled.

#### 25.2.3 Global clocks

The daughter card pin out defines 6 clock output pins. These clock outputs are intended to be used a 3 differential signals (LVDS). Two clock signals GCA and GCB connect to the "GC" clock inputs on the FPGA. These clocks can be used only by the FPGA that is associated with the header.

The GCC signal driven from each FPGA connects to a global clock buffer and can be used by all of the FPGAs on the DN9002K10PCIE8T. (EXT0 and EXT1 networks). Since daughter cards E and F share the same clock network (EXT1), only one of these two daughtercards can drive a global clock at one time.

## 25.2.4 Timing and Clocking

Signal from the FPGAs to the daughtercard connector are not length-matched. The maximum trace length on the DN9002K10PCIE8T board for these signals is 800ps.

Each daughtercard has a global clock output pair "DCCLKCp/n". This LVDS output is distributed on the DN9002K10PCIE8T to all Virtex-5 FPGAs. The clock buffer on the host board is designed to deliver the clock edge to all FPGA synchronized with the CCLK pin on the daughtercard header. The daughtercard is expected to distribute clocks on it so that ICs on the

daughtercard receive the clock signal synchronized with the pin on the daughtercard header. In this way, the host and daughter boards should be able to communicate synchronously with equal, large IO periods in each direction.

There are three methods of communicating FPGA-to-FPGA across the daughtercard interface.

#### **Local Synchronous**

The daughtercard generates a clock and drives it over the GCAp/n or GCBp/n clock pins to the host board FPGA. The daughtercard drives a synchronized clock to the logic on the daughtercard, adding 0.5ns delay to account for the trace delay on the DN9002K10PCIE8T. The host FPGA will use a DCM in zero-delay mode, and the logic on the daughtercard should have a low clock-to-out and setup times (or use a DCM). This method has the disadvantage of only allowing the one FPGA attached to the daughtercard to use this frequency. To communicate globally across the DN9002K10PCIE8T, the user would have to pass the data across clock domains.

#### **Global Synchronous**

The daughter card generates a clock and drives it over the GCCp/n pins to the DN9002K10PCIE8T host board. The user will select the daughtercard source for either the EXT0 or EXT1 networks as appropriate. The user sets the EXT0 or EXT1 network into zero-delay mode (Contact <a href="support@dinigroup.com">support@dinigroup.com</a>). The disadvantage of this method is that the EXT0 or EXT1 network must be used, and that the zero-delay configuration has to be calculated for you by us. The advantage is that the entire system can be operated on a single clock domain.

Zero-delay on the DN9002K10PCIE8T is allowed by enabling PLL devices (zero-delay buffers) connected to the GCC pins of each daughtercard header. To allow for a very wide range of clock frequencies sourced from the daughtercard, the PLL bandwidth of these buffers must be manually set. This can be done via USB, PCIe or Compact Flash. The PLL can also be bypassed, allowing a global system-synchronous clock to be used without configuring this PLL. To use this method, the user will have to experimentally find the proper clock phase to use on the IO of the daughter card.

#### **Source Synchronous**

The daughtercard drives a clock into the CC pins of the daughtercard connector. This clock is used to latch IOs. This method should be used for frequencies exceeding 150MHz, because the phase-tolerance of the Virtex 5 FPGA and the clock buffer devices on the DN9002K10PCIE8T EXT0 and EXT1 signals will prevent a reliable system-synchronous design at high speeds.

#### 25.2.5 Power and Reset

The +3.3V, +5.0V and +12V power rails are supplied to the Daughter card headers. Each pin on the MEG-Array connector is rated to tolerate 1A of current without thermal overload. Most of the power available to daughter cards through the connector comes from the two 12V pins, for a total of 24W. Each power rail supplied to the Daughter card is fused with a reset-able

switch. Daughter cards are required to provide their own power supply bypassing and onrush current limiting.



The RSTn signal to the daughter card is an open-drain, buffered copy of the SYS\_RST# signal. It is also asserted when the User Reset is active. When RSTn is de-asserted, the +3.3V, +5.0V and +12V power rails are guaranteed to be within the DN9002K10PCIE8T tolerance. If there are additional power requirements, the daughter card is required to ensure these.

### 25.2.6 VCCO Voltage

The daughter card is required to provide a voltage on the VCCO pin on the connector. This voltage is used on the DN9002K10PCIE8T to power the FPGA IOs that are connected with that daughter card. In this way, the daughter card can control what voltage the interface will use.

Each bank of the connector (B0, B1, or B2) uses a separate VCCO pin, and can have a different voltage applied to it. When designing a daughter card, you must determine the current requirements for the DN9002K10PCIE8T and supply enough current capacity on these pins.

The VCCO voltage impressed by the daughter card should be less than 3.75 to prevent damage to the Virtex 5 IOs connected to that daughter card. Additionally, the voltage applied to the header pins from a daughtercard or external source, should be equal to or less than the VCCO voltage of the bank that contains the IO. For example, a 2.5V daughtercard (one that uses 2.5V on each VCCO pin) should not drive a 3.3V signal onto the daughtercard pins.

### 25.2.7 VCCO bias generation

Since a daughter card will not always be present on a daughter card connector, a VCCO bias generator is used on the motherboard for each daughter card bank to keep the VCCO pin on the FPGA within its recommended operating range. The VCCO bias generators supply +1.2V to the VCCO pins on the FPGAs, and are back-biased by the daughter card when it drives the VCCO rails.



The output voltage of this regulator can be adjusted if needed. This will require changing the resistors on the ADJ pin of the regulators. The bias regulators can provide up to 1.5A of current. Some low-speed designs may not need more than this. Dini Group recommends placing the IO voltage regulators on the daughtercards, because this does not require modification of the DN9002K10PCIE8T.

### 25.3 Rolling your own daughtercard

Small quantities of the connectors required for building a daughtercard can be obtained at cost from the Dini Group.

If you need help designing a daughtercard, we will be happy to review your schematic for errors. Send it.

# **26Troubleshooting**

#### 26.1 The board is dead

If the board is not responding at all (when connected to a Windows XP computer, there is no "Dini Emulation Engine" in the hardware manager) the board may be stuck in reset. Check the power failure LEDs. If any of them are red, then the board is stuck in reset due to a power problem. If the failing voltage is 3.3V, 5V, or 12V, then the problem is probably caused by your power supply. Check the voltages of these power rails and make sure they are within at least 5% of their nominal voltages. If the power supply was the one supplied by Dini Group, make sure that the voltage trim faceplate is connected. This faceplate allows trimming the 3.3, 5.0 and 12V outputs up and down for performance reasons. If the plate is not connected, all of the power supply's outputs default to their lowest settings. This will cause the Dini Group board to reset due to under-voltage.

If the board is not in reset, the RS232 terminal will be active. Connect a computer serial port to this header and open a terminal program on the computer. Start->Programs->Accessories-

>Communication->HyperTerminal is a suitable program. We use VanDyke software SecureCRT program, because it doesn't suck. Hopefully the RS232 configuration status dump will tell you exactly what the problem is. In any case, the Dini Group will need this capture to diagnose the problem.

# 26.2 The FPGAs won't program

First, connect the RS232 terminal and follow the instructions in the preceding paragraph. Usually, when an FPGA fails to program, the configuration section will detect the problem and print an error message to this terminal. Common problems the configuration section might report are:

- The syntax in the main.txt file is incorrect
- The bit file on the CompactFlash card is for the wrong type of FPGA
- The CompactFlash card is not formatted with a file system that the DN9002K10PCIE8T can read

If the DN9002K10PCIE8T reports about one or more FPGAs that "DONE did not go high", then there is a problem with the bit file. The bit file may have been generated using bitgen options that are not compatible with the DN9002K10PCIE8T.

See if the FPGAs will configure using USB, PCIe or JTAG.

When you contact Dini Group for support, we will need a capture of the RS232 terminal output.

# 26.3 My design doesn't do anything

Make sure that the clock your design uses is running. Output the clock to an LED and probe it with an oscilloscope.

Check the pin out in your constraint file. Check the .PAR report file to make sure that 100% of your IOBs used have LOC constraints. There is never a reason not to constrain an IO.

Use the .PAD report to make sure your constraints were all applied. Some situations may cause constraints to be ignored.

Double-check that the connections match between your FPGA pins and the daughtercard pins using the schematic.

If "MainBus" interface is not working, make sure that none of the other FPGAs are driving those MB pins.

Make sure that the "Unused IOBs" option in bitgen is set to "Float

Check for Timing errors in the timing report

Route the clock signal to a pin and observe it with an oscilloscope.

### 26.4 The DCMs won't lock

1) The DCMs are required to be set in a frequency mode compatible with the frequency of the reference clock input. Check the following attributes of the DCMs. DFS\_FREQUENCY\_MODE

DFS\_PERFORMANCE\_MODE

- 2) All clock inputs of the DCM are required to be stable for a certain number of microseconds before releasing the DCMs reset signal. If you are generating the reference clock from an FPGA (or another DCM), you will need to build a delayed-reset circuit to reset the second DCM.
- 3) Make sure the global clock you are using is being received with an LVDS receiver, not a single-ended one. Make sure the DIFF\_TERM attribute is turned on (especially low frequency clocks).

# 26.5 The signal on my board is going crazy on my oscilloscope

Make sure the ground clip is attached to the probe.

If there is an oscillation on the signal at 60Hz, there is a problem with the oscilloscope setup.

Capture the oscilloscope view and email it to <a href="mailto:support@dinigroup.com">support@dinigroup.com</a>.

# **Chapter 5: Reference Design**

This chapter introduces the DN9002K10PCIE8T Reference Design, including information on what the reference design does, how to build it from the source files, and how to modify it for another application.

# 1 Purpose

The purpose of the reference design includes the following:

Provide a means to test board hardware for failure.

Give users an understanding of the code necessary to use each interface provided in hardware

Provide a starting point for using a tool design flow

# 1.1 Interfaces used by reference design

The reference design helps users by showing them how using each interface is possible. Code is provided as-is, and is intended as proof-of-concept on each interface advertised for the DN9002K10PCIE8T product. The Dini Group warrants only that the DN9002K10PCIE8T hardware is functional and usable. The interfaces that the Dini Group design exercises and provides examples for are:

Access to the DDR2 SDRAM Modules at 250MHz FPGA Configuration interfaces over PCI Express, USB, JTAG and Compact Flash

RS232 Communication

FPGA Interconnect at high speed techniques. High-Speed PCIe (DMA mode to FPGA A)

MainBus interface (for USB and PCIe communication)

Blink LEDs in cool patterns.

Reset Button

New internal Virtex-5 features (PLL, ODELAY, 550MHz clocking, and 800Mbs IO)

Set global clocks

Ethernet

All source code for the reference design is included on the CD and may be used freely in customer development. Precompiled bit files for the FPGA types that are installed on your board are provided.

and can be used to verify board functionality before beginning development. A build utility, described in the section <u>Compiling The Reference Design</u>, can be used to generate new bit files, or to generate bit files for less common configurations of the DN9002K10PCIE8T.

### 2 Hardware Tests

The provided bit files and software is suitable for testing most of the hardware interfaces on your board. Some hardware tests require test fixtures, and these are not provided.

### 2.1.1 Testing PCI Express interface

Install the board into a windows machine in a PCI Express x16 or x8 slot (other slots will cause the test to erroneously report a failure). Turn on the machine. Run the provided executable aetest\_wdm.exe. From the main menu, select "production tests" and then "pci test".

The test should report PASS or FAIL.

### 2.1.2 Testing FPGA-to-FPGA interconnect

To test the FPGA interconnect, you will need to run the "one-shot test". This is a feature of the windows program USB Controller.exe. Turn on the board and connect it to a windows computer over USB.

From the "settings/info" menu, select "one shot test". Enter in one of the text boxes the path to your user CD where the bit files are kept. Unselect "DDR" from the test options, so that only interconnect is tested.

# 2.1.3 Testing DDR2 Interfaces

Turn on the board and connect it to a windows machine.

To test the DDR2 interface(s), configure an FPGA which has a DDR2 interface with the "Main" reference design. Install a DDR2 SODIMM into the socket of the FPGA.

In USB Controller, click the "enable USB communication" button. Then, set the global clock networks to the following frequencies:

G0 100MHz G1 250MHz

G2 200MHz

The frequency of network G1 determines the DDR2 frequency of operation. From the "settings/info" menu, select "Test DDR". In the dialog box, select the FPGA which is configured. The test will report PASS or FAIL.

### 2.1.4 Testing USB

USB can be tested by running the DDR2 test, or by configuring FPGAs over USB.

### 2.1.5 Testing Ethernet

This test can be performed by the user, however bit files are not provided. If you suspect a hardware failure you will have to contact technical support.

### 2.1.6 Testing Daughtercard Connectors

This test requires a test fixture and cannot be performed by the user.

# 3 Reference Design Types

"The Reference Design" in this chapter refers to the FPGA designs located on the user CD at D:\FPGA\_Reference\_Designs\DN9002K10PCIE8T\MainRef\
D:\FPGA\_Reference\_Designs\Programming\_Files\DN9002K10PCIE8T\MainRef\

Four other self-contained designs are on the CD and described in this manual. These four designs are described in their own sections later in this chapter. The remaining sections describe the "MainTest" design. "MainTest", "MainRef", "The reference design" and "The Dini Group reference design" are the same thing.

The four additional designs are

PCIe Interface Design: Tests the 64-bit interface between FPGA A and the LX50T (PCIe) LVDS Reference Design: Characterizes the FPGA interconnect using source-synchronous Ethernet Reference Design: Tests the Ethernet PHY.

Other features of the board, such as memory sockets and daughtercard headers are tested using the Main Test.

#### 3.1 Main Test

This reference design is also referred to as "SINGLE INTERCON", because it is used to test the FPGA-to-FPGA interconnect. This reference design provides access to the following:

- -All FPGA clocks
- -DDR2 memory
- -MainBus (for USB and PCI Express)
- -RS232
- -"Tenth Inch" header pins

### **3.2 LVDS**

This reference design is an implementation of Xilinx App Note 705. It achieves 900 Mt/sec per LVDS pair between FPGAs, the maximum speed possible using this method. (Other methods may improve bandwidth beyond this limit). The design provides MainBus registers to allow counting the bit error rate of each bank of 40 interconnect pins.

# 3.3 Single Fast

This reference design allows the characterization of FPGA-to-FPGA interconnect using standard synchronous IO methods between FPGAs. Main Bus registers are provided to allow the monitoring of the BER of each bank of 40 interconnect pins.

### 3.4 V5 Interconnect

This reference design might not be provided.

### 3.5 Ethernet

This reference design is a hardware test of the Ethernet interface. It may not be provided.

### 3.6 Header

This reference design is a hardware test of the Header interface. It requires a test fixture to work properly. It may not be provided.

# 4 Using the Reference Design

# 4.1 Reference Design Memory Map

Each reference design uses the MainBus interface to supply status and controls. The following memory map is used. These registers are accessible using the windows USB Controller program using the "MainBus" menu, or from AETEST for PCI Express access.

All addresses on main bus are 32-bits. Each address contains one 32-bit word. By convention, each FPGA has a fixed memory range. FPGA A will respond to all MB accesses in the range 0x00000000 – 0x0FFFFFFF. FPGA B will respond to accesses from 0x10000000-0x1FFFFFFF. Other addresses are not defined.

The addresses given below are offsets from the base address of any given FPGA. Some registers are not valid for all FPGAs. Some addresses are not valid for all of the Dini Group's reference designs. (Main Test does not have LVDS registers, and LVDS test does not have DDR2 registers).

Some of the address bits are decoded as "Don't care" bits. Therefore, accesses to undefined addresses may alter stuff.

#### THE REFERENCE DESIGN

| Address<br>Range                                                                                                     | Register<br>Name                                                                                         | Registe            | r<br>Contents                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00000000 -<br>0x07FFFFFF                                                                                           | DDR2                                                                                                     |                    | The data contained in the DDR2 SODIMM memory                                                                                                                                                                                                                                |
| 0x08000001                                                                                                           | DDR2HIADD                                                                                                | R                  | The upper bits of DDR2 address (MainBus memory space is smaller than most DDR2 SODIMMs)                                                                                                                                                                                     |
| 0x08000002<br>0x08000003<br>0x08000004                                                                               | IDCODE<br>DDR2HIADD<br>INTERCONT                                                                         |                    | 0x05000142 The number of valid addresses in DDR2HIADDR An ID code used to identify which design is loaded 0x34561111 – Interconnect, Single 0x34562222 – Interconnect, LVDS 0x34563333 – Interconnect, LVDS (reversed) 0x34560000 – Any Other Design (PCIe, Ethernet, etc.) |
| 0x08000005                                                                                                           | DDR2SIZE                                                                                                 |                    | A code to control how DDR2 memory is coded into MainBus memory                                                                                                                                                                                                              |
| 0x08000006<br>0x08000007                                                                                             | RWREG<br>DDR2TAPCN                                                                                       | Т0                 | Read/Write Scratch Register for testing The current "tap" settings of the IODELAY elements in the DQ IO buffers on the DDR2 interface (lower bytes)                                                                                                                         |
| 0x08000008                                                                                                           | DDR2TAPCN                                                                                                | T1                 | The current "tap" settings of the IODELAY elements in the DQ IO buffers on the DDR2 interface (upper bytes)                                                                                                                                                                 |
| 0x0800000A -<br>0x080000011                                                                                          |                                                                                                          |                    | This range of addresses is reserved for manufacturing tests (Daughtercards)                                                                                                                                                                                                 |
| 0x080000012<br>0x080000013<br>0x080000014<br>0x08000001B<br>0x08000001C<br>0x08000001D<br>0x08000001E<br>0x08000001F | SODIMM_SEI<br>FAN_TACH<br>IS_LX_330<br>SODIMM_RAI<br>SODIMM_CO:<br>SODIMM_RO<br>SODIMM_BAI<br>SODIMM_CAS | NK<br>L<br>W<br>NK | This does nothing on the DN9002K10PCIE8T The current input value of the fan tachometer (0 or 1) 0x1 if the FPGA is an LX330, 0x0 is it is not. Data read from the SODIMM IIC interface                                                                                      |
| 0x08000021<br>0x08000022<br>0x08000023<br>0x08000024                                                                 | CLK_COUNT<br>CLK_COUNT<br>CLK_COUNT<br>CLK_COUNT                                                         | ER<br>ER           | Contains contents of G0 counter /4 Contains contents of G1 counter Contains contents of G2 counter Contains contents of CLK48 counter                                                                                                                                       |
| 0x08000025 -<br>0x08000032                                                                                           | RCLK_COUN                                                                                                | TER                | LVDS source-synchronous clock counters (LVDS design only)                                                                                                                                                                                                                   |

#### THE REFERENCE DESIGN

| 0x08000033 -<br>0x0800003F | MCLK_COUNTER      | Clock counters for (in backwards order!): DDR2 clock, EXTCLK0, EXTCLK1, SMACLK, CLK_FBE, CLK_FBB, CLK125_ETH, CLKP, CLK_TPp |                                                   |
|----------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| 0x08000040 -<br>0x08000043 | DDR2TESTTAPCNT    | Reserve                                                                                                                     | ed for manufacturing tests (DDR2)                 |
| 0x08000044<br>0x08000045   | LED_OE<br>LED_OUT |                                                                                                                             | ols LED output enables.<br>ols LED output values. |
| 0x08000046                 | DDR2SIZE_SODIMN   | И2                                                                                                                          | Controls address mapping order on second          |
| 0x08000047                 | HIADDRSIZE_SODI   | DIMM interface (FGPA C only) Number of unique addresses in HIADI second DIMM interface (FPGA C only)                        |                                                   |
| 0x0800004B                 | SODIMM2_RANK      | IIC dat                                                                                                                     | ca retrieved from the SODIMM in socket 2          |
| 0x0800004C                 | SODIMM2_COL       | (FPGA                                                                                                                       | A C only)                                         |
| 0x0800004D                 | SODIMM2_ROW       | -                                                                                                                           | •                                                 |
| 0x0800004E                 | SODIMM2_BANK      | -                                                                                                                           |                                                   |
| 0x0800004F                 | SODIMM2_CAS       | -                                                                                                                           |                                                   |
| 0x0800007E                 | VRP_ALL           |                                                                                                                             | ns input signals on the "VRP" pins                |
| 0x0800007F                 | VRN_ALL           | Contains input values on the "VRN" pins                                                                                     |                                                   |
| 0x0B000000 -               | BLOCKRAM          | The contents of an internal-FPGA block RAM                                                                                  |                                                   |
| 0x0B0003FF                 |                   |                                                                                                                             |                                                   |
| 0x0C000XX0                 | BUS XX OUT        |                                                                                                                             | n be 0-21 hex. Output status of                   |
|                            |                   |                                                                                                                             | bus XX.                                           |
| 0x0C000XX4                 | BUS XX OE         |                                                                                                                             | n be 0-21 hex. OE status of IOs                   |
| 0x0C000XX8                 | BUS XX IN         |                                                                                                                             | n be 0-21 hex. The input values                   |
| 0x0C000XXC                 | BUS XX Name       | A uniq                                                                                                                      | ue name of the bus (schematic)                    |
| 0x0xxxxxxx                 | REG_DEFAULT       |                                                                                                                             | AD5566<br>ndefined register                       |

# 5 Interconnect (Single)

The "single-ended" interconnect test tests the DC connectivity of FPGA-to-FPGA interconnect, and the "MB" signals.

Presented on the MainBus, are registers allowing the interface to control the output value, output enable, and input value of each FPGA-to-FPGA interconnect pin. Each pin on the FPGAs is pulled high. This allows a test program to find single-stuck-at faults, open faults, and stuck-together faults.

# 5.1 Using the Design

The design can be controller over the MainBus. The register banks connected to the IO are arranged into "busses". Each bus has an ID code, an OE register bank, an ENABLE register bank, and an IN register bank.

The addresses of the IO registers are as follows:

FpgaNum (4-bit) | MB\_SEL\_INTERCON (4 bit) | busnum (20-bit) | reg\_offset (4-bit)

FPGA NUM is 0x0 for FPGA A, 0x1 for FPGA B, 0x2 for FPGA C... MB\_SEL\_INTERCON is 0xC

busnum is any number, but only low-values (less than LAST\_ADDR) will constrain valid busses reg\_offset is 0x0 for REG\_OUT, 0x4 for REG\_OE, 0x8 for REG\_IN and 0xC for REG\_ENABLED

To determine which bits (if any) in a bus are valid, read the REG\_ENABLED register. The 32-bits returned '1 are a mask for which of the bits in the REG\_OUT, REG\_OE, and REG\_IN registers are meaningful.

To get the bus ID of a bus, write value 0x1 (32-bit) to REG\_ENABLED, then read REG\_ENABLED, then write 0x0 (32-bit) to REG\_ENABLED. The value returned will be a coded name for the bus. Bits 0-15 are ASCII characters representing FPGA names. Bits 16-31 are an arbitrary unique integer distinguishing the bus. Connecting busses from two different FPGAs have the same bus ID.

To cause an FPGA to output signals on a bus, write 0xFFFFFFF on REG\_OE. To set the outputs all to "high" write 0xFFFFFFFF to REG\_OUT.

To read the current received value from the bus' inputs, read from REG\_IN

# **5.2 Running the Test**

In the USB Controller program, select Settings->OneShot Test. From the dialog box, check the Interconnect Test box. The program will automatically load the bit files, set the clocks and run the test.

# 6 DDR2 Interface

The DDR2 interface design is an example DDR2 controller running at 250MHz. You can use this controller as an example, especially for the purpose of required IO logic, timing and clocking. The controller bandwidth is most of the DDR2 bandwidth possible on the DN9002K10PCIE8T.

### **6.1 Provided Files**

The DDR2 reference design is part of the "MainRef" reference design, and the MainRef files should be used.

# 6.2 Using the Design

The DDR2 memory interfaces are mapped to the address range

0xNXX00000 - 0xNXXFFFFF

Where the 4-bit "N" represents an FPGA ID, as described in the MainBus interface description. X are "don't-care". Since the remaining 19 bits are insufficient to address an entire 4GB DRAM, there is a register DDR2HIADDR that selects the highest address bits of the DRAM. Each address refers to a 32-bit location in the DRAM. The lowest bit is not mapped to DRAM address, but instead selects between the upper and lower 32 bits of the DRAM data. This is necessary because MainBus is a 32-bit interface, and the DN9002K10PCIE8T DRAM interfaces are 64 bits wide.

The bank and side controls are also mapped to the DDR2HIADDR register. The location of the DDR2HIADDR register is given in the Reference Design Memory Map section.

The clock that this design uses (G1) must be set to between 200 and 250MHz.

# **6.3 Running the Test**

To run the hardware test, in the USB Controller application, select Settings->OneShotTest and check the DDR2 box. The program will automatically load the bit files, set the clocks and run the test, reporting any errors.

# **7 Clock Counters**

Each clock available to the FPGA is connected to a counter register, and the value of this register is available on MainBus. In this way, the user can determine if each clock input is working properly.

# 8 LEDs

All of the LEDs are connected to an output enable register. When the LEDs are not enabled, the blink a pattern representing which FPGA the design is for. When enabled, each LED is controlled by the LED value register.

# 9 Simulating the Reference Design

The simulation environment the Dini Group uses is ModelSim. A ModelSim project file is provided, but it may not be compatible with your version of ModelSim. When you create a ModelSim project, add only the top-level design file (sim\_board.v).

Source can be found on the user CD: D:\ FPGA\_Reference\_Designs\dn9002k10pcie8t\MainRef\source\

Also, you must add to the project a simulation library. Simulation models of all of the primitives used in the reference design are found in the Xilinx ISE install directory in the unisims directory.

Simulation models are also provided of the DN9002K10PCIE8T as a whole board, along with DDR2 modules, headers and the MainBus interface.

# **10Compiling the Reference Design**

The MainRef reference design (for which bit files are included on the user CD and the provided CompactFlash card) can be found on the user CD here.

```
D:\FPGA_Reference_Designs\
\common\DDR2\controller_ver\*
\common\DDR2\ddr2_to_mb\*
\DN9002K10PCIE8T'
\MainRef\source\*
```

The top module is

D:\FPGA Reference Designs\DN9002K10PCIE8T\MainRef\source\fpga.v

This module includes all of the other required sources and expects the directory structure found on the CD.

### 10.1.1 The Xilinx Embedded Development Kit (EDK)

The DN9002K10PCIE8T does not use the EDK because it has no embedded processor.

#### 10.1.2 Xilinx ISE

Xilinx ISE version 9.1 (service pack 1 or later) is required to use the reference designs. Earlier versions may work, but are not supported.

If you are using a third-party synthesis tool, you can create a new ISE project file and add the .edf as a source. For part type, select the type of FPGA installed on your board. Make sure to add the provided .ucf file to the project, or the produced place-and-route will not work.

Run the map, implement and generate steps.

### 10.1.3 The Build Utility: Make.bat

If you are not using a third-party synthesis tool, then you should use the provided batch script to generate the programming files from the reference design. The batch script will synthesize using XST from the source, assigning the correct value to each #define switch in the source.

The Build Utility is found at

'DN9002K10PCIE8T/MainRef/buildxst\_DN9002K10PCIE8T/make.bat'. This batch file can be used to run ISE and bitgen. If you do not have cygwin installed, you need 'sed' (Stream Editor) command to run make.bat, sed can be download from

http://gnuwin32.sourceforge.net/packages/sed.htm, please download the setup program and set your PATH environment to executable file under <SED>\bin folder. You may also need to add the Xilinx bin directory to your path so the command "par" calls the correct program.

First make ucf file, the script can be found at "DN9002K10PCIE8T/MainRef/ucf\_DN9002K10PCIE8T/make\_ucf.bat'.

Make sure that when you do (type) under cygwin >which map /cygdrive/c/Xilinx/10.1/ISE/bin/nt/map >which par /cygdrive/c/Xilinx/10.1/ISE/bin/nt/par

There are command line options that cause the script to output the correct reference design. (Since all the reference designs use the same source files). Most commonly, you would want to make the "single-ended" or "main" reference design. This includes the DDR2 controller.

Type

>make.bat SINGLE

to change the current source compilation type to "Single ended"; Then type >make.bat build\_all\_lx330

to start synthesis, place and route, and bitfile generation; the build script creates a directory called "out" and places its output files there. After the script completes you will find files for each FPGA that was built. fpga\_\*.bit is the file to be downloaded to the FPGA.

When using the provided VHDL, the generic definitions are not complete in the Dini Group code. Some of the signals that are governed by generics must be defined externally or (defined in the first place).

# **10.2 Bitgen Options**

The Make bat script correctly sets all bitgen options that are compatible with the DN9002K10PCIE8T. The following options should be used with the DN9002K10PCIE8T. Options that are not listed here can be selected by the user, or left to their default settings.

Compress: OFF (Or you can disable "sanity check" option on board)

UnusedPin: Pullnone

#### THE REFERENCE DESIGN

Persist: Yes (Only require is Readback is used)

Encrypt: No (YES requires that you disable "sanity check" option on board)

DonePipe: No DriveDone: Yes

Don't ever disable "CRC Check". This is the easiest and most certain way to turn your FPGAs into little piles of carbon ash. I am pretty sure this option exists to increase sales of replacement FPGAs.

# 11LVDS Reference Design

The "LVDS Interconnect" design is to show the user how to implement source-synchronous communication between FPGAs. Using this method, the advertised 900Mbs system speed can be achieved. If you do not wish to use source-synchronous interconnect, ignore this reference design with prejudice.

All FPGA-to-FPGA interconnect in this design is constantly being driven by one FPGA sending (uni-directionally) a test pattern. The receiving FPGA checks the test pattern for correctness against a known pattern.

The design is intended to characterize the bandwidth of the interconnect between FPGAs. Access to test status is provided over the MainBus interface.

Note that there are two designs, "ADC" and "CBA". In the design, the directions of LVDS connections between FPGAs are uni-directional. In the "CBA", all of the signals are in a direction opposite to the "ABC" design signals.

#### 11.1 Provided Files

The source is located at:

D:\FPGA\_Reference\_Designs\DN9002K10PCIE8T\MainRef

Note that this is the same source as the "Main Reference Design". To compile the design for LVDS, #define statements in the Verilog code must be added or removed. The make bat utility described in the "compiling the reference design" section automatically adds and removes these directives. The pre-compiled bitfiles for this design are located at

D:\FPGA\_Reference\_Designs\Programming\_Files\DN9002K10PCIE8T\LVDSIntercon\

# 11.2 Using the Design

The design's MainBus interface is undocumented

The IOs in the LVDS reference design are clocked using the G0 clock. A clock setting of 300MHz on G0 results in data transmission from FPGA to FPGA of 600Mbs per signal pair.

The G2 clock is required to be 200MHz, or IDELAY will not calibrate correctly, and performance will be degraded.

# 11.3 Running the Test

In the USB Controller program, select Settings->OneShot Test. From the dialog box, check the Interconnect Test box. The program will automatically load the bit files, set the clocks and run the test.

# 12PCIe Interface Reference Design

The PCIe reference design is an example of how to use the provided LX50T\_module\_interface module provided.

### **12.1 Provided Files**

# 12.2 Using the Design

The PCIe reference design maps internal FPGA block rams to BAR 1 through BAR6 of the FPGA's PCIe interface, and a separate block ram to the DMA channel of the PCIe interface. When the design in loaded in the FPGA, a host machine can read and write to this memory space to verify the interface is working. Only 4KB of memory is mapped to each BAR, even though the size of each BAR is larger. The block ram memory will wrap.

# 12.3 Running the Test

The PCIe Reference Design is an FPGA A-only design that implements the pcie\_x8\_user\_interface module described the document D:\FPGA\_Reference\_Designs\common\PCIE\_x8\_Interface\pcie8t\_user\_interface\_manual.pdf

This design implements a PCIe target access and DMA interface to a block ram inside FPGA A. The source code is located on the CD at:

D:\FPGA\_Reference\_Designs\common\PCIE\_x8\_Interface\

The pre-compile bitfiles for your board are located at: D:\FPGA\_Reference\_Designs\Programming\_files\pcie\_dma

In this design, accesses to BAR2, BAR3, BAR4, BAR5 and both DMA channels are mapped to separate block rams in the FPGA. Upper bits of the address offset are ignored, so the block ram loops around. To use this design, see the PCIe section of the hardware chapter.

# **Chapter 6: Ordering Information**

Part Number DN9002K10PCIE8T

### 1 Section Title

Request quotes by emailing <u>sales@dinigroup.com</u>.

For technical questions email support@dinigroup.com

# 2 FPGA Options

Any subset of FPGAs can be installed on the DN9002K10PCIE8T. Any unneeded FPGA positions can ship empty to reduce the total price.

### 2.1 FPGA A and B:

Select an FPGA part to be supplied in each position, A, B. Possible selections are

NONE LX110 -1 -2 -3 LX220 -1 -2 -3 LX330 -1 -2

### 2.2 CES Parts

The DN9002K10PCIE8T may ship with CES "engineering sample" parts. This is often the case early in the Xilinx product release cycle. If your board will ship with CES parts, the quote will state the Xilinx part number of each FPGA on your board, indicating a CES revision. It is important that the user knows that CES parts may have limitations that are not listed in the Virtex-5 datasheet. To read about these limitations, see the Xilinx website and search for Virtex-5 errata. In general, it is the responsibility of the user to determine if the board is suitable for his application prior to ordering a board. Details about the interfaces on the board that are not in this manual and characterizations of interfaces, if available can be requested.

#### 2.2.1 Hardware Errata Details

There are no errata for Virtex-5 production (non-CES) parts.

### 2.3 "Small" FPGAs

The DN9002K10PCIE8T is optimized for two Xilinx Virtex-5 LX330 FPGAs. Optionally, it can be ordered with LX110 or LX220 FPGAs instead. When installed with one or more LX110 or LX220 FPGAs, the amount of available interconnect is reduced due to some IOs in those devices being "no-balled".



The diagram above shows the block diagram representing the resources available on a board installed with two LX110 or LX220 FPGAs. One-third of each daughter card's pins become unusable, and the amount of interconnect between FPGA A and B is reduced from 696 signals to 378 signals.

The Ethernet, PCIe and DIMMs are not affected by FPGA selection. Also, you should analyze your design to determine if the internal resources available in the LX110 and LX220 are sufficient to meet your needs. The FPGA selection guide from Xilinx is printed below.

|                                     |                     | LX110   | LX220     | LX330     |           |
|-------------------------------------|---------------------|---------|-----------|-----------|-----------|
|                                     | Part l              | Number  | XC5VLX110 | XC5VLX220 | XC5VLX330 |
| CLB                                 | Array Size (Row x ( | Column) | 160 x 54  | 160 x 108 | 240 x 108 |
| Slices <sup>(2)</sup>               |                     | 17,280  | 34,560    | 51,840    |           |
| Logic Cells <sup>(3)</sup>          |                     | 110,592 | 221,184   | 331,776   |           |
| CLB Flip-Flops                      |                     | 69,120  | 138,240   | 207,360   |           |
| Maximum Distributed RAM (kbits)     |                     | 1,120   | 2,280     | 3,420     |           |
| Block RAM/FIFO w/ECC (36kbits each) |                     | 129     | 192       | 288       |           |
| Total Block RAM (kbits)             |                     | 4,608   | 6,912     | 10,368    |           |
| DSP48E Slices                       |                     | 64      | 128       | 192       |           |
| FF1760                              | 42.5 x 42.5 mm      | 1/0     | 800       | 800       | 1200      |

# 2.4 Speed Grades

The interface performance characterizations included in this manual and in advertisements are valid for all shipped FPGAs, regardless of speed grade. These numbers are characterizations, and not guaranteed under all operational conditions. Every shipped board has passed this characterization test under some operational conditions.

If there are any interfaces where performance is only characterized for specific speed grade parts, this is noted in the advertisement and in this document. Below is a list of all such interfaces:

#### 1) PCIe Express

Some interfaces may run at increased speeds above and beyond Dini Group's advertised performances when used with -2 or -3 speed grade parts. Some performance numbers that are advertised by Xilinx are listed here. These characterizations have not been performed on the DN9002K10PCIE8T, but we have no reason to think the DN9002K10PCIE8T is a limiting factor on these interfaces:

| FPGA-to-FPGA interconnect, LVDS         | 1.25 Gbs (625 MHz) |
|-----------------------------------------|--------------------|
| FPGA-to-FPGA interconnect, single-ended | 800 Mbps (400 MHz) |
| DDR2 Interface                          | 667 Mbps (333 MHz) |

# 2.5 Upgrade Policy

Upgrading (adding FPGAs) to a DN9002K10PCIE8T.

Call for a quote.

# 3 Optional Equipment

The following tools are suggested for use with the Dini Group DN9002K10PCIE8T.

# 3.1 Compatible Dini Group products

The Dini Group supplies standard daughtercards and memory modules that you can use with the DN9002K10PCIE8T.

#### 3.1.1 Memories

The memory module solutions from Dini Group allow the user to install whichever type of memory his application requires.

#### DNSODM200 SRAM

Memory module for use in the 200-pin SODIMM sockets.

Standard memory configuration: Two GS8320V32 memories

(1M x 32 each)

Performance up to 175MHz (SDR)

Small EPROM. Contact us about "zero bus latency" type parts.

#### DNSODM200 RLDRAM

Reduced latency DRAM (Micron) 64 bit wide compatible with the 200-pin SODIMM sockets

Small EPROM

#### DNSODM200 MICTOR

#### DNSODM200\_QUADMIC

Provides 2 or 4 Mictor-38 connectors.

Compatible with the DDR2 SODIMM sockets.

User LEDs; Small EPROM

#### DNSODM200 DDR1

DDR1 memory module compatible with the 200-pin SODIMM sockets

Comes with 512MB standard.

Allows use of standard PC2700 modules (up to 1GB)

175MHz performance

#### DNSODM200 SDR

SDR memory module compatible with 200-pin SODIMM sockets.

Accepts PC133 modules up to 512MB

(User is required to install a Jumper)

Comes with 256MB standard

75MHz performance

#### DNSODM200\_FLASH

Spansion S29WS064J memory (x2); each is 4Mx16 bit flash

#### ORDERING INFORMATION

16Mb SRAM memory (512k x 32) Compatible with DDR2 SODIMM sockets. 66MHz performance (read burst)

Other SODIMMs include access to the following interfaces:

- USB, 3.3V IO, FPGA interconnect,

### 3.1.2 Daughtercards

Dini Group daughtercards connect to the MEG-Array connector (400-pin) using the standard Dini Group interface description.

#### DNMEG\_PCIE

8-lane PCIe express PHY card; Host or downstream mode DDR2 memory module Virtex-4 FPGA. (LX40-LX160)

#### DNMEG\_AD\_DA

High-speed Analog-Digital daughtercard Virtex-4 FPGA DDR2 memory module 250Msps, 12-bit ADC; 60dB SNR (10 bits) 200 kHz-75MHz

### DNMEG\_V5T (two versions)

Xilinx Virtex 5 LXT FPGA with high-speed serial interfaces; SMA, SATA, SFP, PCI Express

#### DNMEG\_INTERCON

Connects headers for FPGA A and B together

#### DNMEG\_OBS

Adjustable-voltage tenth-inch pitch headers User LEDs

Two Mictor-38 connectors



# 3.2 Compatible third-party products

The following products have been shown to work with the DN9002K10PCIE8T.

Intel Entry Server board SE7230NH1-E

http://www.intel.com/design/servers/boards/se7230nh1-e/index.htm

Standard DDR2 modules (256 MB \$19, 512 MB \$15, 1GB \$25, 2GB \$79, 4GB eventually) <a href="http://www.crucial.com/store/listmodule/DDRII/list.html">http://www.crucial.com/store/listmodule/DDRII/list.html</a>

Xilinx Platform USB Cable (required for JTAG FPGA programming, ChipScope Pro) HW-USB-G

http://nuhorizons.com

Mictor breakout

MIC-38-BREAKOUT

http://www.emulation.com/catalog/off-the-shelf\_solutions/mictor/

# **4 Compliance Data**

### 4.1 Compliance

#### 4.1.1 EMI

Since the DN9002K10PCIE8T is not intended for production systems, it has not passed EMI testing. Compliance is only done by special request.

#### 4.1.2 PCIe-SIG

The DN9002K10PCIE8T passes the electrical compliance test for PCI express 1.1 and 1.0a, using the Provided DMA-enabled PCI Express core, and with the Xilinx PCIe endpoint LogiCORE. Additionally, the LogiCORE endpoint passes the PCI-SIG compliance full test.

The provided PCI Express DMA-enabled core has not been tested at a compliance workshop.

The FX70T passes the PCI Express electrical compliance test for revision 2.0.

EYE WIDTH: 149ps
TIE JITTER: -28 to 28ps
TOTAL JITTER @ BER: 77ps
DIFF PEAK VOLTAGE 1.12V

### 4.2 Environmental

### 4.2.1 Temperature

The DN9002K10PCIE8T is designed to operate within an ambient temperature range of 0-50 degrees C.

All components used on the DN9002K10PCIE8T are guaranteed to operate within a temperature range of 0-80 degrees C (measured on the device die).

# 4.3 Export Control

#### 4.3.1 Lead-Free

The DN9002K10PCIE8T meets the requirements of EU Directive 2002/95/EC, "RoHS". Specifically, the DN9002K10PCIE8T contains no homogeneous materials that:

- a) contains lead (Pb) in excess of 0.1 weight-\% (1000 ppm)
- b) contains mercury (Hg) in excess of 0.1 weight-\% (1000 ppm)
- c) contains hexavalent chromium (Cr VI) in excess of 0.1 weight-% (1000 ppm)
- d) contains polybrominated biphenyls (PBB) or polybrominated dimethyl ethers (PBDE) in excess of 0.1 weight-% (1000 ppm)
- e) contains cadmium (Cd) in excess of 0.01 weight-% (100 ppm)

No exemptions are claimed for this product.

#### 4.3.2 The USA Schedule B number based on the HTS

8471 60 7080

## 4.3.3 Export control classification number ECCN

EAR99

# **4.4 Mission Critical**

DN9002K10PCIE8T and supporting hardware and software are not intended for use on human subjects that you like, in life support, mission-critical systems, or aviation.