Digilent Basys2 Board
Reference Manual
Revision: November 11, 2010
1300 Henley Court | Pullman, WA 99163
(509) 334 6306 Voice and Fax
Introduction
The Basys2 board is a circuit design and
implementation platform that anyone can use
to gain experience building real digital circuits.
Built around a Xilinx Spartan-3E Field
Programmable Gate Array and a Atmel
AT90USB2 USB controller, the Basys2 board
provides complete, ready-to-use hardware
suitable for hosting circuits ranging from basic
logic devices to complex controllers. A large
collection of on-board I/O devices and all
required FPGA support circuits are included,
so countless designs can be created without
the need for any other components.
Full Speed
USB2 Port
(JTAG and data transfers)
Settable Clock
Source
(config ROM)
(25 / 50 / 100 MHz)
JTAG
port
Data
port
20
Platform
Flash
Xilinx Spartan3E-100 CP132
32
2
8 bit
color
JA
I/O Devices
PS/2
Port
VGA Port
JB
4
4
4
4
JC
JD
Pmod Connectors
Four standard expansion connectors allow
• 100,000-gate Xilinx Spartan 3E FPGA
• Atmel AT90USB2 Full-speed USB2 port providing board power
designs to grow beyond the Basys2 board
and programming/data transfer interface
using breadboards, user-designed circuit
•
Xilinx Platform Flash ROM to store FPGA configurations
boards, or Pmods (Pmods are inexpensive
• 8 LEDs, 4-digit 7-segment display, 4 buttons, 8 slide switches
analog and digital I/O modules that offer A/D
• PS/2 port and 8-bit VGA port
nd
& D/A conversion, motor drivers, sensor
• User-settable clock (25/50/100MHz), plus socket for 2 clock
inputs, and many other features). Signals on
• Four 6-pin header expansion connectors
• ESD and short-circuit protection on all I/O signals.
the 6-pin connectors are protected against
ESD damage and short-circuits, ensuring a
Figure 1. Basys2 board block diagram and features
long operating life in any environment. The
Basys2 board works seamlessly with all
versions of the Xilinx ISE tools, including the free WebPack. It ships with a USB cable that provides
power and a programming interface, so no other power supplies or programming cables are required.
The Basys2 board can draw power and be programmed via its on-board USB2 port. Digilent’s freely
available PC-based Adept software automatically detects the Basys2 board, provides a programming
interface for the FPGA and Platform Flash ROM, and allows user data transfers (see
www.digilentinc.com for more information).
The Basys2 board is designed to work with the free ISE WebPack CAD software from Xilinx.
WebPack can be used to define circuits using schematics or HDLs, to simulate and synthesize
circuits, and to create programming files. Webpack can be downloaded free of charge from
www.xilinx.com/ise/.
The Basys2 board ships with a built-in self-test/demo stored in its ROM that can be used to test all
board features. To run the test, set the Mode Jumper (see below) to ROM and apply board power. If
the test is erased from the ROM, it can be downloaded and reinstalled at any time. See
www.digilentinc.com/Basys2 for the test project as well as further documentation, reference designs,
and tutorials.
Doc: 502-155
page 1 of 12
Copyright Digilent, Inc. All rights reserved. Other product and company names mentioned may be trademarks of their respective owners.
Basys2 Reference Manual
Digilent
www.digilentinc.com
Board Power
The Basys2 board is typically powered from a USB cable, but a
battery connector is also provided so that external supplies can be
used. To use USB power, simply attach the USB cable. To power
the Basys2 using a battery or other external source, attach a 3.5V5.5V battery pack (or other power source) to the 2-pin, 100-mil
spaced battery connector (three AA cells in series make a good
4.5+/- volt supply). Voltages higher than 5.5V on either power
connector may cause permanent damage.
Input power is routed through the power switch (SW8) to the four
6-pin expansion connectors and to a Linear Technology LTC3545
voltage regulator. The LTC3545 produces the main 3.3V supply
for the board, and it also produces 2.5V and 1.2V supply voltages
Figure 2. Basys2 power circuits
required by the FPGA. Total board current is dependent on FPGA
configuration, clock frequency, and external connections. In test circuits with roughly 20K gates
routed, a 50MHz clock source, and all LEDs illuminated, about 100mA of current is drawn from the
1.2V supply, 50mA from the 2.5V supply, and 50mA from the 3.3V supply. Required current will
increase if larger circuits are configured in the FPGA, or if peripheral boards are attached.
The Basys2 board uses a four layer PCB, with the inner layers dedicated to VCC and GND planes.
The FPGA and the other ICs on the board have large complements of ceramic bypass capacitors
placed as close as possible to each VCC pin, resulting in a very clean, low-noise power supply.
Configuration
After power-on, the FPGA on the Basys2 board must be configured before it can perform any useful
functions. During configuration, a “bit” file is transferred into memory cells within the FPGA to define
the logical functions and circuit interconnects. The free ISE/WebPack CAD software from Xilinx can
be used to create bit files from VHDL, Verilog, or schematic-based source files.
Digilent’s PC-based program called Adept can be used to configure the FPGA with any suitable bit file
stored on the computer. Adept uses the USB cable to transfer a selected bit file from the PC to the
FPGA (via the FPGA’s JTAG programming port). Adept can also program a bit file into an on-board
non-volatile ROM called “Platform Flash”. Once programmed, the Platform Flash can automatically
transfer a stored bit file to the FPGA at a subsequent power-on or reset event if the Mode Jumper
(JP3) is set to ROM. The FPGA will remain configured until it is reset by a power-cycle event. The
Platform Flash ROM will retain a bit file until it is reprogrammed, regardless of power-cycle events.
Doc: 502-138
page 2 of 12
Digilent
Basys2 Reference Manual
Atmel
AT90USB2
Mode
Jumper
PC
USB miniB
connector
JTAG
To program the Basys2 board, set the mode
jumper to PC and attach the USB cable to
the board. Start the Adept software, and
wait for the FPGA and the Platform Flash
ROM to be recognized. Use the browse
function to associate the desired .bit file with
the FPGA, and/or the desired .mcs file with
the Platform Flash ROM. Right-click on the
device to be programmed, and select the
“program” function. The configuration file
will be sent to the FPGA or Platform Flash,
and the software will indicate whether
programming was successful. The “Status
LED” LED (LD_8) will also blink after the
FPGA has been successfully configured.
For further information on using Adept,
please see the Adept documentation
available at the Digilent website.
www.digilentinc.com
ROM
LD8
Spartan 3E
FPGA
XCF02
Platform
Flash
JTAG
port
Slave
serial
port
Figure 4. Basys2 Programming Circuits
Oscillators
The Basys2 board includes a primary, user-settable silicon oscillator that produces 25MHz, 50MHz, or
100MHz based on the position of the clock select jumper at JP4. Initially, this jumper is not loaded
and must be soldered in place. A socket for a second oscillator is provided at IC6 (the IC6 socket can
accommodate any 3.3V CMOS oscillator in a half-size DIP package). The primary and secondary
oscillators are connected to global clock input
pins at pin B8 and pin M6 respectively.
Both clock inputs can drive the clock synthesizer
DLL on the Spartan 3E, allowing for a wide range
if internal frequencies, from 4 times the input
frequency to any integer divisor of the input
frequency.
The primary silicon oscillator is flexible and
inexpensive, but it lacks the frequency stability of
a crystal oscillator. Some circuits that drive a
VGA monitor may realize a slight improvement in
image stability by using a crystal oscillator
installed in the IC6 socket. For these applications,
a 25MHz (or 50MHz) crystal oscillator, available
from any catalog distributor, is recommended
(see for example part number SG-8002JF-PCC at
www.digikey.com ).
Spartan-3E
FPGA
B8
Linear Tech.
LTC6905
Oscillator
Frequency
Select
Jumper
25MHz
50MHz
CLK_OUT
100MHz
Figure 5. Basys2 oscillator circuits
Doc: 502-138
page 3 of 12
Digilent
Basys2 Reference Manual
www.digilentinc.com
User I/O
Four pushbuttons and eight slide switches
are provided for circuit inputs. Pushbutton
inputs are normally low and driven high
only when the pushbutton is pressed.
Slide switches generate constant high or
low inputs depending on position.
Pushbuttons and slide switches all have
series resistors for protection against
short circuits (a short circuit would occur if
an FPGA pin assigned to a pushbutton or
slide switch was inadvertently defined as
an output).
Eight LEDs and a four-digit sevensegment LED display are provided for
circuit outputs. LED anodes are driven
from the FPGA via current-limiting
resistors, so they will illuminate when a
logic ‘1’ is written to the corresponding
FPGA pin. A ninth LED is provided as a
power-indicator LED, and a tenth LED
(LD-D) illuminates any time the FPGA has
been successfully programmed.
Seven-segment display
Push
buttons
3.3V
LEDs
M5
M11
C11
P7
P6
M4
N5
A7
N4
P4
Spartan 3E
G1
FPGA
G12
BTN0
BTN1
BTN2
BTN3
3.3V
SW0
P11
SW1
L3
SW2
K3
SW3
B4
SW4
G3
SW5
F3
SW6
E2
SW7
N3
Slide
switches
LD0
LD1
LD2
LD3
LD4
LD5
LD6
LD7
3.3V
F12
J12
M13
K14
L14
H12
N14
N11
P12
L13
M12
N13
AN0
AN1
AN2
AN3
CA
CB
CC
CD
CE
CF
CG
DP
Each of the four digits of the seven7seg
Display
segment LED display is composed of
Figure 6. Basys2 I/O circuits
seven LED segments arranged in a “figure
8” pattern. Segment LEDs can be
individually illuminated, so any one of 128 patterns can be displayed on a digit by illuminating certain
LED segments and leaving the others dark. Of these 128 possible patterns, the ten corresponding to
the decimal digits are the most useful.
The anodes of the seven LEDs forming each digit are tied together into one common anode circuit
node, but the LED cathodes remain separate. The common anode signals are available as four “digit
enable” input signals to the 4-digit display. The cathodes of similar segments on all four displays are
connected into seven circuit nodes labeled CA through CG (so, for example, the four “D” cathodes
from the four digits are grouped together into a single circuit node called “CD”). These seven cathode
signals are available as inputs to the 4-digit display. This signal connection scheme creates a
multiplexed display, where the cathode signals are common to all digits but they can only illuminate
the segments of the digit whose corresponding anode signal is asserted.
A scanning display controller circuit can be used to show a four-digit number on this display. This
circuit drives the anode signals and corresponding cathode patterns of each digit in a repeating,
continuous succession, at an update rate that is faster than the human eye response. Each digit is
illuminated just one-quarter of the time, but because the eye cannot perceive the darkening of a digit
before it is illuminated again, the digit appears continuously illuminated. If the update or “refresh” rate
is slowed to a given point (around 45 hertz), then most people will begin to see the display flicker.
Doc: 502-138
page 4 of 12
Digilent
Basys2 Reference Manual
www.digilentinc.com
Common anode
AN1
AN2
AN3
AN4
A
F
CA CB CC CD CE CF CG DP
G
E
B
C
DP
Four-digit Seven
Segment Display
D
An un-illuminated seven-segment display, and nine
illumination patterns corresponding to decimal digits
Individual cathodes
Figure 7. Seven-segment display
For each of the four digits to appear
Refresh period = 1ms to 16ms
bright and continuously illuminated, all
four digits should be driven once every 1
Digit period = Refresh / 4
to 16ms (for a refresh frequency of
AN0
1KHz to 60Hz). For example, in a 60Hz
AN1
refresh scheme, the entire display would
be refreshed once every 16ms, and
AN2
each digit would be illuminated for ¼ of
AN3
the refresh cycle, or 4ms. The controller
Cathodes
Digit 0
Digit 1
Digit 2
Digit 3
must assure that the correct cathode
pattern is present when the
corresponding anode signal is driven.
Figure 8. Multiplexed 7seg display timing
To illustrate the process, if AN1 is
asserted while CB and CC are asserted, then a “1” will be displayed in digit position 1. Then, if AN2 is
asserted while CA, CB and CC are asserted, then a “7” will be displayed in digit position 2. If A1 and
CB, CC are driven for 4ms, and then A2 and CA, CB, CC are driven for 4ms in an endless
succession, the display will show “17” in the first two digits. Figure 8 shows an example timing
diagram for a four-digit seven-segment controller.
PS/2 Port
The 6-pin mini-DIN connector can accommodate a PS/2 mouse or keyboard. The PS/2 connector is
supplied with 5VDC.
Both the mouse and keyboard use a two-wire serial bus (clock and data) to communicate with a host
device. Both use 11-bit words that include a start, stop and odd parity bit, but the data packets are
organized differently, and the keyboard interface allows bi-directional data transfers (so the host
device can illuminate state LEDs on the keyboard). Bus timings are shown in the figure.
The clock and data signals are only driven when data transfers occur, and otherwise they are held in
the “idle” state at logic ‘1’. The timings define signal requirements for mouse-to-host communications
and bi-directional keyboard communications. A PS/2 interface circuit can be implemented in the
FPGA to create a keyboard or mouse interface.
Doc: 502-138
page 5 of 12
Digilent
Basys2 Reference Manual
8
6
5
3
2
5
www.digilentinc.com
1
2
8
1
3
Pin1: Data
Pin2: Data
Pin3: GND
Pin5: Vdd
Pin6: Clock
Pin8: Clock
Spartan 3E
FPGA
B1
C3
200 Ω
200 Ω
CLK
DATA
6-pin
mini-DIN
6
(bottom up)
Figure 9. PS/2 connector and Basys2 PS/2 circuit
Keyboard
The keyboard uses open-collector drivers so the
keyboard or an attached host device can drive the
two-wire bus (if the host device will not send data to
the keyboard, then the host can use input-only ports).
Tck Tck
Edge 0
‘0’ start bit
Edge 10
‘1’ stop bit
Thld
Tsu
Symbol
Parameter
Min
30us
Clock time
TCK
Data-to-clock setup time 5us
TSU
THLD Clock-to-data hold time 5us
Max
50us
25us
25us
PS2-style keyboards use scan codes to
communicate key press data. Each key is assigned a
code that is sent whenever the key is pressed; if the
key is held down, the scan code will be sent
Figure 10. PS/2 signal timing
repeatedly about once every 100ms. When a key is
released, a “F0” key-up code is sent, followed by the
scan code of the released key. If a key can be “shifted” to produce a new character (like a capital
letter), then a shift character is sent in addition to the scan code, and the host must determine which
ASCII character to use. Some keys, called extended keys, send an “E0” ahead of the scan code (and
they may send more than one scan code). When an extended key is released, an “E0 F0” key-up
code is sent, followed by the scan code. Scan codes for most keys are shown in the figure. A host
device can also send data to the keyboard. Below is a short list of some common commands a host
might send.
ED
EE
F3
FE
FF
Set Num Lock, Caps Lock, and Scroll Lock LEDs. Keyboard returns “FA” after receiving “ED”,
then host sends a byte to set LED status: Bit 0 sets Scroll Lock; bit 1 sets Num Lock; and Bit 2
sets Caps lock. Bits 3 to 7 are ignored.
Echo (test). Keyboard returns “EE” after receiving “EE”.
Set scan code repeat rate. Keyboard returns “F3” on receiving “FA”, then host sends second
byte to set the repeat rate.
Resend. “FE” directs keyboard to re-send most recent scan code.
Reset. Resets the keyboard.
The keyboard can send data to the host only when both the data and clock lines are high (or idle).
Since the host is the “bus master”, the keyboard must check to see whether the host is sending data
before driving the bus. To facilitate this, the clock line is used as a “clear to send” signal. If the host
pulls the clock line low, the keyboard must not send any data until the clock is released.
Doc: 502-138
page 6 of 12
Digilent
Basys2 Reference Manual
www.digilentinc.com
The keyboard sends data to the host in 11-bit words that contain a ‘0’ start bit, followed by 8-bits of
scan code (LSB first), followed by an odd parity bit and terminated with a ‘1’ stop bit. The keyboard
generates 11 clock transitions (at around 20 - 30KHz) when the data is sent, and data is valid on the
falling edge of the clock.
ESC
76
1!
16
`~
0E
F2
06
F3
04
F4
0C
2@
1E
3#
26
4$
25
5%
2E
Q
15
TAB
0D
W
1D
S
1B
A
1C
Caps Lock
58
D
23
V
2A
N
31
B
32
Alt
11
Ctrl
14
J
3B
H
33
G
34
K
42
M
3A
[{
54
P
4D
L
4B
,<
41
=+
55
-_
4E
0)
45
O
44
I
43
U
3C
Y
35
T
2C
F
2B
C
21
X
22
Z
1Z
Shift
12
R
2D
E
24
9(
46
8*
3E
7&
3D
6^
36
F10
09
F9
01
F8
0A
F7
83
F6
0B
F5
03
F1
05
;:
4C
/?
4A
>.
49
Space
29
Alt
E0 11
F11
78
F12
07
E0 75
BackSpace
66
E0 74
]}
5B
'"
52
\|
5D
E0 6B
Enter
5A
E0 72
Shift
59
Ctrl
E0 14
Figure 11. Keyboard scan codes
Mouse
The mouse outputs a clock and data signal when it is moved; otherwise, these signals remain at logic
‘1’. Each time the mouse is moved, three 11-bit words are sent from the mouse to the host device.
Each of the 11-bit words contains a ‘0’ start bit, followed by 8 bits of data (LSB first), followed by an
odd parity bit, and terminated with a ‘1’ stop bit. Thus, each data transmission contains 33 bits, where
bits 0, 11, and 22 are ‘0’ start bits, and bits 11, 21, and 33 are ‘1’ stop bits. The three 8-bit data fields
contain movement data as shown in the figure above. Data is valid at the falling edge of the clock, and
the clock period is 20 to 30KHz.
The mouse assumes a relative coordinate system wherein moving the mouse to the right generates a
positive number in the X field, and moving to the left generates a negative number. Likewise, moving
the mouse up generates a positive number in the Y field, and moving down represents a negative
number (the XS and YS bits in the status byte are the sign bits – a ‘1’ indicates a negative number).
The magnitude of the X and Y numbers represent the rate of mouse movement – the larger the
number, the faster the mouse is moving (the XV and YV bits in the status byte are movement overflow
indicators – a ‘1’ means overflow has occurred). If the mouse moves continuously, the 33-bit
transmissions are repeated every 50ms or so. The L and R fields in the status byte indicate Left and
Right button presses (a ‘1’ indicates the button is being pressed).
Mouse status byte
1
0
L
R
0
Start bit
1 XS YS XY YY P
Stop bit
X direction byte
1
0
Y direction byte
X0 X1 X2 X3 X4 X5 X6 X7 P
Start bit
1
Stop bit
Idle state
0
Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 P
Start bit
1
Stop bit
Idle state
Figure 12. Mouse data format
Doc: 502-138
page 7 of 12
Digilent
Basys2 Reference Manual
www.digilentinc.com
VGA Port
The Basys2 board uses 10 FPGA signals to
create a VGA port with 8-bit color and the two
standard sync signals (HS – Horizontal Sync,
and VS – Vertical Sync). The color signals use
resistor-divider circuits that work in conjunction
with the 75-ohm termination resistance of the
VGA display to create eight signal levels on the
red and green VGA signals, and four on blue
(the human eye is less sensitive to blue levels).
This circuit, shown in figure 13, produces video
color signals that proceed in equal increments
between 0V (fully off) and 0.7V (fully on). A
video controller circuit must be created in the
FPGA to drive the sync and color signals with
the correct timing in order to produce a working
display system.
VGA System Timing
5
10
15
Pin 1: Red
Pin 2: Grn
Pin 3: Blue
Pin 13: HS
Pin 14: VS
1
6
11
RED0
2KΩ
RED1
1KΩ
F13
RED2
510Ω
F14
G13
G14
GRN0
2KΩ
GRN1
1KΩ
GRN2
510Ω
BLUE0
1KΩ
BLUE1
510Ω
C14
Spartan 3E
D13
FPGA
H13
J13
Pin 5: GND
Pin 6: Red GND
Pin 7: Grn GND
Pin 8: Blu GND
Pin 10: Sync GND
HD-DB15
RED
GRN
BLU
200Ω
HS
J14
VGA signal timings are specified, published,
200Ω
copyrighted and sold by the VESA organization
VS
K13
(www.vesa.org). The following VGA system
timing information is provided as an example of
Figure 13. VGA pin definitions and Basys2 circuit
how a VGA monitor might be driven in 640 by
480 mode. For more precise information, or for
information on other VGA frequencies, refer to documentation available at the VESA website.
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 permittivity 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
Anode (entire screen)
timings as CRT displays (so the “signals”
discussion below pertains to both CRTs and
Cathode ray tube
LCDs). Color CRT displays use three electron
Deflection coils
beams (one for red, one for blue, and one for
Grid Electron guns
green) to energize the phosphor that coats
(Red, Blue, Green)
the inner side of the display end of a cathode
Cathode ray
ray tube (see illustration). Electron beams
emanate from “electron guns” which are
R,G,B signals
finely-pointed heated cathodes placed in
(to guns)
close proximity to a positively charged
annular plate called a “grid”. The electrostatic
VGA
force imposed by the grid pulls rays of
cable
energized electrons from the cathodes, and
High voltage deflection grid
gun
those rays are fed by the current that flows
supply (>20kV) control control control
into the cathodes. These particle rays are
initially accelerated towards the grid, but they
Figure 14. CRT deflection system
soon fall under the influence of the much
larger electrostatic force that results from the
Doc: 502-138
page 8 of 12
Basys2 Reference Manual
Digilent
www.digilentinc.com
entire phosphor-coated display surface of the CRT being charged to 20kV (or more). The rays are
focused to a fine beam as they pass through the center of the grids, and then they accelerate to
impact on the phosphor-coated display surface. The phosphor surface glows brightly at the impact
point, and it continues to glow for several hundred microseconds after the beam is removed. The
larger the current fed into the cathode, the brighter the phosphor will glow.
Between the grid and the display surface, the beam passes through the neck of the CRT where two
coils of wire produce orthogonal electromagnetic fields. Because cathode rays are composed of
charged particles (electrons), they can be deflected by these magnetic fields. Current waveforms are
passed through the coils to produce magnetic fields that interact with the cathode rays and cause
them to transverse the display surface in a “raster” pattern, horizontally from left to right and vertically
from top to bottom. As the cathode ray moves over the surface of the display, the current sent to the
electron guns can be increased or decreased to change the brightness of the display at the cathode
ray impact point.
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 is reset 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. The size of the beams, the frequency at
which the beam can be traced across the display, and the frequency at which the electron beam can
be modulated determine the display resolution. Modern VGA displays can accommodate different
resolutions, and a VGA controller
circuit dictates the resolution by
pixel 0,0
pixel 0,639
producing timing signals to control the
raster patterns. The controller must
640 pixels per row are displayed
produce synchronizing pulses at 3.3V
during forward beam trace
(or 5V) to set the frequency at which
current flows through the deflection
Retrace - no
coils, and it must ensure that video
information
Display Surface
data is applied to the electron guns at
displayed
the correct time. Raster video displays
during this
time
define a number of “rows” that
pixel 479,0
pixel 479,639
corresponds to the number of
horizontal passes the cathode makes
over the display area, and a number of
“columns” that corresponds to an area
Stable current ramp - information
on each row that is assigned to one
is displayed during this time
“picture element” or pixel. Typical
Current
displays use from 240 to 1200 rows
waveform
and from 320 to 1600 columns. The
through
overall size of a display and the
horizontal
Total horizontal time
number of rows and columns
defletion
retrace
coil
determines the size of each pixel.
Horizontal display time
time
time
Video data typically comes from a
HS
video refresh memory, with one or
Horizontal sync signal
more bytes assigned to each pixel
"front porch"
"back porch"
sets retrace frequency
location (the Basys2 uses three bits
per pixel). The controller must index
Figure 15. VGA system signals
into video memory as the beams move
across the display, and retrieve and apply video data to the display at precisely the time the electron
beam is moving across a given pixel.
Doc: 502-138
page 9 of 12
Digilent
Basys2 Reference Manual
www.digilentinc.com
A VGA controller circuit must generate the
TS
HS and VS timings signals and coordinate
Tfp
Tdisp
the delivery of video data based on the pixel
clock. The pixel clock defines the time
available to display one pixel of information.
T pw
Tbp
The VS signal defines the “refresh”
frequency of the display, or the frequency at
Horiz. Sync
Vertical Sync
which all information on the display is
Symbol Parameter
Time Clocks Lines Time Clks
redrawn. The minimum refresh frequency is
TS
Sync pulse
16.7ms 416,800 521
32 us 800
a function of the display’s phosphor and
T disp Display time 15.36ms 384,000 480 25.6 us 640
electron beam intensity, with practical
refresh frequencies falling in the 50Hz to
T pw Pulse width
64 us 1,600
2
3.84 us 96
120Hz range. The number of lines to be
T fp
Front porch
320 us 8,000
10
640 ns 16
displayed at a given refresh frequency
T bp
Back porch
928 us 23,200
29
1.92 us 48
defines the horizontal “retrace” frequency.
For a 640-pixel by 480-row display using a
Figure 16. VGA system timings for 640x480 display
25MHz pixel clock and 60 +/-1Hz refresh,
the signal timings shown in the table at right
can be derived. Timings for sync pulse width and front and back porch intervals (porch intervals are
the pre- and post-sync pulse times during which information cannot be displayed) are based on
observations taken from actual VGA displays.
A VGA controller circuit decodes the output of a horizontal-sync counter driven by the pixel clock to
generate HS signal timings. This counter can be used to locate any pixel location on a given row.
Likewise, the output of a vertical-sync counter that increments with each HS pulse can be used to
generate VS signal timings, and this counter can be used to locate any given row. These two
continually running counters can be used to form an address into video RAM. No time relationship
between the onset of the HS pulse and the onset of the VS pulse is specified, so the designer can
arrange the counters to easily form video RAM addresses, or to minimize decoding logic for sync
pulse generation.
HS
Zero
Detect
Pixel
CLK
Set
Horizontal
Synch
Horizontal
Counter
3.84us
Detect
Reset
CE
Zero
Detect
Set
Vertical
Synch
Vertical
Counter
64us
Detect
VS
Reset
Figure 17. Schematic for a VGA controller circuit
Doc: 502-138
page 10 of 12
Digilent
Basys2 Reference Manual
www.digilentinc.com
Short-circuit protection
resistors
Expansion Connectors (6-pin headers)
B2
A3
J3
B5
The Basys2 board provides four 6-pin
peripheral module connectors. Each connector
provides Vdd, GND, and four unique FPGA
signals. Several 6-pin module boards that can
attach to this connector are available from
Digilent, including A/D converters, speaker
amplifiers, microphones, H-bridge amplifiers,
etc. Please see www.digilentinc.com for more
information.
Spartan 3E
FPGA
FPGA Pin Definitions
The table below shows all pin definitions for the
Spartan-3E on the Basys2 board. Pins in grey
boxes are not available to the user
FPGA pin definition table color key
Grey
Green
Yellow
Tan
Blue
Not available to user
User I/O devices
Data ports
Pmod connector signals
USB signals
Pin
Signal
Pin
C12
A13
A12
B12
B11
C11
C6
B6
C5
B5
C4
B4
A3
A10
C9
B9
A9
B8
C8
A7
B7
P4
JD1
JD2
NC
NC
NC
BTN1
JB1
JB2
JB3
JA4
NC
SW3
JA2
JC3
JC4
JC2
JC1
MCLK
RCCLK
BTN3
JB4
LD6
P11
M2
N2
M9
N9
M10
N10
M11
N11
P12
N3
M6
P6
P7
M4
N4
M5
N5
G14
G13
F12
K13
Doc: 502-138
N14
N13
M13
M12
L14
L13
F13
F14
D12
D13
C13
C14
G12
K14
J12
J13
J14
H13
H12
J3
K3
B1
6-pin
header
JA
ESD protection
3.3V
diodes
C6
B6
C5
B7
1
2
3
4
6-pin
header
A9
B9
A10
C9
1
2
3
4
6-pin
header
C12
A13
C13
D12
1
2
3
4
6-pin
header
JB
JC
JD
Figure 18. Basys2 Pmod connector circuits
Basys2 Spartan-3E pin definitions
Signal Pin Signal Pin
Signal
Pin
SW0
USB-DB1
USB-DB0
NC
NC
NC
NC
LD1
CD
CE
SW7
UCLK
LD3
LD2
BTN2
LD5
LD0
LD4
GRN2
GRN1
AN0
VSYNC
1
2
3
4
5
6
CC
DP
AN2
CG
CA
CF
RED2
GRN0
JD4
RED1
JD3
RED0
BTN0
AN3
AN1
BLU2
HSYNC
BLU1
CB
JA3
SW2
PS2C
B2
C2
C3
D1
D2
L2
L1
M1
L3
E2
F3
F2
F1
G1
G3
H1
H2
H3
B14
B13
A2
A14
JA1
USB-WRITE
PS2D
NC
USB-WAIT
USB-DB4
USB-DB3
USB-DB2
SW1
SW6
SW5
USB-ASTB
USB-DSTB
LD7
SW4
USB-DB6
USB-DB5
USB-DB7
TMS
TCK-FPGA
TDO-USB
TDO-S3
P8
N7
N6
N12
P13
A1
N8
N1
P1
B3
A4
A8
C1
C7
C10
E3
E14
G2
H14
J1
K12
M3
Signal
Pin
Signal
MODE0
MODE1
MODE2
CCLK
DONE
PROG
DIN
INIT
NC
GND
GND
GND
GND
GND
GND
GND
GND
GND
GND
GND
GND
GND
M7
P5
P10
P14
A6
B10
E13
M14
P3
M8
E1
J2
A5
E12
K1
P9
A11
D3
D14
K2
L12
P2
GND
GND
GND
GND
VDDO-3
VDDO-3
VDDO-3
VDDO-3
VDDO-3
VDDO-3
VDDO-3
VDDO-3
VDDO-2
VDDO-2
VDDO-2
VDDO-2
VDDO-1
VDDO-1
VDDO-1
VDDO-1
VDDO-1
VDDO-1
page 11 of 12
Basys2 Reference Manual
Digilent
www.digilentinc.com
Built in Self Test
The Basys2 board comes preloaded with a simple self test/demonstration project stored in its ROM.
The demo project (available at the website) shows how the Xilinx CAD tools connect FPGA signals to
Basys2 circuits. Since the project is stored in ROM, it can also be used to check board functions. To
run the demo, set the ROM/USB jumper (JP3) to ROM and apply power to the board; the sevensegment display will show counting digits, the switches will turn on individual LEDs, the buttons will
turn off individual digits on the seven segment display, and a test pattern is driven on the VGA port.
If the self test is not resident in the Platform Flash ROM, it can be programmed into the FPGA or
reloaded into the ROM using the Adept programming software.
Doc: 502-138
page 12 of 12
Mouser Electronics
Authorized Distributor
Click to View Pricing, Inventory, Delivery & Lifecycle Information:
Digilent:
250-041P 250-041