# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



### Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



# Spartan-3 FPGA Starter Kit Board User Guide

UG130 (v1.2) June 20, 2008







Xilinx is disclosing this Document and Intellectual Property (hereinafter "the Design") to you for use in the development of designs to operate on, or interface with Xilinx FPGAs. Except as stated herein, none of the Design may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx. Any unauthorized use of the Design may violate copyright laws, trademark laws, the laws of privacy and publicity, and communications regulations and statutes.

Xilinx does not assume any liability arising out of the application or use of the Design; nor does Xilinx convey any license under its patents, copyrights, or any rights of others. You are responsible for obtaining any rights you may require for your use or implementation of the Design. Xilinx reserves the right to make changes, at any time, to the Design as deemed desirable in the sole discretion of Xilinx. Xilinx assumes no obligation to correct any errors contained herein or to advise you of any correction if such be made. Xilinx will not assume any liability for the accuracy or correctness of any engineering or technical support or assistance provided to you in connection with the Design.

THE DESIGN IS PROVIDED "AS IS" WITH ALL FAULTS, AND THE ENTIRE RISK AS TO ITS FUNCTION AND IMPLEMENTATION IS WITH YOU. YOU ACKNOWLEDGE AND AGREE THAT YOU HAVE NOT RELIED ON ANY ORAL OR WRITTEN INFORMATION OR ADVICE, WHETHER GIVEN BY XILINX, OR ITS AGENTS OR EMPLOYEES. XILINX MAKES NO OTHER WARRANTIES, WHETHER EXPRESS, IMPLIED, OR STATUTORY, REGARDING THE DESIGN, INCLUDING ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, AND NONINFRINGEMENT OF THIRD-PARTY RIGHTS.

IN NO EVENT WILL XILINX BE LIABLE FOR ANY CONSEQUENTIAL, INDIRECT, EXEMPLARY, SPECIAL, OR INCIDENTAL DAMAGES, INCLUDING ANY LOST DATA AND LOST PROFITS, ARISING FROM OR RELATING TO YOUR USE OF THE DESIGN, EVEN IF YOU HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. THE TOTAL CUMULATIVE LIABILITY OF XILINX IN CONNECTION WITH YOUR USE OF THE DESIGN, WHETHER IN CONTRACT OR TORT OR OTHERWISE, WILL IN NO EVENT EXCEED THE AMOUNT OF FEES PAID BY YOU TO XILINX HEREUNDER FOR USE OF THE DESIGN. YOU ACKNOWLEDGE THAT THE FEES, IF ANY, REFLECT THE ALLOCATION OF RISK SET FORTH IN THIS AGREEMENT cc THAT XILINX WOULD NOT MAKE AVAILABLE THE DESIGN TO YOU WITHOUT THESE LIMITATIONS OF LIABILITY.

The Design is not designed or intended for use in the development of on-line control equipment in hazardous environments requiring failsafe controls, such as in the operation of nuclear facilities, aircraft navigation or communications systems, air traffic control, life support, or weapons systems ("High-Risk Applications"). Xilinx specifically disclaims any express or implied warranties of fitness for such High-Risk Applications. You represent that use of the Design in such High-Risk Applications is fully at your risk.

© 2004-2008 Xilinx, Inc. All rights reserved. XILINX, the Xilinx logo, and other designated brands included herein are trademarks of Xilinx, Inc. PowerPC is a trademark of IBM Corp. and used under license. PCI, PCI-X, and PCI EXPRESS are registered trademarks of PCI-SIG. All other trademarks are the property of their respective owners. Some portions reproduced by permission from Digilent, Inc.

## Spartan-3 FPGA Starter Kit Board User Guide UG130 (v1.2) June 20, 2008

|          | Version | Revision                                                                  |
|----------|---------|---------------------------------------------------------------------------|
| 04/26/04 | 1.0     | Initial Xilinx release.                                                   |
| 06/07/04 | 1.0.1   | Minor modifications for printed release.                                  |
| 07/21/04 | 1.0.2   | Added information on auxiliary serial port connections to Chapter 7.      |
| 05/13/05 | 1.1     | Clarified that SRAM IC10 shares eight lower data lines with A1 connector. |
| 06/20/08 | 1.2     | Corrected A1 pins in Table 2-2. Updated links.                            |

The following table shows the revision history for this document.

# Table of Contents

| Preface: About This Guide Guide Contents                                              |
|---------------------------------------------------------------------------------------|
| Chapter 1: Introduction<br>Key Components and Features                                |
| Chapter 2: Fast, Asynchronous SRAM<br>Address Bus Connections                         |
| Chapter 3: Four-Digit, Seven-Segment LED Display                                      |
| Chapter 4: Switches and LEDsSlide Switches19Push Button Switches19LEDs20              |
| Chapter 5: VGA Port<br>Signal Timing for a 60Hz, 640x480 VGA Display                  |
| Chapter 6: PS/2 Mouse/Keyboard PortKeyboard28Mouse30Voltage Supply31                  |
| Chapter 7: RS-232 Serial Port                                                         |
| Chapter 8: Clock Sources                                                              |
| Chapter 9: FPGA Configuration Modes and Functions<br>FPGA Configuration Mode Settings |

### 

| Chapter 10: Platform Flash Configuration Storage            |
|-------------------------------------------------------------|
| Platform Flash Jumper Options (JP1)                         |
| <b>"Default" Option</b>                                     |
| "Flash Read" Option 39                                      |
| <b>"Disable" Option</b>                                     |
| Chapter 11: JTAG Programming/Debugging Ports                |
| <b>JTAG Header (J7)</b>                                     |
| Parallel Cable IV/MultiPro Desktop Tool JTAG Header (J5) 42 |
| Chapter 12: Power Distribution                              |
| AC Wall Adapter                                             |
| Voltage Regulators 45                                       |
| Chapter 13: Expansion Connectors and Boards                 |
| Expansion Connectors                                        |
| A1 Connector Pinout                                         |
| A2 Connector Pinout50B1 Connector Pinout51                  |
|                                                             |
| Expansion Boards                                            |
| Appendix A: Board Schematics                                |

Appendix B: Reference Material for Major Components



### Preface

## About This Guide

This user guide describes the components and operation of the Spartan<sup>®</sup>-3 FPGA Starter Kit Board.

#### **Guide Contents**

This manual contains the following chapters:

- Chapter 1, "Introduction"
- Chapter 2, "Fast, Asynchronous SRAM"
- Chapter 3, "Four-Digit, Seven-Segment LED Display"
- Chapter 4, "Switches and LEDs"
- Chapter 5, "VGA Port"
- Chapter 6, "PS/2 Mouse/Keyboard Port"
- Chapter 7, "RS-232 Serial Port"
- Chapter 8, "Clock Sources"
- Chapter 9, "FPGA Configuration Modes and Functions"
- Chapter 10, "Platform Flash Configuration Storage"
- Chapter 11, "JTAG Programming/Debugging Ports"
- Chapter 12, "Power Distribution"
- Chapter 13, "Expansion Connectors and Boards"
- Appendix A, "Board Schematics"
- Appendix B, "Reference Material for Major Components"



### Introduction

The Xilinx Spartan<sup>®</sup>-3 FPGA Starter Kit provides a low-cost, easy-to-use development and evaluation platform for Spartan-3 FPGA designs.

#### **Key Components and Features**

Figure 1-1 shows the Spartan-3 Starter Kit board, which includes the following components and features:

- 200,000-gate Xilinx <u>Spartan-3</u> XC3S200 FPGA in a 256-ball thin Ball Grid Array package (XC3S200FT256)
  - 4,320 logic cell equivalents
  - Twelve 18K-bit block RAMs (216K bits)
  - Twelve 18x18 hardware multipliers
  - Four Digital Clock Managers (DCMs)
  - Up to 173 user-defined I/O signals
- 2Mbit Xilinx XCF02S <u>Platform Flash</u>, in-system programmable configuration PROM (2)
  - 1Mbit non-volatile data or application code storage available after FPGA configuration
  - Jumper options allow FPGA application to read PROM data or FPGA configuration from other sources 3
- 1M-byte of Fast Asynchronous SRAM (bottom side of board, see Figure 1-3) (4)
  - Two 256Kx16 ISSI IS61LV25616AL-10T 10 ns SRAMs
  - Configurable memory architecture
    - Single 256Kx32 SRAM array, ideal for MicroBlaze code images
    - Two independent 256Kx16 SRAM arrays
  - Individual chip select per device
  - Individual byte enables
- 3-bit, 8-color VGA display port 5
- 9-pin RS-232 Serial Port 6
  - DB9 9-pin female connector (DCE connector)
  - RS-232 transceiver/level translator
     7
  - Uses straight-through serial cable to connect to computer or workstation serial port
  - Second RS-232 transmit and receive channel available on board test points (3)



#### Figure 1-1: Xilinx Spartan-3 Starter Kit Board Block Diagram

- PS/2-style mouse/keyboard port (9)
- Four-character, seven-segment LED display 🔟
- Eight slide switches (1)
- Eight individual LED outputs (12)
- Four momentary-contact push button switches (13)

- 50 MHz crystal oscillator clock source (bottom side of board, see Figure 1-3) (14)
- Socket for an auxiliary crystal oscillator clock source (15)
- FPGA configuration mode selected via jumper settings (16)
- Push button switch to force FPGA reconfiguration (FPGA configuration happens automatically at power-on)
- LED indicates when FPGA is successfully configured (18)
- Three 40-pin expansion connection ports to extend and enhance the Spartan-3 Starter Kit Board (19) (20) (21)
  - See compatible expansion cards at <u>www.xilinx.com/products/boards/DO-SPAR3-DK/boards/daughtercards.htm</u>
  - Compatible with Digilent, Inc. peripheral boards
     www.digilentinc.com/Products/Catalog.cfm?Nav1=Products&Nav2=Peripheral&Cat=Peripheral
  - FPGA serial configuration interface signals available on the A2 and B1 connectors
    - PROG\_B, DONE, INIT\_B, CCLK, DONE
- JTAG port 2 for low-cost download cable 3
- Digilent JTAG download/debugging cable connects to PC parallel port 🙉
- JTAG download/debug port compatible with the Xilinx Parallel Cable IV and MultiPRO Desktop Tool (24)
- AC power adapter input for included international unregulated +5V power supply 25
- Power-on indicator LED (26)
- On-board 3.3V (27), 2.5V (28), and 1.2V (29) regulators

#### **Component Locations**

Figure 1-2 and Figure 1-3 indicate the component locations on the top side and bottom side of the board, respectively.



ug130\_c1\_02\_042704

Figure 1-2: Xilinx Spartan-3 Starter Kit Board (Top Side)



Figure 1-3: Xilinx Spartan-3 Starter Kit Board (Bottom Side)



## Fast, Asynchronous SRAM

The Spartan<sup>®</sup>-3 FPGA Starter Kit board has a megabyte of fast asynchronous SRAM, surface-mounted to the backside of the board. The memory array includes two 256Kx16 ISSI <u>IS61LV25616AL-10T</u> 10 ns SRAM devices, as shown in Figure 2-1. A detailed schematic appears in Figure A-8.



UG130\_c2\_01\_042604

Figure 2-1: FPGA to SRAM Connections

www.xilinx.com

The SRAM array forms either a single 256Kx32 SRAM memory or two independent 256Kx16 arrays. Both SRAM devices share common write-enable (WE#), output-enable (OE#), and address (A[17:0]) signals. However, each device has a separate chip select enable (CE#) control and individual byte-enable controls to select the high or low byte in the 16-bit data word, UB and LB, respectively.

The 256Kx32 configuration is ideally suited to hold MicroBlaze instructions. However, it alternately provides high-density data storage for a variety of applications, such as digital signal processing (DSP), large data FIFOs, and graphics buffers.

### **Address Bus Connections**

Both 256Kx16 SRAMs share 18-bit address control lines, as shown in Table 2-1. These address signals also connect to the A1 Expansion Connector (see "Expansion Connectors," page 47).

| Address Bit | FPGA Pin | A1 Expansion Connector Pin |
|-------------|----------|----------------------------|
| A17         | L3       | 35                         |
| A16         | K5       | 33                         |
| A15         | K3       | 34                         |
| A14         | J3       | 31                         |
| A13         | J4       | 32                         |
| A12         | H4       | 29                         |
| A11         | H3       | 30                         |
| A10         | G5       | 27                         |
| A9          | E4       | 28                         |
| A8          | E3       | 25                         |
| A7          | F4       | 26                         |
| A6          | F3       | 23                         |
| A5          | G4       | 24                         |
| A4          | L4       | 14                         |
| A3          | M3       | 12                         |
| A2          | M4       | 10                         |
| A1          | N3       | 8                          |
| A0          | L5       | 6                          |

Table 2-1: External SRAM Address Bus Connections to Spartan-3 FPGA



Both 256Kx16 SRAMs share common output enable (OE#) and write enable (WE#) control lines, as shown in Table 2-2. These control signals also connect to the A1 Expansion Connector (refer to "Expansion Connectors," page 47).

| Signal | FPGA Pin | A1 Expansion Connector Pin |  |  |
|--------|----------|----------------------------|--|--|
| OE#    | K4       | 18                         |  |  |
| WE#    | G3       | 16                         |  |  |

Table 2-2: External SRAM Control Signal Connections to Spartan-3 FPGA

### SRAM Data Signals, Chip Enables, and Byte Enables

The data signals, chip enables, and byte enables are dedicated connections between the FPGA and SRAM. Table 2-3 shows the FPGA pin connections to the SRAM designated IC10 in Figure A-8. Table 2-4 shows the FPGA pin connections to SRAM IC11. To disable an SRAM, drive the associated chip enable pin High.

| Signal                       | FPGA Pin | A1 Expansion Connector Pin |
|------------------------------|----------|----------------------------|
| IO15                         | R1       |                            |
| IO14                         | P1       |                            |
| IO13                         | L2       |                            |
| IO12                         | J2       |                            |
| IO11                         | H1       |                            |
| IO10                         | F2       |                            |
| IO9                          | P8       |                            |
| IO8                          | D3       |                            |
| IO7                          | B1       | 19                         |
| IO6                          | C1       | 17                         |
| IO5                          | C2       | 15                         |
| IO4                          | R5       | 13                         |
| IO3                          | T5       | 11                         |
| IO2                          | R6       | 9                          |
| IO1                          | T8       | 7                          |
| IO0                          | N7       | 5                          |
| CE1 (chip enable IC10)       | P7       |                            |
| UB1 (upper byte enable IC10) | T4       |                            |
| LB1 (lower byte enable IC10) | P6       |                            |

Table 2-3: SRAM IC10 Connections

XILINX®

| Signal                       | FPGA Pin |
|------------------------------|----------|
| IO15                         | N1       |
| IO14                         | M1       |
| IO13                         | K2       |
| IO12                         | C3       |
| IO11                         | F5       |
| IO10                         | G1       |
| IO9                          | E2       |
| IO8                          | D2       |
| IO7                          | D1       |
| IO6                          | E1       |
| IO5                          | G2       |
| IO4                          | J1       |
| IO3                          | K1       |
| IO2                          | M2       |
| IO1                          | N2       |
| IO0                          | P2       |
| CE2 (chip enable IC11)       | N5       |
| UB2 (upper byte enable IC11) | R4       |
| LB2 (lower byte enable IC11) | Р5       |

 Table 2-4:
 SRAM IC11 Connections



# Four-Digit, Seven-Segment LED Display

The Spartan<sup>®</sup>-3 FPGA Starter Kit board has a four-character, seven segment LED display controlled by FPGA user-I/O pins, as shown in Figure 3-1. Each digit shares eight common control signals to light individual LED segments. Each individual character has a separate anode control input. A detailed schematic for the display appears in Figure A-2.

The pin number for each FPGA pin connected to the LED display appears in parentheses. To light an individual signal, drive the individual segment control signal Low along with the associated anode control signal for the individual character. In Figure 3-1, for example, the left-most character displays the value '2'. The digital values driving the display in this example are shown in blue. The AN3 anode control signal is Low, enabling the control inputs for the left-most character. The segment control inputs, A through G and DP, drive the individual segments that comprise the character. A Low value lights the individual segment, a High turns off the segment. A Low on the A input signal, lights segment 'a' of the display. The anode controls for the remaining characters, AN[2:0] are all High, and these characters ignore the values presented on A through G and DP.



UG130\_c3\_01\_042704

#### Figure 3-1: Seven-Segment LED Digit Control

Table 3-1 lists the FPGA connections that drive the individual LEDs comprising a sevensegment character. Table 3-2 lists the connections to enable a specific character. Table 3-3 shows the patterns required to display hexadecimal characters.

www.xilinx.com

| Segment | FPGA Pin |
|---------|----------|
| А       | E14      |
| В       | G13      |
| С       | N15      |
| D       | P15      |
| Е       | R16      |
| F       | F13      |
| G       | N16      |
| DP      | P16      |

Table 3-1: FPGA Connections to Seven-Segment Display (Active Low)

| Table 3-2: | Digit Enable (Anode Control) Signals (Active Low) |
|------------|---------------------------------------------------|
|------------|---------------------------------------------------|

| Anode Control | AN3 | AN2 | AN1 | AN0 |
|---------------|-----|-----|-----|-----|
| FPGA Pin      | E13 | F14 | G14 | D14 |

| Table 3-3: | <b>Display Characters and Resulting</b> | a LED Segment Control Values |
|------------|-----------------------------------------|------------------------------|
| 10010 0 0. | Biopiay onalaotoro ana hooalting        |                              |

| Character | а | b | С | d | е | f | g |
|-----------|---|---|---|---|---|---|---|
| 0         | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1         | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 2         | 0 | 0 | 1 | 0 | 0 | 1 | 0 |
| 3         | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 4         | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 5         | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| 6         | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 7         | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 8         | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 9         | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| А         | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| b         | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| С         | 0 | 1 | 1 | 0 | 0 | 0 | 1 |
| d         | 1 | 0 | 0 | 0 | 0 | 1 | 0 |
| Е         | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| F         | 0 | 1 | 1 | 1 | 0 | 0 | 0 |



The LED control signals are time-multiplexed to display data on all four characters, as shown in Figure 3-2. Present the value to be displayed on the segment control inputs and select the specified character by driving the associated anode control signal Low. Through persistence of vision, the human brain perceives that all four characters appear simultaneously, similar to the way the brain perceives a TV display.



Figure 3-2: Drive Anode Input Low to Light an Individual Character

This "scanning" technique reduces the number of I/O pins required for the four characters. If an FPGA pin were dedicated for each individual segment, then 32 pins are required to drive four 7-segment LED characters. The scanning technique reduces the required I/O down to 12 pins. The drawback to this approach is that the FPGA logic must continuously scan data out to the displays—a small price to save 20 additional I/O pins.



### Switches and LEDs

#### Slide Switches

The Spartan<sup>®</sup>-3 FPGA Starter Kit board has eight slide switches, indicated as 1 in Figure 1-2. The switches are located along the lower edge of the board, toward the right edge. The switches are labeled SW7 through SW0. Switch SW7 is the left-most switch, and SW0 is the right-most switch. The switches connect to an associated FPGA pin, as shown in Table 4-1. A detailed schematic appears in Figure A-2.

#### Table 4-1: Slider Switch Connections

| Switch   | SW7 | SW6 | SW5 | SW4 | SW3 | SW2 | SW1 | SW0 |
|----------|-----|-----|-----|-----|-----|-----|-----|-----|
| FPGA Pin | K13 | K14 | J13 | J14 | H13 | H14 | G12 | F12 |

When in the UP or ON position, a switch connects the FPGA pin to  $V_{CCO}$ , a logic High. When DOWN or in the OFF position, the switch connects the FPGA pin to ground, a logic Low. The switches typically exhibit about 2 ms of mechanical bounce and there is no active debouncing circuitry, although such circuitry could easily be added to the FPGA design programmed on the board. A 4.7K $\Omega$  series resistor provides nominal input protection.

#### **Push Button Switches**

The Spartan-3 Starter Kit board has four momentary-contact push button switches, indicated as (3) in Figure 1-2. These push buttons are located along the lower edge of the board, toward the right edge. The switches are labeled BTN3 through BTN0. Push button switch BTN3 is the left-most switch, BTN0 the right-most switch. The push button switches connect to an associated FPGA pin, as shown in Table 4-2. A detailed schematic appears in Figure A-2.

Table 4-2: Push Button Switch Connections

| Push Button | BTN3 (User Reset) | BTN2 | BTN1 | BTN0 |  |
|-------------|-------------------|------|------|------|--|
| FPGA Pin    | L14               | L13  | M14  | M13  |  |

Pressing a push button generates a logic High on the associated FPGA pin. Again, there is no active debouncing circuitry on the push button.

The left-most button, BTN3, is also the default User Reset pin. BTN3 electrically behaves identically to the other push buttons. However, when applicable, BTN3 resets the provided reference designs.

#### **LEDs**

The Spartan-3 Starter Kit board has eight individual surface-mount LEDs located above the push button switches, indicated by (12) in Figure 1-2. The LEDs are labeled LED7 through LED0. LED7 is the left-most LED, LED0 the right-most LED. Table 4-3 shows the FPGA connections to the LEDs.

Table 4-3: LED Connections to the Spartan-3 FPGA

| LED      | LD7 | LD6 | LD5 | LD4 | LD3 | LD2 | LD1 | LD0 |
|----------|-----|-----|-----|-----|-----|-----|-----|-----|
| FPGA Pin | P11 | P12 | N12 | P13 | N14 | L12 | P14 | K12 |

The cathode of each LED connects to ground via a  $270\Omega$  resistor. To light an individual LED, drive the associated FPGA control signal High, which is the opposite polarity from lighting one of the 7-segment LEDs.



## VGA Port

The Spartan<sup>®</sup>-3 FPGA Starter Kit board includes a VGA display port and DB15 connector, indicated as <sup>(5)</sup> in Figure 1-2. Connect this port directly to most PC monitors or flat-panel LCD displays using a standard monitor cable.



#### Figure 5-1: VGA Connections from Spartan-3 Starter Kit Board

As shown in Figure 5-1, the Spartan-3 FPGA controls five VGA signals: Red (R), Green (G), Blue (B), Horizontal Sync (HS), and Vertical Sync (VS), all available on the VGA connector. The FPGA pins that drive the VGA port appear in Table 5-1. A detailed schematic is in Figure A-7.

www.xilinx.com

| Signal               | FPGA Pin |
|----------------------|----------|
| Red (R)              | R12      |
| Green (G)            | T12      |
| Blue (B)             | R11      |
| Horizontal Sync (HS) | R9       |
| Vertical Sync (VS)   | T10      |

| Table 5-1: | VGA Port Connections to the Spartan-3 FPGA |
|------------|--------------------------------------------|
|------------|--------------------------------------------|

Each color line has a series resistor to provide 3-bit color, with one bit each for Red, Green, and Blue. The series resistor uses the  $75\Omega$  VGA cable termination to ensure that the color signals remain in the VGA-specified 0V to 0.7V range. The HS and VS signals are TTL level. Drive the R, G, and B signals High or Low to generate the eight possible colors shown in Table 5-2.

| Resulting Color | Blue (B) | Green (G) | Red (R) |
|-----------------|----------|-----------|---------|
| Black           | 0        | 0         | 0       |
| Blue            | 1        | 0         | 0       |
| Green           | 0        | 1         | 0       |
| Cyan            | 1        | 1         | 0       |
| Red             | 0        | 0         | 1       |
| Magenta         | 1        | 0         | 1       |
| Yellow          | 0        | 1         | 1       |
| White           | 1        | 1         | 1       |

Table 5-2: 3-Bit Display Color Codes

VGA signal timing is specified, published, copyrighted, and sold by the Video Electronics Standards Association (VESA). The following VGA system and timing information is provided as an example of how the FPGA might drive VGA monitor in 640 by 480 mode. For more precise information or for information on higher VGA frequencies, refer to documents available on the VESA website or other electronics websites:

- Video Electronics Standards Association <u>http://www.vesa.org</u>
- VGA Timing Information <u>http://www.epanorama.net/documents/pc/vga\_timing.html</u>

### Signal Timing for a 60Hz, 640x480 VGA Display

CRT-based VGA displays use amplitude-modulated, moving electron beams (or cathode rays) to display information on a phosphor-coated screen. LCD displays use an array of switches that can impose a voltage across a small amount of liquid crystal, thereby changing light permitivity through the crystal on a pixel-by-pixel basis. Although the following description is limited to CRT displays, LCD displays have evolved to use the

same signal timings as CRT displays. Consequently, the following discussion pertains to both CRTs and LCD displays.

Within a CRT display, current waveforms pass through the coils to produce magnetic fields that deflect electron beams to transverse the display surface in a "raster" pattern, horizontally from left to right and vertically from top to bottom. As shown in Figure 5-2, information is only displayed when the beam is moving in the "forward" direction—left to right and top to bottom—and not during the time the beam returns back to the left or top edge of the display. Much of the potential display time is therefore lost in "blanking" periods when the beam is reset and stabilized to begin a new horizontal or vertical display pass.



Figure 5-2: CRT Display Timing Example

The size of the beams, the frequency at which the beam traces across the display, and the frequency at which the electron beam is modulated determine the display resolution.

Modern VGA displays support multiple display resolutions, and the VGA controller dictates the resolution by producing timing signals to control the raster patterns. The controller produces TTL-level synchronizing pulses that set the frequency at which current flows through the deflection coils, and it ensures that pixel or video data is applied to the electron guns at the correct time.

Video data typically comes from a video refresh memory with one or more bytes assigned to each pixel location. The Spartan-3 Starter Kit board uses three bits per pixel, producing one of the eight possible colors shown in Table 5-2. The controller indexes into the video data buffer as the beams move across the display. The controller then retrieves and applies video data to the display at precisely the time the electron beam is moving across a given pixel.

As shown in Figure 5-2, the VGA controller generates the HS (horizontal sync) and VS (vertical sync) timings signals and coordinates the delivery of video data on each pixel clock. The pixel clock defines the time available to display one pixel of information. The VS signal defines the "refresh" frequency of the display, or the frequency at which all information on the display is redrawn. The minimum refresh frequency is a function of the display's phosphor and electron beam intensity, with practical refresh frequencies in the 60 Hz to 120 Hz range. The number of horizontal lines displayed at a given refresh frequency defines the horizontal "retrace" frequency.

#### **VGA Signal Timing**

The signal timings in Table 5-3 are derived for a 640-pixel by 480-row display using a 25 MHz pixel clock and 60 Hz  $\pm$ 1 refresh. Figure 5-3 shows the relation between each of the timing symbols. The timing for the sync pulse width (T<sub>PW</sub>) and front and back porch intervals (T<sub>FP</sub> and T<sub>BP</sub>) are based on observations from various VGA displays. The front and back porch intervals are the pre- and post-sync pulse times. Information cannot be displayed during these times.

| Symbol            | Parameter       | Ve       | rtical Sync | Horizontal Sync |         |        |
|-------------------|-----------------|----------|-------------|-----------------|---------|--------|
|                   | Falameter       | Time     | Clocks      | Lines           | Time    | Clocks |
| T <sub>S</sub>    | Sync pulse time | 16.7 ms  | 416,800     | 521             | 32 µs   | 800    |
| T <sub>DISP</sub> | Display time    | 15.36 ms | 384,000     | 480             | 25.6 µs | 640    |
| T <sub>PW</sub>   | Pulse width     | 64 µs    | 1,600       | 2               | 3.84 µs | 96     |
| T <sub>FP</sub>   | Front porch     | 320 µs   | 8,000       | 10              | 640 ns  | 16     |
| T <sub>BP</sub>   | Back porch      | 928 µs   | 23,200      | 29              | 1.92 µs | 48     |

Table 5-3: 640x480 Mode VGA Timing



Figure 5-3: VGA Control Timing

Generally, a counter clocked by the pixel clock controls the horizontal timing. Decoded counter values generate the HS signal. This counter tracks the current pixel display location on a given row.

A separate counter tracks the vertical timing. The vertical-sync counter increments with each HS pulse and decoded values generate the VS signal. This counter tracks the current display row. These two continuously running counters form the address into a video display buffer. For example, the on-board fast SRAM is an ideal display buffer.

No time relationship is specified between the onset of the HS pulse and the onset of the VS pulse. Consequently the counters can be arranged to easily form video RAM addresses, or to minimize decoding logic for sync pulse generation.