# **VIRTEX II Timing-Simulation vs Reality**

### Silvana POPESCU, Aurel GONTEAN

Abstract — The goal of this paper is understanding the performance capability of a modern FPGA in a post-layout simulator using a typical design. For this, an eight-phase generator was used as a test circuit and the delays between the outputs have been evaluated and corrected.

Keywords — FPGA, rise time, simulation, VHDL.

#### I. INTRODUCTION

**A**<sup>FPGA</sup> (Field-Programmable Gate Array) is an manufacturing. FPGAs contain programmable logic components called logic blocks and a hierarchy of reconfigurable interconnects that allows the blocks to be wired together. To define its behavior, the FPGA is programmed generally using a hardware description language (HDL). The most common language is VHDL (VHSIC – Very High Speed Integrated Circuits Hardware Description Language).

VHDL is used for two different goals: simulation of electronic designs and synthesis of such designs. Synthesis is a process where a VHDL is compiled and mapped into an implementation technology such as a FPGA. Also, VHDL allows the description of a concurrent system unlike some programs in which the code run sequentially[1].

#### II. HARDWARE AND SOFTWARE RESOURCES

#### A. Virtex II Board

The Virtex-II Pro Development System provides an advanced hardware platform that consists of a high performance Virtex-II Pro Platform FPGA surrounded by a comprehensive collection of peripherial components that can be used to create a complex system and to demonstrate the capabilities of the Virtex-II Pro Platform FPGA.

Based on the Virtex-II Pro FPGA, the board can function as a digital design trainer, a microprocessor development system or a host for embedded processor cores and complex digital systems.

Features of Virtex-II board:

- Virtex-II Pro FPGA with PowerPC 405 cores;
- Up to 2 GB of Double Data Rate (DDR) SDRAM;
- System AC controller and Type II CompactFlash connector for FPGA configuration and data storage;
- Embedded Platform Cable USB configuration port;

- High-speed SelectMAP FPGA configuration from Platform Flash In-System Programmable Configuration PROM;
- Support for "Golden" and "User" FPGA configuration bitstreams;
- On-board 10/100 Ethernet PHY device;
- Silicon Serial Number for unique board identification;
- RS-232 DB9 serial port;
- Two PS-2 serial ports;
- Four LEDs connected to Virtex-II Pro I/O pins;
- Four switches connected to Virtex-II Pro I/O pins;
- Five push buttons connected to Virtex-II Pro I/O pins;
- Six expansion connectors joined to 80 Virtex-II Pro I/O pins with over-voltage protection;
- High-speed expansion connector joined to 40 Virtex-II Pro I/O pins that can be used differentially or single ended;
- AC-97 audio CODEC with audio amplifier and speaker/headphone output and line level output;
- Microphone and line level audio input;
- On-board XSGA output, up to 1200 x 1600 at 70 Hz refresh;

![](_page_0_Picture_34.jpeg)

Fig. 1. Virtex-II Board

- Three Serial ATA ports, two Host ports and one Target port;
- Off-board expansion MGT link, with user-supplied clock;
- 100 MHz system clock, 75 MHz SATA clock;
- Provision for user-supplied clock;

S. P. - PhD student, Faculty of Electronics and Telecommunication, "Politehnica" University of Timisoara, Romania (phone: +4-0724214627; e-mail: silvana.popescu@etc.upt.ro).

A. G. – Applied Electronics Departament, Faculty of Electronics and Telecommunications, "Politehnica" University of Timisoara, Romania; (phone: +4-0745119858; e-mail: aurel.gontean@etc.upt.ro).

- On-board power supplies;
- Power-on reset circuitry;
- PowerPC 405 reset circuitry[2].

#### B. Virtex-II Pro Family FPGA

The Virtex-II Pro/Virtex-II Pro X family is the first FPGA family to incorporate both serial transceiver technology and a hard processor core within a generalpurpose FPGA device. This is significant for new highbandwidth embedded processing applications such as packet processing, where both high device I/O bandwidth and high performance processor cores are needed together. The Virtex-II Pro/Virtex-II Pro X family marks the first paradigm change from programmable logic to programmable systems, with profound implications for leading-edge system architectures in networking applications, deeply embedded systems, and digital signal processing systems. It allows custom user-defined system architectures to be synthesized, next-generation connectivity standards to be seamlessly bridged, and complex hardware and software systems to be codeveloped rapidly with insystem debug at system speeds. Together, these capabilities usher in the next programmable logic revolution[3].

### C. Xilinx Web Pack ISE

ISE WebPACK from Xilinx is a design software for FPGA design solution for Linux, Windows XP and Windows Vista. ISE WebPACK is used for FPGA and CPLD design offering HDL synthesis and simulation, implementation, device fitting, and JTAG programming.

### III. DESIGN IMPLEMENTATION AND TESTING

In order to verify the limits of the ISE Web Pack Suite, the eight-phase generator has been simulated, implemented and tested.

## A. Eight-phase Waveform Generator

The eight-phase generator is an application of shift registers in ring counters.

A shift register is a cascade of flip-flops, all sharing the same clock which have their inputs and outputs connected together, resulting in a circuit that shifts by one position the information stored in it at every transition of the clock input. Ring counters are implemented using shift registers so that the output of the last register is fed to the input of the first register.

Figure 3 illustrates a ring counter on 8 bits.

![](_page_1_Figure_13.jpeg)

Fig.2. A 8 bits ring counter

The VHDL program of the eight-phase waveform generator is shown below.

entity 8phase is port( clk:in std\_logic; reset, start. restart: in std logic; OUT: out std\_logic\_vector(1 to 8)); End 8phase; architecture 8phase\_arch of 8phase is signal R\_W: std\_logic\_vector(1 to 8); signal Aux: std logic; begin process(clk, R\_W) begin if (clk'event and clk='1') then if (reset='1') then Aux  $\leq$  '1'; elsif ((R W=('0','0','0','0','0','0','0','0')) or (restart='1')) then Aux  $\leq$  '1'; R W <= ('1','0','0','0','0','0','0','0','0'); elsif (start='1') then Aux <= not Aux; if (Aux='0') then R W <= R W(8)&R W(1 to 7); end if; end if; end if;  $OUT \leq not R_W;$ end process; end 8phase\_arch;

R\_W is an internal active-high signal vector, used for reading and writing what eventually becomes the circuit's output. This signal is inverted to obtain the required active-low output signal vector.

Aux is an auxiliary state bit to keep track of the two states within each phase. The OUT[i] and Aux signals are all outputs from the flip-flops clocked by the same clock clk[4].

This design is tested in simulation, first behavioral and then post-routed.

#### B. Behavioral Simulation

The behavioral simulation is used to test the design functionality.

The behavioral simulation is illustrated in fig.3.

Signal clk is the clock used in the application of the eight-phase generator, signals start, restart and reset are the input signals and the OUT[i] signals are active low-phase outputs[5].

The signals in the selected aria are zoomed and shown in UT[8] fig.4.

As expected, fig.4. demonstrates that the behavioral simulation does not point out any delays.

#### C. Post-Route Simulation

Unlike the behavioral simulation, in the post-route simulation, the delays became noticeable. The encirclements from fig.5 are the delays introduced by the post-route simulation. One of these delays is shown in fig.6, namely the delay between the third and the fourth signal.

| Current Simulation<br>Time: 1000 ns |       |       | 500 ns |      | 550 ns | 6     | 00 ns   | 6     | 50 ns | 7 | 00 ns  | 75     | 0 ns | 80    | 00 ns | 8   | 850 ns |
|-------------------------------------|-------|-------|--------|------|--------|-------|---------|-------|-------|---|--------|--------|------|-------|-------|-----|--------|
| clk                                 | 1     |       | 11     |      | T T    | 11    |         | h     | 10    |   | TT.    | Πİ     | 11   | 1 11  | i i i | T1  |        |
| o reset                             | 0     |       |        |      |        |       |         |       |       |   |        |        |      |       |       |     |        |
| ji start                            | 1     |       |        |      |        |       |         |       |       |   |        |        |      |       |       |     |        |
| j.[! restart                        | 0     |       |        |      |        |       |         |       |       |   |        |        |      |       |       |     |        |
| OUT[1:8]                            | 8'hFB | 8'hFB | 8'h7F  | X 81 | hBF X  | 8'hDF | X 81    | hEF ) | 8'hF7 | X | 8'hFB  | X 8'hF | DX   | 8'hFE | X s   | h7F | 8'hBF  |
| 0.[[OUT[1]                          | 1     |       |        |      |        |       |         |       |       |   |        | · ·    |      |       | 1     |     |        |
| 0UT[2]                              | 1     |       |        |      |        |       | <b></b> |       |       |   |        |        | 7    |       |       |     | Ì      |
|                                     | 1     |       |        | 1    |        |       |         |       |       |   |        |        |      |       |       |     |        |
| 0.[] OUT[4]                         | 1     |       |        |      |        |       |         |       |       |   |        |        | _    |       |       |     |        |
|                                     | 1     | -     |        |      |        |       | -       |       |       |   |        |        |      |       |       |     |        |
|                                     | 0     | -     |        |      |        |       |         |       |       |   | 1.2    |        | -    |       |       |     |        |
| 0UT[7]                              | 1     |       |        |      |        |       |         |       |       |   |        | 1      | ſ    |       |       |     |        |
| 0UT[8]                              | 1     | Г     | -      |      |        |       |         |       |       |   |        |        | -    |       |       |     |        |
| o period                            | 2     |       |        |      |        |       |         |       |       |   | 200000 | 00     | -    |       |       |     |        |
| duty_cycle                          | 0.5   |       |        |      |        |       |         |       |       | _ | 0.5    |        |      |       |       |     |        |
| j∬ offset                           | 1     |       |        |      |        |       |         |       |       | 3 | 100000 | 00     |      |       |       |     |        |
|                                     |       |       |        |      |        |       |         |       |       |   |        |        |      |       |       |     |        |

# Fig.3. Behavioral Simulation

| Current Simulation<br>Time: 1000 ns |       | 640 ns | 650 ns | 660 ns | 670 ns | 680 ns | 690 ns | 700 ns   | 710 ns | 720 ns | 730 ns | 740 ns |
|-------------------------------------|-------|--------|--------|--------|--------|--------|--------|----------|--------|--------|--------|--------|
| oj i cik                            | 1     |        | 1      |        |        |        |        |          |        |        | 1      |        |
| jireset                             | 0     |        |        |        |        |        |        |          |        |        |        |        |
| j.[ start                           | 1     |        |        |        |        |        |        |          |        |        |        |        |
| o[] restart                         | 0     |        |        |        |        |        |        |          |        |        |        |        |
| ■ 🚮 OUT[1:8]                        | 8'hFB | hÈ     |        | 8"hF7  |        | X      |        | 8'hFB    |        | X      |        | 8'hFD  |
| о́[] ОUТ[1]                         | 1     |        |        |        |        |        |        |          |        |        |        |        |
| 0UT[2]                              | 1     |        |        |        |        |        |        |          |        |        |        |        |
| 0.[] OUT[3]                         | 1     |        |        |        |        |        |        |          |        |        |        |        |
| o[] OUT[4]                          | 1     |        |        |        |        |        |        |          |        |        |        |        |
| out[s]                              | 1     | Ħ      |        |        |        |        |        |          |        |        |        |        |
|                                     | 0     |        |        |        |        |        |        |          |        |        |        |        |
| j] OUT[7]                           | 1     | -      |        |        |        |        |        |          |        |        |        |        |
|                                     | 1     |        |        |        |        |        |        |          |        |        |        |        |
| period                              | 2     |        |        |        |        |        |        | 20000000 | -      |        |        |        |
| duty_cycle                          | 0.5   |        |        |        |        |        |        | 0.5      |        |        |        |        |
| j∬ offset                           | 1     |        |        |        |        |        |        | 10000000 |        |        |        |        |

# Fig.4. Zoomed Behavioral Simulation

| Current Simulation<br>Time: 1000 ns |       | 200 ns  | 225 ns | 250 ns | 275 ns | 300 ns  | 325 ns | 350 ns | 375 n: | s 400 | ns 425 n |
|-------------------------------------|-------|---------|--------|--------|--------|---------|--------|--------|--------|-------|----------|
| 🦕 🛛 clk                             | 1     |         |        |        |        |         |        |        |        |       |          |
| o[] reset                           | 0     |         |        |        |        |         |        |        |        |       |          |
| o.[] start                          | 1     |         |        |        |        |         |        |        |        |       |          |
| o[] restart                         | 0     |         |        | ~      |        |         | ~      |        | ^      |       | •        |
| OUT[1:8]                            | 8'hF7 | 8'h7F 🗼 | 8'hBF  | 謝      | 8'hDF  | 8'hEF   | (¥)    | 8'hF7  |        | 8'hFB | 8'hFD    |
| 0UT[1]                              | 1     | Ψ       |        | 0      |        |         | 0      |        | v      |       | 0        |
| 0UT[2]                              | 1     |         |        |        |        |         |        |        |        |       |          |
| out[3]                              | 1     |         |        |        |        |         |        |        |        |       |          |
| out[4]                              | 1     |         |        |        |        |         |        |        |        |       |          |
| j[] OUT[5]                          | CI    |         |        |        |        |         |        |        |        |       |          |
| io.[] OUT[6]                        | 1     |         |        |        |        |         |        |        |        |       |          |
| i] OUT[7]                           | 1     |         |        |        |        |         |        |        |        |       |          |
| 6.[] OUT[8]                         | 1     |         |        |        |        |         |        |        |        |       |          |
| o[] period                          | 2     |         |        |        |        | 2000000 | 8)     |        |        |       |          |
| outy_cycle                          | 0.5   |         |        |        |        | 0.5     |        |        |        |       |          |
| oj∏ offset                          | 1     | 1       |        |        |        | 1000000 | 5      |        |        |       |          |

# Fig.5. The Post-Route Simulation

| Current Simulation<br>Time: 1e+06 ps |       | 286300 ps286350 ps 286400 ps 286450 p | 286<br>s 286500 ps 2 | .5 ns<br>4<br>36550 ps | -104.0<br>286600 ps | 285650 ps  | 2867     |
|--------------------------------------|-------|---------------------------------------|----------------------|------------------------|---------------------|------------|----------|
| clk                                  | 1     |                                       | <u></u>              |                        |                     |            | <u> </u> |
| o reset                              | 0     |                                       |                      | 1                      |                     |            |          |
| j] start                             | 1     |                                       |                      | 1                      |                     |            |          |
| oj restart                           | 0     |                                       |                      | 1                      |                     |            |          |
| ■ 😽 OUT[1:8]                         | 8'hCF | 8'hDF                                 |                      | X                      | 8'hCF               | - <u>x</u> |          |
| OUT[1]                               | 1     |                                       |                      | 1                      |                     |            |          |
| 0UT[2]                               | 1     |                                       |                      | 1                      |                     |            |          |
| 0.1 OUT[3]                           | 0     |                                       |                      |                        |                     |            |          |
| 0.[] OUT[4]                          | 0     |                                       |                      | 1                      |                     |            |          |
| 0UT[5]                               | 1     |                                       |                      | 1                      |                     |            |          |
| <mark>ф</mark> ]! ОUТ[6]             | 1     |                                       |                      |                        |                     |            |          |
| o.[] OUT[7]                          | 1     |                                       |                      | 1                      |                     | _          |          |
| о.[] OUT[8]                          | 1     |                                       |                      | 1                      |                     |            |          |
| o period                             | 2     |                                       | 2000                 | 0000                   |                     |            |          |
| duty_cycle                           | 0.5   |                                       | (                    | ).5                    |                     |            |          |
| offset                               | 1     |                                       | 1000                 | 0000                   |                     |            |          |
|                                      |       |                                       |                      |                        |                     |            |          |

Fig.6. Zoomed delayed detail between out[3] and out[4]

The delays between every two consecutive signals are listed in Table 1.

| Signals | Delays [ps] |
|---------|-------------|
| 1_2     | 238         |
| 2_3     | 527         |
| 3_4     | 104         |
| 4_5     | 376         |
| 5_6     | 117         |
| 6_7     | 208         |
| 7_8     | 106         |
| 8 1     | 176         |

TABLE 1: DELAYS BETWEEN CONSECUTIVE SIGNALS.

#### D. Experimental Results

Experimental results were acquired with a LeCroy WaveSurfer Xs Series Oscilloscope, a high performance digital oscilloscope. In order to obtain results, the eight signals were routed to the two 40-pin right angle connectors[6].

The first measurement was with the eight signals routed to the left expansion connector and the second measurement was with the signals routed to the right connector.

Fig.7 illustrates the delay between the third and the fouth signal. The delay is estimated with the skew function of the digital oscilloscope. The skew function calculates the delay between two signals in the following way: time of clock1 edge minus time of the nearest clock2 edge which represents exactly the delay between the two signals.

![](_page_3_Figure_7.jpeg)

Fig.7. The delay between the third and the fourth signal.

Computing all the delays between every two consecutive signals, Table 2 illustrates some of the most effective delays.

TABLE 2: DELAYS AT THE TWO 40-PIN CONNECTORS.

| Delay  | Post-route | 1 <sup>st</sup> 40-pin | 2 <sup>nd</sup> 40-pin |
|--------|------------|------------------------|------------------------|
| Signal | simulation | connector              | connector              |
|        | [ps]       | [ps]                   | [ps]                   |
| 3_4    | 104        | 606                    | 451                    |
| 5_6    | 117        | 438                    | 1051                   |

#### E. Correcting the Measured Rise Time

Rise time refers to the time required for a signal to change from a specificed low value(10%) to a specified high value(90%).

The relationship between the rise time and the bandwidth of a digital oscilloscope is given by:

$$t_r[\mu s] = \frac{N}{B[MHz]}, \qquad N = 0.4 \text{ to } 0.5$$
(1)

The measured rise time is commonly related to the oscilloscope rise time and the real rise time using the formula:

$$t_{measured}^2 = t_{oscilloscope}^2 + t_{real}^2 \tag{2}$$

The relationship (2) is useble only if  $t_{measured} \ge t_r$  [7],[8]. Otherwise, the errors make the correction useless. The oscilloscope rise time is, form its tehnical manual, 400ps.[6]

The real rise time is shown in Tabel 3.

TABLE 3: REAL RISE TIME

| Delay  | Measured  | Oscilloscope | Real rise |
|--------|-----------|--------------|-----------|
| Signal | rise time | rise time    | time      |
|        | [ps]      | [ps]         | [ps]      |
| 3_4    | 606       | 400          | 456       |
| 5_6    | 438       | 400          | 178       |

#### IV. CONCLUSION

In managing short times, extra care should be taken. The oscilloscope's bandwidth should be at least five times higher than the fastest clock rate in the design. Otherwise, in order to make accurate edge-speed measurements on the signals, you will need to determine the maximum practical frequency present in the signal.

#### References

- S. Popescu, A.Gontean, I.Lie, "Comparing FPGA behavioral simulation, post-routed simulation with real-life experiments"— Accepted for publication at SIITME2009.
- [2] XUP Virtex-II Pro Development System, User Manual, Xilinx, 2009.
- [3] Virtex II Pro User Guide Family, Xilinx, 2004
- [4] J.Wakerly Digital Design.Principles and Practices, Third Edition, 2006.
- [5] ISE 10.1 Quick Start Tutorial, *Xilinx*, 2008
- [6] LeCroy WaveSurfer, Xs Series Oscilloscope Operator's Manual, 2008
- [7] Relating wideband DSO rise time to bandwidth: Lose the 0.35, *Agilent* 55W-18024-2, 2009
- [8] Understanding Oscilloscope Bandwidth, Rise Time and Signal Fidelity, *Tektronix*, 2002.