

# Spartan®-3A FPGA Family DDR2 MIG Back-to-Back Bursts Wrapper

Reference Design on Spartan-3A/AN FPGA Starter Kits with ISE® 11.2 Software

Cliff Tsai Xilinx

#### Limitations

- Limited Warranty and Disclaimer. These designs are provided to you "as is". Xilinx and its licensors make and you receive no warranties or conditions, express, implied, statutory or otherwise, and Xilinx specifically disclaims any implied warranties of merchantability, non-infringement, or fitness for a particular purpose. Xilinx does not warrant that the functions contained in these designs will meet your requirements, or that the operation of these designs will be uninterrupted or error free, or that defects in the Designs will be corrected. Furthermore, Xilinx does not warrant or make any representations regarding use or the results of the use of the designs in terms of correctness, accuracy, reliability, or otherwise.
- Limitation of Liability. In no event will Xilinx or its licensors be liable for any loss of data, lost profits, cost or procurement of substitute goods or services, or for any special, incidental, consequential, or indirect damages arising from the use or operation of the designs or accompanying documentation, however caused and on any theory of liability. This limitation will apply even if Xilinx has been advised of the possibility of such damage. This limitation shall apply notwithstanding the failure of the essential purpose of any limited remedies herein.
- This design modules is **not** supported by Xilinx Technical support as an official Xilinx Product.



#### **Features**

- A wrapper on top of the Memory Interface Generator (MIG) tool within the Core Generator (CoreGen) tool hiding the details of the original interface, initialization sequence and AREF requests handling
- Single User Clock Domain
- Easy FIFO-like user interface
- Automatically pausing when AREF requests occur (about every 7.8μs) during R/W bursts and continuing R/W once AREF is done
- Back-to-back bursts for performance improvement with different Burst Length
  - Note the max number of back-to-back bursts is limited by column address and user R/W FIFO depth
- Suitable for applications such as Video Line buffer access



# Reference Design Architecture





## Reference Design RTL Hierarchy

- sim\_tb\_top.v (simulation top instantiates syn\_test\_top and Micron DDR2 model)
  - syn\_test\_top.v: Top module instantiates syn\_test\_bench,s3\_mig\_ddr2\_wrapper and mig usr top
    - syn\_test\_bench.v: synthesizable test bench instantiates WR/RD FIFO and ctrl fsm to generate Write data and Read data comparison
    - s3\_mig\_ddr2\_wrapper.v: wrapper for MIG and provides simple clock domain FIFO interface
    - s3\_mig\_wrapper\_define.v: defines file control burst length and synthesizable test bench consecutive back-to-back burst number
    - mig\_top\_no\_tb.v: used as top of vlog\_bl8 for Spartan-3A/AN Kit LOC
  - Default test\_seed/bit\_shift\_seed definition in s3\_mig\_wrapper\_define.v
  - The Write Data Test Pattern is from 1,2,3,4,5,6...... To N-1,
    so the RD Data comparison must match the Write Data Sequence



# Reference Design Size and Timing (ISE 11)

- The synthesizable testbench instantiates two 18KB Block RAM configured as one 511x32 Write FIFO and one 511x32 Read FIFO (FWFT mode), total Block RAM usage is 5 include MIG control
  - So the max number of back-to-back bursts is int[511/8]
  - Check consecutive\_burst in s3\_mig\_wrapper\_define.v

| xc3s700a-4fg484 Device U                       | Device Utilization Summary |           |             |  |  |  |  |
|------------------------------------------------|----------------------------|-----------|-------------|--|--|--|--|
| Logic Utilization                              | Used                       | Available | Utilization |  |  |  |  |
| Total Number Slice Registers                   | 1,421                      | 11,776    | 12%         |  |  |  |  |
| Number used as Flip Flops                      | 1,420                      |           |             |  |  |  |  |
| Number used as Latches                         | 1                          |           |             |  |  |  |  |
| Number of 4 input LUTs                         | 1,262                      | 11,776    | 10%         |  |  |  |  |
| Number of occupied Slices                      | 1,223                      | 5,888     | 20%         |  |  |  |  |
| Number of Slices containing only related logic | 1,223                      | 1,223     | 100%        |  |  |  |  |
| Number of Slices containing unrelated logic    | 0                          | 1,223     | 0%          |  |  |  |  |

The reference design runs at more than 133 MHz with -4 device,
 but was tested with a 133 MHz clk input on the Spartan-3A/AN kit



#### **Simulation**

- Double-click the ModelSim script file .\sim\sim.bat or type vsim –do sim.do under a console window
- Optionally change the simulation time in the sim.do

Bursts Write and Read in 1000µs



## Configuration of Spartan-3A/AN Starter Kit

#### Clocking

133 MHz Clock on IC14 socket for GCLK2 (V12)

#### DDR2 Performance Correction

- Xilinx has identified two component changes which improve the performance of the DDR2 SDRAM device
- If you are using the DDR2 SDRAM device and experience suboptimal performance, short out components FB4 and FB5
- These are both located near the index pin on the DDR2 SDRAM

#### Output

- LD2 (On means : Init\_done)
- LD1 (On means : data valid)
- LD0 (Off means : No data W/R comparison error)



# Implementation and ChipScope<sup>™</sup> Pro Verification on Spartan-3A/AN Starter Kit

- Double-click Analyze Design Using ChipScope Pro under ISE GUI
- Use ChipScope Pro Analyzer 11 to configure FPGA and load ila\_debug.cdc allowing the automatic Trigger/Data signal annotation





# **Enlarge the ChipScope Pro Waveform Window**

 RD FIFO receives DDR2 Read data, and starts to output and perform comparison



Last piece of RD Burst Data comparison

| Waveform - DEV:0 MyDevice0 (XC3S700A) UNIT:0 MyILA0 (ILA) |       |       |          |            |          |              |         |         |         |         |  |
|-----------------------------------------------------------|-------|-------|----------|------------|----------|--------------|---------|---------|---------|---------|--|
| Bus/Signal                                                | х     | 0     | 355<br>  | 356<br>    | 357<br>  | 358<br>      | 359<br> | 360<br> | 361<br> | 362<br> |  |
| /syn_test_bench/led_error_output_reg                      | 0     | 0     |          |            |          |              |         |         |         |         |  |
| -/syn_test_bench/rd_fifo_rd_en_r                          | 0     | 0     |          |            |          |              |         |         |         |         |  |
| - /syn_test_bench/rd_fifo_cmp_data                        | 212A9 | 212A9 | 212A96FD | 212A96FE   | 212A96FF | X 212A9700 X |         |         |         |         |  |
| - /syn_test_bench/rd_fifo_test_data_out_r                 | 212A9 | 212A9 | 212A96FD | X 212A96FE | 212A96FF | X            |         |         |         | 212A97  |  |

