®
Altera Corporation 1
Configuring
FLASHlogic Devices
April 1995, ver. 1 Application Note 45
A-AN-045-01
Introduction
The Altera FLASHlogic family of programmable logic devices (PLDs) is
based on CMOS technology with SRAM configuration elements. This
technology supports in-circuit reconfigurability (ICR) via the Joint Test
Action Group (JTAG) interface without requiring any special
programming voltages. FLASHlogic devices can be reconfigured with the
FLASHlogic Download Cable or an intelligent host.
Each FLASHlogic device has on-board, non-volatile FLASH or EPROM
memory that stores a single configuration. An external controller, such as
a microcontroller or state machine, is required for reconfiguration. When
the device is powered up, the configuration information is written into the
on-board SRAM and the device is ready to perform its intended function.
1
The FLASH or EPROM memory is programmed with Altera’s
PENGN software, which is not discussed in this application
note. For more information on programming FLASHlogic
devices, refer to the
PLDshell Plus/PLDasm User’s Guide V5.0
,
available from Altera Literature at (408) 894-7144.
JED2JTAG
Operation
To reconfigure a FLASHlogic device, you must first use Altera’s PLDshell
Plus software or third-party software to create a JEDEC File (
.jed
) that
contains the FLASHlogic device configuration information. You can then
process the file with Altera’s JED2JTAG software and use it to reconfigure
the device. The JED2JTAG software is included with PLDshell Plus.
1
The Altera MAX+PLUS II development system provides
programming-only support for FLASHlogic devices. Full device
support is planned for the second half of 1995.
JED2JTAG converts a JEDEC File into one of three different output
formats: a Bit File (
.bit
), a Binary File (
.bin
), or a Hexadecimal (Intel-
Format) File (
.hex
). The output format you choose depends on the type of
controller used to reconfigure the device. The controller then uses the
selected output format to send the configuration data to the FLASHlogic
device via the JTAG interface. Table 1 describes the JED2JTAG input files.
f
Go to the
PLDshell Plus/PLDasm User’s Guide V5.0
for additional
information on the FLASHlogic Download Cable, the JED2JTAG
software, and FLASHlogic device configuration.
2 Altera Corporation
AN 45: Configuring FLASHlogic Devices
The JED2JTAG software produces one of the output formats shown in
Table 2.
To start the JED2JTAG software, type the following command at the DOS
prompt:
jed2jtag
<
project name
>
9
Figure 1 shows a block diagram of JED2JTAG operation.
Table 1. JED2JTAG Input Files
File Description
String Description
File (
.sdl)
Describes the JTAG chain, which is the series of
connected devices on a circuit board.
<
file name
>
.jed
JEDEC File(s) generated with PLDshell Plus software can
be used to configure the FLASHlogic devices.
jtag.dvc
Library file, included with the PLDshell Plus software, that
contains a description of several common JTAG devices.
You can easily add information for other JTAG devices
from device data sheets or from the appropriate Boundary
Scan Description Language File (BSDL). Instructions on
adding devices are included in the
jtag.dvc
file.
Table 2. JED2JTAG Output Files
File Description
<
file name
>
.bit
JED2JTAG intermediate file. JED2JTAG creates one Bit File
for each JEDEC File, then compares the time stamps. If the
JEDEC File is more recent, JED2JTAG recreates the Bit
File.
<
project name
>
.bin
Bin File containing the JED2JTAG stream of JTAG signals.
This file is used to create a Hex File or is sent to the
computer’s parallel port. The Bin File is created from Bit
Files.
<
project name
>
.hex
Hex File used for programming standard memory devices.
Altera Corporation 3
AN 45: Configuring FLASHlogic Devices
Figure 1. JED2JTAG Block Diagram
The String Description File lists the JTAG device chain and any associated
JEDEC Files, as shown in the
example.sdl
file in Figure 2.
Figure 2. String Description File (example.sdl)
In this example, a pipe character (|) indicates a comment line.
|FILE: example.sdl -Simple Prototype Board
{
| Port_Num Port_Type
STRING 3 BIN_FILE
| Port_Num 1 - for LPT1:
| Port_Type must be PARALLEL_PORT or BIN_FILE
| Loc. Ref Device JEDEC File
DEVICE 0 U3 EPX780QC132 RIGHT.JED
DEVICE 1 U4 EPX780LC84 LEFT.JED
DEVICE 2 U1 TI_74BCT8373
}
The
STRING
instruction in the String Description File controls which
operations JED2JTAG uses for the JTAG chain. To create a Hex File or a
Bin File, specify the following:
STRING 3
<
file type
>
where
3
specifies the configuration option that enables you to generate a
file, and <
file type
> is either
HEX_FILE
or
BIN_FILE
.
.bin
Binary
File
jtag.dvc
Device
Library
File
.sdl
String
Description
File
JED2JTAG
Software
ICR via
Intelligent
Host
Parallel Port
Reconfiguration
via FLASHlogic
Download Cable
Custom Reconfiguration
Scheme (i.e., Board
Tester or Other Process)
.jed
JEDEC
File
.hex
Hex
File
4 Altera Corporation
AN 45: Configuring FLASHlogic Devices
To send the configuration via the PC’s parallel port, you must specify
parallel port instructions in the String Description File as follows:
STRING
<
parallel port
>
PARALLEL_PORT
where <
parallel port
> is
1
to specify LPT1 and
2
to specify LPT2.
The
example.sdl
file shown in Figure 2 describes the JTAG device chain
shown in Figure 3. In this example, Device 2 does not have a JEDEC File,
and will not be reconfigured by JED2JTAG.
Figure 3. JTAG Chain (example.sdl)
Configuring
FLASHlogic
Devices Using
ICR
In-circuit reconfigurability (ICR) enables you to reconfigure devices that
are already soldered onto a printed circuit board. For example, you can
use the FLASHlogic Download Cable or an intelligent host to change the
logic in add-on card applications that interface with different buses.
In-Circuit Reconfiguration with the FLASHlogic Download Cable
If a printed circuit board has a JTAG chain with a header, you can use the
FLASHlogic Download Cable to reconfigure devices in-circuit.
External Connector
Device
2 Device
1
TDOTDI TDOTDI
TDOTDI
Device
0
TMS & TCK
Altera Corporation 5
AN 45: Configuring FLASHlogic Devices
To use the FLASHlogic Download Cable:
1. Connect one end of the cable to your PC’s parallel port, and connect
the other end of the cable to the JTAG header on your printed circuit
board.
2. Create the JEDEC File(s) for the design.
3. Create a String Description File that describes the JTAG chain. Be
sure to include the appropriate parallel port
STRING
instruction.
4. Run JED2JTAG. This software generates a Bin File and downloads it
to your board to reconfigure the FLASHlogic device(s).
In-Circuit Reconfiguration with an Intelligent Host
When you reconfigure a device using an intelligent host, your system
must have the appropriate storage capability, such as ROM, external
peripherals, or disk drives. To reconfigure a device with an intelligent
host:
1. Create the JEDEC File(s) for the design.
2. Create a String Description File that describes the JTAG chain. Be
sure to include the appropriate Hex File
STRING
instruction.
3. Run JED2JTAG to create the Hex File.
4. Program the storage memory with the Hex File.
5. Develop software using the guidelines specified by your
microcontroller manufacturer to download the configuration data
from the storage device into the FLASHlogic device(s).
You can use almost any combination of CPU and memory to reconfigure
FLASHlogic devices in-circuit. For example, you can use an Intel 87C51
microprocessor as an intelligent host. See Figure 4.
6 Altera Corporation
AN 45: Configuring FLASHlogic Devices
Figure 4. Implementing ICR with an Intelligent Host
The interconnect between the CPU and the JTAG chain requires four I/O
signals (
TMS
,
TCK
,
TDI
, and
TDO
), plus a
RESET
signal, if necessary. See
Figure 5.
Figure 5. Sample Schematic for Implementing ICR with an Intelligent Host
Hex
File
(.hex)
JTAG
87C51 Memory
FLASHlogic
Device FLASHlogic
Device
RESET_R#
TDI_Port_R
TDO_Port_R
TMS_R
TCK_R
2
3
4
5
6
7
8
9
P10/T2
P11/T2EX
P12/ECI
P13/CEX0
P14/CEX1
P15/CEX2
P16/CEX3
P17/CEX4
P30/RXD
P31/TDX
P32/IN0 -
P33/IN1 -
P34/T0
P35/T1
P36/WR -
P37/RD -
VCC 21 12
237
LED
DS1 R3
LED_R
VCC
1
2
C4
0.1 µF1
C5
0.1 µF21
C6
0.1 µF21
C7
0.1 µF2
1
2Reset
2
1
C1
33 pF 2
12 MHz
1
3
41
2
Y1 C2
33 pF
VCC
C51-Reset
R1
21.5
VCC 12
21.5 k
R9
S11
2
R2
215
2
1
P20/A8
P21/A9
P22/A10
P23/A11
P24/A12
P25/A13
P26/A14
P27/A15
EA#
AL/Prog-
P00/AD0
P01-AD1
P02/AD2
P03/AD4
P04/AD5
P05/AD5
P06/AD6
P07/AD7
PSEN-XTAL1
XTAL2
EA-/VPP
35
87C51FA FLASH Memory
256KX8
CE
OE
WE
A0
A1
A2
A3
A4
A5
A6
A7
I/O1
I/O2
I/O3
I/O4
I/O5
I/O6
I/O7
I/O8
A8
A9
A10
A11
A12
A13
A14
A15
VPP
74HCT573
OC-
C
1D
2D
3D
4D
5D
6D
7D
8D
19 AO0
18 AO1
17 AO2
16 AO3
15 AO4
14 AO5
13 AO6
12 AO7
33 ALE
43 ADO0
42 ADO1
41 ADO2
40 ADO3
39 ADO4
38 ADO5
37 ADO6
36 ADO7
1
11
2
3
4
5
6
7
8
9
32
21
20
1Q
2Q
3Q
4Q
5Q
6Q
7Q
8Q
22
24
31
12
11
10
9
8
7
6
5
11
13
14
15
16
17
18
19
Flash-CE#
A16
A17
Write#
Read#
1
13
14
15
17
18
19
20
21
XTAL1
XTAL2
1
2C2
4.7 µF
10
27
26
23
25
4
28
29
3
24 A08
25 A09
26 A10
27 A11
28 A12
29 A13
30 A14
31 A15
2
30 A16
A17
JTAG Chain of
FLASHlogic
Devices
Altera Corporation 7
AN 45: Configuring FLASHlogic Devices
Figure 6 shows the code used by the 87C51 microprocessor to control the
JTAG chain.
Figure 6. Hex File Download Algorithm for the 87C51 (Part 1 of 2)
;********************************************************************
;* JTAG STAND-ALONE LOADER CODE
;**
;* This program usually executes in an embedded controller from an
;* executable memory bank. It transmits data from a local nonvolatile
;* data memory bank to a JTAG IEEE 1149.1 chain, typically to load the
;* SRAM control memory in the FLASHlogic devices in the chain.
;**
;* Data is stored in the non-volatile memory off-line, e.g., with a PROM
;* programmer. It is formatted as a JTAG data stream. Each byte
;* contains TDO/TMS data for 4 TCK cycles. Bit 0 of each byte is the
;* first TDO, bit 1 is the first TMS, bit 2 is the second TDO, etc.
;* No inversion occurs between memory and TMS/TDO.
;**
;* The first four bytes in the non-volatile memory specify the Ending
;* Address + 1. The least significant byte is at data address 0. The
;* JTAG data stream starts at data address 4.
;**
;* Data is automatically downloaded each time the embedded controller
;* is reset, including power-on.
;********************************************************************
; Initialization
SET LED# port bit ; turn off LED
DELAY (500) ; delay 500 ms.
; Give time for host JTAG string to completely power-up before
beginning.
CLR TICK port bit ; init TCK to LOW
CLR RESET# port bit ; init RESET# to LOW (activate host RESET)
CLR CE# port bit ; enable FLASH memory
CLR LED# port bit ; turn on LED
; Transmit data
adrs = 0; initialize data address and
last-adrs = (adrs) ; last address + 1 (these are 32 bit values)
adrs = adrs + 4;
WHILE (adrs < last_adrs)
( ; loop until all data is moved from memory to JTAG chain
; output lst TMS/TDO
MOVE bit 0 of (adrs) to TDO port bit
MOVE bit 1 of (adrs) to TMS port bit
SET TCK port bit ; pulse TCK
CLR TCK port bit
8 Altera Corporation
AN 45: Configuring FLASHlogic Devices
Figure 6. Hex File Download Algorithm for the 87C51 (Part 2 of 2)
; output 2nd TMS/TDO
MOVE bit 2 of (adrs ) to TDO port bit
MOVE bit 3 of (adrs) to TMS port bit
SET TCK port bit ; pulse TCK
CLR TCK port bit
; output 3rd TMS/TDO
MOVE bit 4 of (adrs) to TDO port bit
MOVE bit 5 of (adrs) to TMS Port bit
SET TCK port bit ; pulse TCK
CLR TCK port bit
; output 4th TMS/TDO
MOVE bit 6 of (adrs) to TDO port bit
MOVE bit 7 of (adrs) to TMS port bit
SET TCK port bit ; pulse TCK
CLR TCK port bit
adrs = adrs + 1
)
; Completion
SET RESET# port bit ; release host
SET LED# port bit ; turn off LED
SET CE# port bit ; disable memory to save power
SLEEP ; disable embedded controller to save power
Conclusion
Altera’s FLASHlogic family of PLDs provides the features and flexibility
designers need for many of today’s applications. These devices can be
reconfigured in-circuit, allowing quick and easy design iterations and
field upgrades.
Altera, MAX, MAX+PLUS, and FLEX are registered trademarks of Altera Corporation. The following are
trademarks of Altera Corporation: MAX+PLUS II, AHDL, and FLEX 10K. Altera acknowledges the
trademarks of other organizations for their respective products or services mentioned in this document,
specifically: Verilog and Verilog-XL are registered trademarks of Cadence Design Systems, Inc. Mentor
Graphics is a registered trademark of Mentor Graphics Corporation. Synopsys is a registered trademark of
Synopsys, Inc. Viewlogic is a registered trademark of Viewlogic Systems, Inc. Altera products are protected
under numerous U.S. and foreign patents and pending applications, maskwork rights, and copyrights. Altera
warrants performance of its semiconductor products to current specifications in accordance with Altera’s
standard warranty, but reserves the right to make changes to any products and services at any time without
notice. Altera assumes no responsibility or liability arising out of the application or use of
any information, product, or service described herein except as expressly agreed to in
writing by Altera Corporation. Altera customers are advised to obtain the latest version of
device specifications before relying on any published information and before placing
orders for products or services.
Copyright
1996 Altera Corporation. All rights reserved.
2610 Orchard Parkway
San Jose, CA 95134-2020
(408) 894-7000
Applications Hotline:
(800) 800-EPLD
Customer Marketing:
(408) 894-7104
Literature Services:
(408) 894-7144
®
Printed on Recycled Paper.