Using In-System Programming in Boundary-Scan Systems: TAP Timing

Download as pdf or txt
Download as pdf or txt
You are on page 1of 8

Application Note: XC9500 CPLDs

Using In-System Programming in BoundaryScan Systems

XAPP070 (v2.1.1) November 15, 2007

Summary

This application note discusses basic design considerations for in-system programming (ISP) of multiple XC9500 devices in a Boundary-Scan chain and shows how to design systems that contain multiple XC9500 devices as well as other IEEE 1149.1-compatible devices. Note: The Basic Boundary-Scan Design Guidelines and Debugging Boundary-Scan Systems
sections within this application note apply to all Xilinx devices that support Boundary-Scan.

Introduction

The XC9500 family performs both in-system programming and IEEE 1149.1 Boundary-Scan (JTAG) testing via a single 4-wire Test Access Port (TAP). This simplifies system designs and allows standard Automatic Test Equipment (ATE) to perform both functions. Xilinx also provides the software that programs and tests XC9500 devices.

XC9500 TAP Characteristics

The AC and DC characteristics of the XC9500 TAP are described below.

TAP Timing
Figure 1 shows the timing relationships of the TAP signals. These TAP timing characteristics are identical for both Boundary-Scan and ISP operations. The timing for the INPUT-I/O-CLK and I/O signals is relevant to Boundary-Scan operations (such as EXTEST) that activate or strobe the system pins.
X-Ref Target - Figure 1

TCKMIN

TCK TMS

TMSS

TMSH

TDIS

TDIH

TDI TDO

TDOZX

TDOV

TDOXZ

TINS TINH

INPUT-I/O-CLK
TIOV

I/O
X070_01_042402

Figure 1:

Test Access Port Timing

1997, 2002, 2007 Xilinx, Inc. All rights reserved. XILINX, the Xilinx logo, and other designated brands included herein are trademarks of Xilinx, Inc. All other trademarks are the property of their respective owners.

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

XC9500 TAP Characteristics

TAP AC Parameters
Table 1 shows the timing parameters for the TAP waveforms shown in Figure 1. Table 1: XC9500 Test Access Port Timing Parameters (ns)
Symbol TCKMIN TMSS TMSH TDIS TDIH TDOZX TDOXZ TDOV TINS TINH TIOV Parameter TCK Minimum Clock Period TMS Setup Time TMS Hold Time TDI Setup Time TDI Hold Time TDO Float to Valid Delay TDI Valid to Float Delay TDO Valid Delay I/O Setup Time I/O Hold Time EXTEST Output Valid Delay 15 30 55 Min 100 10 10 15 25 35 35 35 Max

Terminating TAP Pins


The XC9500 TDI and TMS pins have internal 15-k pull-up resistors required by the IEEE 1149.1 standard. Because these pins are internally terminated, no further termination is required on the TAP connections.

Capacitive Decoupling
Decouple the VCC input with a 0.1 F capacitor connected to the nearest ground plane (lowinductance surface mount capacitors are recommended). Decouple the printed circuit board power inputs with 0.1 F ceramic and 100 F electrolytic capacitors. This helps to provide a stable, noise-free power supply to the ISP parts.

Free Running Oscillators


Boundary-Scan operations often involve the transmission of long streams of data through long and complex paths that traverse the entire system. Often, the presence of active clocks and free running oscillators couple noise onto the Boundary-Scan chain TAP signals. To increase the reliability of Boundary-Scan and ISP operations, equip the system with a clock and oscillator disable. The disable should be activated for all test and program operations when using the download cable, ATE, or third-party systems.

Calculating Maximal Chain Lengths


The XC9500 TAP pins have approximately 5 pF of signal loading. Because each TDI input is driven by only one TDO output (or equivalent single drive), there are no signal limitations related to those connections beyond those of standard board interconnect design rules. The maximum TDO frequency is one half of the maximum TCK frequency. Because TCK and TMS are parallel driven signals, the maximum number of parts in a single Boundary-Scan chain is determined by the ability of the TCK and TMS drivers to deliver the signals at the appropriate frequencies to the parts in the Boundary-Scan chain. Standard board-layout design rules also apply here. If the Boundary-Scan chain includes more than six devices, buffered distribution of TMS and TCK are recommended.
XAPP070 (v2.1.1) November 15, 2007 www.xilinx.com 2

Creating Boundary-Scan Chains

Part Enable Ordering


The ISPEX instruction allows the flexibility to enable parts in an arbitrary order. In some systems, the order in which parts are enabled is critical. For instance, if a slave device awakens before its controller, it can enter an error condition from which it cannot exit. The iMPACT software enables each part immediately after programming. In concurrent mode, the parts are enabled simultaneously.

Creating Boundary-Scan Chains

There are a number of possibilities for creating Boundary-Scan chains, several of which are discussed in the following sections. The single-port serial chain is the recommended topology for in-system programming via Xilinx iMPACT software and cables. Other more complex chain variations are also discussed. However, the Xilinx software does not directly support the more complex chain topologies. Some third-party Boundary-Scan tool vendors support these complex chain configurations. Only Boundary-Scan experts should attempt to use the more complex topologies.

Single-Port Serial Chain


The most simple and widely-used Boundary-Scan configuration is the single port serial chain shown in Figure 2, and only this type of configuration is supported by the iMPACT software. In this configuration, four pins are allocated in the system to facilitate connection of the TCK (clock), TMS (mode), TDI (Test Data Input), and TDO (Test Data Output) signals. All devices in the chain share the TCK and TMS signals. The system TDI signal is connected to the TDI input of the first device in the Boundary-Scan chain. The TDO signal from that first device is connected to the TDI input of the second device in the chain and so on. The last device in the chain has its TDO output connected to the system TDO pin.
X-Ref Target - Figure 2

Device 1 TDI TDI TDO TMS TCK

Device 2 TDI TDO TMS TCK

Device N TDI TMS TCK TDO

System

TMS TCK TDO


x070_02_042302

Figure 2:

Single-Port Serial Boundary-Scan Chain

Star Configuration
The single port serial chain, shown in Figure 3, configuration has a significant limitation due to the possibility that a defect in the backplane wiring or the removal of a board from the system can break the chain. This would make ISP and system testing impossible. In order to overcome this limitation and make the 1149.1 standard practical for very large systems, the standard allows the connection of Boundary-Scan chains in star configuration in which the four pins of the TAP are multiplexed. The costs of this approach are the additional overhead required to switch between scan paths, and the reduced TCK frequency due to TMS routing delays.

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

Creating Boundary-Scan Chains

X-Ref Target - Figure 3

Device 1

Device 2 TDI TDO TMS TCK

Device N TDI TMS TCK TDO

MUX

TDI TDO TMS TCK

Path 1

TDI TMS TCK Device 1 TDI TDO TMS TCK Device 2 TDI TDO TMS TCK Device N TDI TMS TCK TDO

System

Path 2

Select

TDO

DE-MUX

x070_03_042302

Figure 3:

Star Configuration

Caution! The external MUX and select hardware must disconnect the primary TMS or TCK from
the deselected scan chain to prevent unexpected behavior on the deselected scan chain.

Multiple Independent Paths


In the topology shown in Figure 4, the TDI and TDO paths are independent allowing data to be streamed into and out of the portions of the system independently. Caution! This topology is not recommended for use with the Xilinx iMPACT software and cables.
X-Ref Target - Figure 4

Device 1 TDI TMS TCK TDI TDO TMS TCK TDO

TDI

Device 2 TDI TDO TMS TCK TDO

TDI

Device N TDI TMS TCK TDO

TDO

x070_04_021907

Figure 4:

Multiple Independent Chains

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

In-System Programming

Parallel Chains
In the topology shown in Figure 5, TDI and TMS inputs are independent but the TDO is shared. This means that although data can be streamed into portions of the system independently, data being streamed out is time multiplexed through TMS control. Caution! This topology is not recommended for use with the Xilinx iMPACT software and cables.
X-Ref Target - Figure 5

TDI

Device 1 TDI TDO TMS TCK

Device 2 TDI TMS TCK TDO

TMS TCK

Device 1 TDI TDI TDO TMS TCK

Device 2 TDI TMS TCK TDO

TMS
x070_05_042302

Figure 5:

Parallel Chains

In-System Programming

Using the Xilinx Download Cables


The iMPACT software can be used with any of the Xilinx download cables including the Parallel Cable IV or Platform Cable USB. The Xilinx cables can be used on PCs running Microsoft Windows or RedHat Linux operating systems. See the Xilinx Software Manuals for operating system support details. The cables include port protection and drive circuitry. See the Cable Data Sheets for operating recommendations and specifications.

Concurrent Program and Erase Modes


One operating mode of the iMPACT software performs concurrent erasing and programming. The advantage of this approach is speed; the overall programming time is dictated by the slowest part in the Boundary-Scan chain. Also, the total number of vectors required is optimized. The disadvantage of this approach is that the system must supply a peak operating current equal to that required by all parts being programmed or erased concurrently. For more information on how to use this feature in iMPACT, please see the Xilinx iMPACT Software Manual.

ISP Mode I/O Behavior


The functional pins of the device transition to a high-impedance state when ISP mode is entered using the ISPEN instruction. At the completion of an ISP programming or erase operation, the ISPEX instruction is executed. When leaving ISPEX mode (by shifting in an new Boundary-Scan instruction other than ISPEN), the device initializes to its programmed state; the functional pins take on their selected operations (input, output, or bidirectional) and the device registers take on their pre-selected initial values.

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

System-Level Design Issues

System-Level Design Issues

The normal operating mode of a system or a device in the system is known as mission mode which is different from test mode. When operating a device in Boundary-Scan test mode (such as when using either INTEST or EXTEST) as well as when performing ISP operations, the device is effectively disconnected from the overall system. When the operation is completed, the device is re-connected to the system. This can sometimes result in unpredictable system behavior. Additional discussion regarding this problem can be found in [Ref 3]. Fortunately, the XC9500 family supplies two proprietary Boundary-Scan instructions that serve to alleviate this problem.

XC9500 Mission Mode Exit and Re-Entry Techniques


The XC9500 devices support two Boundary-Scan instructions that can be used to help alleviate the problems associated with exiting and re-entering mission mode. The instructions are ISPEN (ISP enable) and ISPEX (ISP exit). ISPEN The ISPEN instruction is used at the beginning of every block of ISP operations attempting to access for alteration or read the device internal program memory (such as program, erase, verify, etc.). When the device is in ISPEN mode, the device I/O pins immediately enter a state in which they are floating with a weak pull-up resistor enabled on each pin. The device pins therefore neither drive nor sense external signal levels. ISPEX The ISPEX instruction is used to conclude every block of ISP operations that have either been read from or written to the device internal program memory. As long as the ISPEX instruction remains in the instruction register the functional pins remain in their lightly pulled-up high-impedance state. After the ISPEX instruction is replaced with any other Boundary-Scan instruction (except ISPEN), the device returns to its initial power state with the pins configured to their programmed states (input, output, or bidirectional) and with the device flip-flops taking on their initial states.

The ISPEX operation takes approximately 100 s to complete. If the ISPEX instruction is held in the instruction register for longer than 100 s, the ISPEX operation does not take effect until the ISPEX instruction is displaced from the instruction register. In order to ensure safe operation, all INTEST, EXTEST, and ISP operations involving the XC9500 parts should be bracketed by ISPEN and ISPEX instructions. The designer must also be careful to select an initial condition that is system-safe so that when the ISPEX instruction is released, the XC9500 part in question safely resumes operation with the rest of the system.

Basic Boundary-Scan Design Guidelines


The following guidelines help ensure a successful design. Make certain that all parts in the Boundary-Scan chain have 1149.1 compatible test access ports. Use clock buffering techniques for TCK/TMS signals, to ensure signal integrity and to simplify test considerations for the Boundary-Scan TAP. If buffers are used, ensure input termination is present on the buffers such that the TCK/TMS signals are held at fixed logic levels when no cable is connected. Do not invert TCK or TMS pathways, to guarantee complete test software compatibility. Group similar device families, and have a single level converter interface between them, for TCK, TMS, TDI, TDO, and system pins. Check that the mission logic is safe from any possible errors that might arise while the Boundary-Scan data is being shifted through the Boundary-Scan chain. For example, pay close attention to bus enable or chip select signals that might be enabled simultaneously, causing unexpected bus contention.

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

Conclusion Provide the capability for the ATE to disable conventional (non Boundary-Scan) ICs whose run-time node values might introduce conflicts with Boundary-Scan logic values during test operations.

Verify that the entire system is held in a benign state during Boundary-Scan test operations. Verify that the set-up and hold times of TDI and TMS with respect to TCK are met by the system.

Debugging Boundary-Scan Systems


The following guidelines and helpful information help isolate potential problems. The iMPACT Initialize Chain operation automatically identifies devices within the Boundary-Scan chain. Devices are identified beginning with the last device in the chain because the IDCODE of the last device is the first to appear on the final TDO output.

If the Initialize Chain operation does not identify any devices, then check for proper power to the devices in the Boundary-Scan chain, check the TCK and TMS signals for opens or shorts, and check the final TDO signal path for an open or short. If a fewer than expected number of devices are identified, then check for an open or short on the TDI pin of the first device shown in the iMPACT Boundary-Scan view. The first device in the Boundary-Scan view is the last device for which iMPACT received an IDCODE. A breach in the serial signal path preceding the device prevents iMPACT from identifying further devices.

The iMPACT Debug menu contains several items that help debug Boundary-Scan issues. The Chain Integrity Testing and IDCODE Looping functions in the Debug menu can help identify signal integrity issues in the Boundary-Scan chain. When traversing the IR states, the CAPTURE-IR value specified in the BSDL file is always shifted out on TDO at SHIFT-IR. This fact can be used to test Boundary-Scan chain continuity. After exit from Test-Logic-Reset, if the system transitions directly to Shift-DR, the values shifted out on TDO must be either the IDCODE (if implemented) or the BYPASS register contents. If all logic 0s are shifted in at TDI, then the first incidence of a logic 1 on TDO represents the first bit of an IDCODE. This fact can be used for blind interrogation of the Boundary-Scan chain and for further Boundary-Scan chain continuity checks. When entering ISP mode via the ISPEN instruction, all XC9500 function pins float to a weakly pulled-up high-impedance state. The pins can easily be tested for this behavior. When ISPEX is shifted out of the instruction register, the XC9500 devices should take on their programmed values with the functional pins acting immediately as inputs or outputs, as programmed. The pins can easily be tested for this behavior. TDO assumes its defined value at the falling edge of TCK. When not in SHIFT-IR or SHIFT-DR, TDO exhibits high-impedance. The last valid TDI bit clocks into the TAP with TMS High. In BYPASS mode, TDO equals the applied TDI data one TCK pulse earlier.

Conclusion

When designing ISP systems, common-sense rules related to electronic system design and board layout should be adhered to. In order to benefit from the synergies associated with the integration of test and programming operations, the designer must consciously design with the entire system life cycle in mind.

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

References

References

1. IEEE 1149.1-199,0 Standard Test Access Port and Boundary-Scan Architecture. 2. Colin Maunder and Rod Tulloss, The Test Access Port and Boundary-Scan Architecture, ISBN: 0-8186-9070-4. 3. Kenneth P. Parker, The Boundary-Scan Handbook, ISBN: 0-7923-9270-1. 4. Harry Bleeker et al., Boundary-Scan Test - A Practical Approach, ISBN: 0-792-9296-5. 5. Hideo Fujiwara, Logic Testing and Design for Testability, ISBN: 0-262-06096-5. 6. M. Montrose, Printed Circuit Board Design Techniques, ISBN: 0780311310.

Revision History

The following table shows the revision history for this document.
Date 07/01/97 05/22/02 02/19/07 Version 1.0 2.0 2.1 Xilinx initial release. Revised release. Updated format. Removed references to the discontinued MultiLINX cable. Corrected connection in Figure 4, page 4. Basic Boundary-Scan Design Guidelines, page 6 updated. Revision

11/15/07

2.1.1

Updated URLs. Updated template.

Notice of Disclaimer

Xilinx is disclosing this Application Note to you AS-IS with no warranty of any kind. This Application Note is one possible implementation of this feature, application, or standard, and is subject to change without further notice from Xilinx. You are responsible for obtaining any rights you may require in connection with your use or implementation of this Application Note. XILINX MAKES NO REPRESENTATIONS OR WARRANTIES, WHETHER EXPRESS OR IMPLIED, STATUTORY OR OTHERWISE, INCLUDING, WITHOUT LIMITATION, IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT, OR FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL XILINX BE LIABLE FOR ANY LOSS OF DATA, LOST PROFITS, OR FOR ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, OR INDIRECT DAMAGES ARISING FROM YOUR USE OF THIS APPLICATION NOTE.

XAPP070 (v2.1.1) November 15, 2007

www.xilinx.com

You might also like