

# Tsi108™/Tsi109™ Debug Checklist

80B5000\_AN006\_02

October 29, 2009

6024 Silver Creek Valley Road San Jose, California 95138 Telephone: (408) 284-8200 • FAX: (408) 284-3572 Printed in U.S.A. ©2009 Integrated Device Technology, Inc.

GENERAL DISCLAIMER Integrated Device Technology, Inc. ("IDT") reserves the right to make changes to its products or specifications at any time, without notice, in order to improve design or performance. IDT does not assume responsibility for use of any circuitry described herein other than the circuitry embodied in an IDT product. Disclosure of the information herein does not convey a license or any other right, by implication or otherwise, in any patent, trademark, or other intellectual property right of IDT. IDT products may contain errata which can affect product performance to a minor or immaterial degree. Current characterized errata will be made available upon request. Items identified herein as "reserved" or "undefined" are reserved for future definition. IDT does not assume responsibility for conflicts or incompatibilities arising from the future definition of such items. IDT products have not been designed, tested, or manufactured for use in, and thus are not warranted for, applications where the failure, malfunction, or any inaccuracy in the application carries a risk of death, serious bodily injury, or damage to tangible property. Code examples provided herein by IDT are for illustrative purposes only and should not be relied upon for developing applications. Any use of such code examples shall be at the user's sole risk.

Copyright  $^{\odot}$  2009 Integrated Device Technology, Inc. All Rights Reserved.

The IDT logo is registered to Integrated Device Technology, Inc. IDT is a trademark of Integrated Device Technology, Inc.

## **About this Document**

This document describes some of the common issues that may be encountered when debugging boards configured with the Tsi108 or Tsi109. The following issues are discussed:

- "Voltages/Sequencing" on page 3
- "Clocks" on page 3
- "Reset" on page 4
- "Other Issues" on page 5

#### 1. Voltages/Sequencing

Check the input voltages to the Tsi108/Tsi109 to ensure the Core and I/O voltages are at the proper levels (for more information, see the *Tsi108/Tsi109 User Manual*.

Verify correct power-up sequencing. The Tsi108/Tsi109 has strict voltage sequencing requirements that must be followed (for more information, see the *Tsi108/Tsi109 Hardware Manual*).

### 2. Clocks

The Tsi108/Tsi109 contains an integrated Clock Generator that allows it to generate independent clocks for the Processor Interface, Memory Controller, PCI/X Interface, and internal logic. These clocks are all generated from a single reference clock input, CG\_REF.

#### 2.1 Quality of the Clocks

The various output clocks provided by the Tsi108/Tsi109 are derived from a 33-MHz reference clock input, CG\_REF. The design contains various PLLs and dividers that allow the Tsi108/Tsi109 to supply the output clocks at the required frequencies. Since all clocks are derived from the single reference clock input, it is extremely important that CG\_REF originate from a clean source. For this reason, make sure the 1.8V output of the crystal oscillator is a clean 33-MHz output.

Once the quality of the input clock is successfully verified, the individual Tsi108/Tsi109 output clocks should be checked to verify proper frequency. The values placed on the Tsi108/Tsi109 CG\_PB\_SELECT[2:0] and CG\_SD\_SELECT[2:0] determine the Processor bus and Memory bus output clock frequencies, and whether or not the Processor Interface and Memory Controller run synchronously or asynchronously. CG\_PB\_SELECT[2:0] and CG\_SD\_SELECT[2:0] and CG\_SD\_SELECT[2:0] and must be terminated correctly for the application.

The PCI/X output clock frequencies are determined by the values placed on Tsi108/Tsi109 PCIX\_CAP[1:0] inputs at power-up when the Tsi108/Tsi109 is being used as the PCI/X host. The Tsi108/Tsi109 Clock Generator should not be used when the Tsi108/Tsi109 is configured as an agent on the PCI/X bus (that is, PCI\_RSTn is configured as an input). In this case the PCI/X clock input to the Tsi108/Tsi109, PCI\_CLK, must be clean and match what is driven on the PCI/X initialization pattern at power-up.

#### 3. Reset

The Tsi108/Tsi109 implements various reset inputs as well as outputs. The application will dictate how the Tsi108/Tsi109 is reset as well as the other devices in the system. The majority of Tsi108/Tsi109 applications use the bridge as the system host where the Tsi108/Tsi109 gets its reset input, OCN\_RSTn, and drives the various resets to the Processor and PCI/X agents. (For more information on Tsi108/Tsi109 resets, see the *Tsi108/Tsi109 User Manual*.)

The following items should be checked at power-up:

- Reference Clock input, CG\_REF, must be valid and stable before reset is released even if the Clock Generator is not being used to generate the various output clocks since this input provides the internal Switch Fabric clock to the Tsi108/Tsi109.
- For designs that do not use the Tsi108/Tsi109 Clock Generator to provide clocks to the various interfaces, the SD\_SYSCLK, PB\_SYSCLK, and PCI\_CLK inputs must be running and stable before reset is released.
- Power-up options are latched at the negation of reset. Make sure the proper values are being latched at power-up. The status of these power-up straps can be determined by reading the CG\_PWRUP\_STATUS register.

The Tsi108/Tsi109 clock outputs stop during a reset when the Tsi108/Tsi109 Clock Generator provides the system clocks. The Tsi108 differs from the Tsi109 regarding the output clocks. The Tsi108 keeps the output clocks running for up to 300 cycles upon the assertion of reset, while the Tsi109 stops the output clocks immediately upon sensing a reset assertion. For designs that use an FPGA to control the resets, ensure it has a valid clock.

#### 4. Other Issues

This section discusses various issues that were observed when bringing up a Tsi108/Tsi109 board in our lab or in customers' labs.

#### 4.1 Incorrect Power-up Configuration Latched

When using weak pull-up resistors (10K) on the Tsi108/Tsi109 Power-up Configuration signals it is possible to latch an incorrect value when the reset is not held long enough (that is, released immediately). To prevent this problem, ensure the Tsi108/Tsi109 receives its reset input asserted long enough for the power-up strap to register a high. IDT recommends using 4.7K pull-ups on these power-up straps.

#### 4.2 Processor Boot Vector Select

The Tsi108 maps the Processor BOOT vector  $(0x0\_FFF0\_0100)$  to Tsi108 HLP address  $0x0\_0000\_0100$ . Designers that are familiar with the Tsi107 expect the Processor BOOT vector to be mapped to HLP address  $0x0\_0FF0\_0100$ . Make sure Flash exists at  $0x0\_0000\_0100$  when using the Tsi108 unless an EEPROM is implemented to adjust the default HLP BOOT address.

The Tsi109 introduces a new power-up configuration strap to make the HLP address mapping selectable.

#### 4.3 Random Reads to PB\_OCN\_SYNC\_GEN and PFAB\_SYNC\_BAR

The Tsi108/Tsi109 Switch Fabric uses a synchronization method called SYNC packets to flush its buffers between selected Switch Fabric ports (for example, between the Processor and PCI/X Interfaces). A read from either the PB\_OCN\_SYNC\_GEN register or the PFAB\_SYNC\_BAR register will generate a SYNC request packet. The priority of a SYNC request packet is set such that it is not allowed to pass either write or completion packets in any queue. The SYNC packet can be used to determine if the path from one Tsi108/Tsi109 port to another is clean, such that there are no write or completion packets within the internal buffers.

The consequences of reading PB\_OCN\_SYNC\_GEN or PFAB\_SYNC\_BAR with invalid destination ports are a possible device lock up. Having the destination ports set to any value other than those specified in the PB\_OCN\_SYNC\_DATA register or the PFAB\_SYNC\_BAR register may cause the Tsi108/Tsi109 internal buffers to lock out and not accept any transactions. Since the reset value of the registers that determine valid SYNC packet destination ports are reset to zero, any random read to the PB\_OCN\_SYNC\_GEN or PFAB\_SYNC\_BAR is not recommended (or more information on these registers, see the *Tsi108/Tsi109 User Manual*).

#### 4.4 HLP Data Swap Control

The Tsi108/Tsi109 HLP Interface can swap data from the device connected to it before returning the read data to the Switch Fabric, or before writing Switch Fabric data to the device. The data swap feature is controlled by HLP\_DATA\_SWAP\_CTRL[DATA\_SWAP] while the PWRUP\_HLP\_BSWP pin controls the reset value of the DATA\_SWAP bit.

The data swapping feature should be used with care because it can produce unpredictable results if any of the data on a Switch Fabric datum is invalid. When using the data swap feature, all address and data must be 64-bit (8-byte) aligned.



*CORPORATE HEADQUARTERS* 6024 Silver Creek Valley Road San Jose, CA 95138 *for SALES:* 800-345-7015 or 408-284-8200 fax: 408-284-2775 www.idt.com

for Tech Support: email: EHBhelp@idt.com phone: 408-360-1538 document: 80B5000\_AN006\_02

October 29, 2009