

# Understanding the CoolRunner-II Timing Model

## Summary

This document describes the CoolRunner<sup>™</sup>-II timing model. Understanding the CoolRunner-II timing model is essential to creating a CPLD design that meets the desired timing requirements.

## Introduction

CPLD designers often require an understanding of the device timing model to compare design specific timing requirements. CPLD designers can use the CoolRunner-II timing model to create a design that fits required timing requirements and compare design critical paths. Designers can use the timing model to create equations of time delays for each logic path in a design. This document will describe the CoolRunner-II timing model in detail and provide examples for using this timing model.

A brief overview of the CoolRunner-II architecture as it pertains to the timing model will be described in the following section.

## CoolRunner-II Architecture

The CoolRunner-II architecture consists of function blocks that are interconnected by a routing matrix called the Advanced Interconnect Matrix (AIM). Each function block contains a Programmable Logic Array (PLA) and 16 macrocells. A total of eight global signals are multiplexed with eight I/O pins and include three clocks, four output enables, and one set/reset signal. The CoolRunner-II architecture allows these global signals to be driven by internal logic. Figure 1 illustrates a block diagram of the CoolRunner-II architecture.



Figure 1: CoolRunner-II Architecture

© 2003 Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, patents, and further disclaimers are as listed at <a href="http://www.xilinx.com/legal.htm">http://www.xilinx.com/legal.htm</a>. All other trademarks and registered trademarks are the property of their respective owners. All specifications are subject to change without notice.

NOTICE OF DISCLAIMER: Xilinx is providing this design, code, or information "as is." By providing the design, code, or information as one possible implementation of this feature, application, or standard, Xilinx makes no representation that this implementation is free from any claims of infringement. You are responsible for obtaining any rights you may require for your implementation. Xilinx expressly disclaims any warranty whatsoever with respect to the adequacy of the implementation, including but not limited to any warranties or representations that this implementation is free from claims of infringement and any implied warranties of merchantability or fitness for a particular purpose. The function block product term and sum term array is a pure PLA (programmable AND array, programmable OR array). Each PLA has 40 inputs from the AIM (true and complement) and contains 56 unique product terms. Product terms can be used as macrocell clocks, control terms (reset, preset, asychronous clock, clock enable, or output enable), or as needed as logic by the macrocells in the function block.

Of the function block product terms, four are available as control terms. The control terms, CTC, CTR, CTS, and CTE, can be a macrocell clock, reset, preset, or output enable. In addition to these function block control terms, each macrocell has three dedicated product terms available as additional control terms, local to that macrocell. PTA can be used as the macrocell reset or preset, PTB for the macrocell output enable, and PTC for the clock enable or product term clock. Note that if these product terms are not needed as control terms, they are available for other logic. Figure 2 illustrates the CoolRunner-II macrocell.



## Timing Model

#### Overview

External signals enter at the pins and are delivered through the I/O block to the AIM. From the AIM, they are dispatched to the various function blocks (FBs). As the signals enter the FBs, they incur incremental time delays depending on how the signals are used within the FB. For example, all logic signals must pass through the AND array where product terms are created and a time delay is incurred as the signal progresses. The number of product terms in a logic equation will impact the time delay encountered on the signal. With the CoolRunner-II architecture, each macrocell has a fast path that contains one product term, PTC (see Figure 2), in a logic equation. With this path, the OR term is bypassed and fed directly into the macrocell register. Logic equations with two or more product terms must enter the OR term and will therefore encounter an additional time delay.

There are additional timing requirements such as setup and clock-to-output times involved when passing signals through a flip-flop. The macrocell output is either directed to the I/O block and pin, or are fed back into the AIM switch matrix for additional logic operations.

Design timing can be manually analyzed as separate signals, each having unique timing parameters that are easily calculated. However, the Xilinx development tools provide a detailed timing report that tallies and summarizes all paths specified by the designer. The timing report is based on the model described here and is a convenient text based mechanism for isolating and displaying timing relationships.

#### Description

The timing model, shown in Figure 3, is used by the Xilinx development software which provides complete fitting for the CoolRunner-II family as well as timing models for simulation and detailed static timing reports.



Figure 3: CoolRunner-II Timing Model

The timing model shown in Figure 3 represents the CoolRunner-II macrocell with additional time delays included to account for the AIM switch matrix and I/O buffers. As signals progress through a CoolRunner-II device, they encounter some of these delays which are tallied to arrive at a cumulative time delay for that signal. Table 1 provides a detailed definition of each parameter contained in Figure 3. The exact values for each device can be obtained from the specific data sheets.

| Parameter           | Description                                               |  |
|---------------------|-----------------------------------------------------------|--|
| Buffer Delays       |                                                           |  |
| T <sub>IN</sub>     | Input buffer delay (see Table 2)                          |  |
| T <sub>DIN</sub>    | Direct input buffer delay (input registers) (see Table 2) |  |
| Т <sub>GCK</sub>    | Global clock buffer delay (see Table 2)                   |  |
| T <sub>GSR</sub>    | Global set/reset buffer delay (see Table 2)               |  |
| T <sub>GTS</sub>    | Global tristate buffer delay (see Table 2)                |  |
| T <sub>OUT</sub>    | Output buffer delay (see Table 2)                         |  |
| T <sub>EN</sub>     | Output buffer enable/disable delay                        |  |
| Product Term Delays |                                                           |  |
| T <sub>CT</sub>     | Control term delay (single P-term or FB control term)     |  |

| Parameter                                  | Description                                  |  |  |
|--------------------------------------------|----------------------------------------------|--|--|
| T <sub>LOGI1</sub>                         | Internal logic delay (single P-term)         |  |  |
| T <sub>LOGI2</sub>                         | Multiple P-term delay adder                  |  |  |
| Internal Register and Combinatorial Delays |                                              |  |  |
| T <sub>PDI</sub>                           | Macrocell input to output valid              |  |  |
| T <sub>SUI</sub>                           | Macrocell register setup time                |  |  |
| T <sub>HI</sub>                            | Macrocell register hold time                 |  |  |
| T <sub>ECSU</sub>                          | Macrocell register clock enable setup time   |  |  |
| T <sub>ECHO</sub>                          | Macrocell register clock enable hold time    |  |  |
| T <sub>COI</sub>                           | Macrocell register clock to output delay     |  |  |
| T <sub>AOI</sub>                           | Macrocell register set/reset to output delay |  |  |
| Feedback Delays                            |                                              |  |  |
| T <sub>F</sub>                             | AIM delay                                    |  |  |
| T <sub>OEM</sub>                           | Macrocell to global output enable delay      |  |  |
| Time Delays                                |                                              |  |  |
| T <sub>HYS</sub>                           | Hysteresis time delay (see Table 2)          |  |  |
| T <sub>SLEW</sub>                          | Slew rate limited delay (see Table 2)        |  |  |

#### Table 1: CoolRunner-II Internal Timing Parameters (Continued)

Table 2 illustrates various timing parameters associated with the available I/O standards on CoolRunner-II devices. Note that the SSTL and HSTL standards are only available on 128 macrocell and larger CoolRunner-II CPLDs. Values for the parameters shown in Table 2 are available in the specific product data sheet. Note that values shown in Table 2 are timing delay adders.

| Table | 2: | I/O | Standard | Related | Timing | Parameters |
|-------|----|-----|----------|---------|--------|------------|
|-------|----|-----|----------|---------|--------|------------|

| Parameter           | Description                                                                                                            |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------|--|
| 1.5V I/O            |                                                                                                                        |  |
| T <sub>IN15</sub>   | Input buffer adder for $\rm T_{IN}, T_{DIN}, T_{GCK}, T_{GSR},$ and $\rm T_{GTS}$                                      |  |
| T <sub>HYS15</sub>  | Input hysteresis input adder for $T_{IN},T_{FIN},T_{GCK},T_{GSR},\text{and}T_{GTS}$                                    |  |
| T <sub>OUT15</sub>  | Output delay adder                                                                                                     |  |
| T <sub>SLEW15</sub> | Output slew adder                                                                                                      |  |
| 1.8V LVCMOS         |                                                                                                                        |  |
| T <sub>IN18</sub>   | Input buffer adder for $T_{IN},T_{DIN},T_{GCK},T_{GSR},andT_{GTS}$                                                     |  |
| T <sub>HYS18</sub>  | Input hysteresis input adder for $T_{\text{IN}},T_{\text{FIN}},T_{\text{GCK}},T_{\text{GSR}},\text{and}T_{\text{GTS}}$ |  |
| T <sub>OUT18</sub>  | Output delay adder                                                                                                     |  |
| T <sub>SLEW18</sub> | Output slew adder                                                                                                      |  |
| 2.5V LVCMOS         |                                                                                                                        |  |
| T <sub>IN25</sub>   | Input buffer adder for $\rm T_{IN}, T_{DIN}, T_{GCK}, T_{GSR},$ and $\rm T_{GTS}$                                      |  |
| T <sub>HYS25</sub>  | Input hysteresis input adder for $T_{IN},T_{FIN},T_{GCK},T_{GSR},\text{and}T_{GTS}$                                    |  |
| T <sub>OUT25</sub>  | Output delay adder                                                                                                     |  |

**WWW.BDT** -800<sup>-</sup>255<sup>-</sup>7778 /XILINX<sup>APP375</sup> (v1.5) February 28, 2003

| Parameter           | Description                                                                                   |  |  |
|---------------------|-----------------------------------------------------------------------------------------------|--|--|
| T <sub>SLEW25</sub> | Output slew adder                                                                             |  |  |
| 3.3V LVTTL/LVC      | 3.3V LVTTL/LVCMOS                                                                             |  |  |
| T <sub>IN33</sub>   | Input buffer adder for $T_{IN}$ , $T_{DIN}$ , $T_{GCK}$ , $T_{GSR}$ , and $T_{GTS}$           |  |  |
| T <sub>HYS33</sub>  | Input hysteresis input adder for $T_{IN}$ , $T_{FIN}$ , $T_{GCK}$ , $T_{GSR}$ , and $T_{GTS}$ |  |  |
| T <sub>OUT33</sub>  | Output delay adder                                                                            |  |  |
| T <sub>SLEW33</sub> | Output slew adder                                                                             |  |  |
| SSTL2-I             |                                                                                               |  |  |
| T <sub>INSS2</sub>  | Input buffer adder for $T_{IN}$ , $T_{DIN}$ , $T_{GCK}$ , $T_{GSR}$ , and $T_{GTS}$           |  |  |
| T <sub>OUTSS2</sub> | Output delay adder                                                                            |  |  |
| SSTL3-I             |                                                                                               |  |  |
| T <sub>INSS3</sub>  | Input buffer adder for $T_{IN}$ , $T_{DIN}$ , $T_{GCK}$ , $T_{GSR}$ , and $T_{GTS}$           |  |  |
| T <sub>OUTSS3</sub> | Output delay adder                                                                            |  |  |
| HSTL-I              |                                                                                               |  |  |
| T <sub>INHS1</sub>  | Input buffer adder for $T_{IN}$ , $T_{DIN}$ , $T_{GCK}$ , $T_{GSR}$ , and $T_{GTS}$           |  |  |
| T <sub>OUTHS1</sub> | Output delay adder                                                                            |  |  |

#### Table 2: I/O Standard Related Timing Parameters (Continued)

## **External Timing Parameters**

Table 3 shows how key external timing parameters are derived from the internal timing parameters.

| Parameter            | Description                                    | Equation                                                                   |
|----------------------|------------------------------------------------|----------------------------------------------------------------------------|
| T <sub>PD1</sub>     | Propagation delay time (single P-term)         | T <sub>IN</sub> + T <sub>LOGI1</sub> + T <sub>PDI</sub> + T <sub>OUT</sub> |
| T <sub>PD2</sub>     | Propagation delay time (OR array)              | $T_{IN} + T_{LOGI1} + T_{LOGI2} + T_{PDI} + T_{OUT}$                       |
| T <sub>SUD</sub>     | Direct input register setup time               | T <sub>DIN</sub> + T <sub>SUI</sub> – T <sub>GCK</sub>                     |
| T <sub>SU1</sub>     | Setup time (single P-term)                     | T <sub>IN</sub> + T <sub>LOGI1</sub> + T <sub>SUI</sub> – T <sub>GCK</sub> |
| T <sub>SU2</sub>     | Setup time (OR array)                          | $T_{IN} + T_{LOGI1} + T_{LOGI2} + T_{SUI} - T_{GCK}$                       |
| T <sub>HD</sub>      | Direct input register hold time                | $T_{GCK} + T_{HI} - T_{DIN}^{(1)}$                                         |
| Т <sub>Н</sub>       | Hold time                                      | $T_{GCK} + T_{HI} - T_{IN} - T_{LOGI1}^{(1)}$                              |
| т <sub>со</sub>      | Clock to output (global synchronous clock pin) | T <sub>GCK</sub> + T <sub>COI</sub> + T <sub>OUT</sub>                     |
| T <sub>CYCLE1</sub>  | Minimum clock period (single P-term)           | T <sub>COI</sub> + T <sub>F</sub> + T <sub>LOGI1</sub> + T <sub>SUI</sub>  |
| T <sub>CYCLE2</sub>  | Minimum clock period (OR array)                | $T_{COI} + T_F + T_{LOGI1} + T_{LOGI2} + T_{SUI}$                          |
| f <sub>SYSTEM1</sub> | Maximum system frequency (single P-term)       | 1/T <sub>CYCLE1</sub>                                                      |
| f <sub>SYSTEM2</sub> | Maximum system frequency (OR array)            | 1/T <sub>CYCLE2</sub>                                                      |
| f <sub>EXT1</sub>    | Maximum external frequency (single P-term)     | 1/(T <sub>SU1</sub> + T <sub>CO</sub> )                                    |
| f <sub>EXT2</sub>    | Maximum external frequency (OR array)          | 1/(T <sub>SU2</sub> + T <sub>CO</sub> )                                    |
| f <sub>TOGGLE</sub>  | Maximum register toggle frequency              | 1/(2 * T <sub>CW</sub> )                                                   |
| T <sub>PSUD</sub>    | Direct input register P-term clock setup time  | $T_{DIN} + T_{SUI} - T_{IN} - T_{CT}$                                      |

| Parameter                          | Description                                              | Equation                                                     |
|------------------------------------|----------------------------------------------------------|--------------------------------------------------------------|
| T <sub>PSU1</sub>                  | P-term clock setup time (single P-term)                  | $T_{IN} + T_{LOGI1} + T_{SUI} - T_{IN} - T_{CT}$             |
| T <sub>PSU2</sub>                  | P-term clock setup time (OR array)                       | $T_{IN} + T_{LOGI1} + T_{LOGI2} + T_{SUI} - T_{IN} - T_{CT}$ |
| T <sub>PHD</sub>                   | Direct input register P-term clock hold time             | $T_{IN} + T_{CT} + T_{HI} - T_{DIN} + skew$                  |
| T <sub>PH</sub>                    | P-term clock hold                                        | $T_{IN} + T_{CT} + T_{HI} - T_{IN} - T_{LOGI1}^{(1)}$        |
| T <sub>PCO</sub>                   | P-term clock to output                                   | $T_{IN} + T_{CT} + T_{COI} + T_{OUT}$                        |
| T <sub>OE</sub> /T <sub>OD</sub>   | Global OE to output enabled/disabled                     | T <sub>GTS</sub> + T <sub>EN</sub>                           |
| T <sub>POE</sub> /T <sub>POD</sub> | P-term OE to output enabled/disabled                     | $T_{IN} + T_{CT} + T_{EN}$                                   |
| T <sub>MOE</sub> /T <sub>MOD</sub> | Macrocell driven OE to output enabled/disabled           | $T_{GCK} + T_{COI} + T_{OEM} + T_{EN}$                       |
| T <sub>PAO</sub>                   | P-term set/reset to output set/reset                     | $T_{IN} + T_{CT} + T_{AOI} + T_{OUT}$                        |
| T <sub>AO</sub>                    | Global set/reset to output set/reset                     | T <sub>GSR</sub> + T <sub>AOI</sub> + T <sub>OUT</sub>       |
| T <sub>SUEC</sub>                  | Register clock enable setup time                         | $T_{IN} + T_{CT} + T_{ECSU} - T_{GCK}$                       |
| T <sub>HEC</sub>                   | Register clock enable hold time                          | $T_{GCK} + T_{ECHO} - T_{IN} - T_{CT}$                       |
| T <sub>CW</sub>                    | Global clock pulse width (high or low)                   | Please see product data sheet                                |
| T <sub>PCW</sub>                   | P-term clock pulse width (high or low)                   | Please see product data sheet                                |
| T <sub>DGSU</sub>                  | Input setup required before DataGate latch assertion     | Please see product data sheet                                |
| T <sub>DGH</sub>                   | Input hold relative to DataGate latch assertion          | Please see product data sheet                                |
| T <sub>DGR</sub>                   | DataGate recovery to new data relative to data input pin | Please see product data sheet                                |
| T <sub>DGW</sub>                   | DataGate high pulse width                                | Please see product data sheet                                |
| T <sub>CDRSU</sub>                 | Setup time of CDRST before negative going GCK2           | Please see product data sheet                                |
| T <sub>CDRH</sub>                  | Hold time of CDRST after negative going GCK2             | Please see product data sheet                                |

#### Table 3: Expressions for External Timing Parameters (Continued)

#### Notes:

1. All CoolRunner-II devices guarantee a zero hold time, even though the equations shown here may create a negative hold time value.

Please note that these times will change if multiple feedback passes (internal nodes) are used.

The following sections provide a few examples of how the device timing is calculated. These calculations are automatically done for the user by software development tools but examples are provided here to help the user better understand how the software calculates device timing. Please note these examples do not cover every possible case.

## Combinatorial Timing Examples

This section provides various combinatorial timing examples. The examples provided here include proprogation delay with a single P-term, multiple P-terms, and multiple levels of logic.

One combinatorial timing example is propagation delay, or  $T_{PD}$ . CoolRunner-II  $T_{PD}$  is seperated into two individual timing parameters,  $T_{PD1}$  and  $T_{PD2}$ .  $T_{PD1}$  is calculated based on a single P-term path in the PLA structure.  $T_{PD2}$  is calculated based on more than one P-term existing in the data path.

### **Single Product Term Propogation Delay**

www.BDT

The CoolRunner-II architecture provides a fast path  $T_{PD}$  with a single product term logic equation. With a single P-term logic equation, the OR term can be bypassed, and the P-term is fed directly in the macrocell using PTC (see Figure 2).

n/XILIN X PP375 (v1.5) February 28, 2003

 $T_{PD1}$  is calculated as the sum of the input buffer time delay ( $T_{IN}$ ), the single P-term logic time delay ( $T_{LOG11}$ ), the bypass path of the macrocell ( $T_{PD1}$ ), and the output buffer time delay ( $T_{OUT}$ ), as shown in Figure 4. Note that the input buffer delay is combined with the AIM time delay since the entering signal passes through the AIM switch matrix.



Figure 4: T<sub>PD1</sub> with a Single Product Term

#### **Multiple Product Term Propogation Delay**

Figure 5 illustrates a variation to the simple  $T_{PD1}$  example with the addition of more product terms. The time delay from input A is slightly altered with  $T_{PD2}$ , which accounts for additional product terms.  $T_{PD2}$  is the same independent of the number of product terms, ranging from 2 to 56.



Figure 5: T<sub>PD2</sub> with 2 to 56 Product Terms

### **Multiple Logic Level Propogation Delay**

If combinational data requires multiple passes of logic,  $T_{PD}$  will increase accordingly. Figure 6 illustrates the case where  $T_{PD}$  is calcuated based on cascaded levels of logic. In this case, there is a single pass through the input buffer, a pass through the function block logic, a pass through the feedback path, an additional pass through the function block logic, and the output buffer.



Figure 6: T<sub>PD</sub> with 2 Levels of Logic

**Note:**  $T_{LOGI^*} = T_{LOGI1}$  if a single P-term is used, and  $T_{LOGI^*} = T_{LOGI1} + T_{LOGI2}$  if 2 to 56 P-terms are used.

Registered Timing Examples

#### **Simple Registered Path**

A simple registered timing example is shown in Figure 7. Figure 7 illustrates a macrocell flipflop with a CoolRunner-II global synchronous clock signal, GCK. The equations for  $T_{SU}$ ,  $T_{CO}$ , and  $T_{H}$  are valid for this arrangement. In this example, the equations for  $T_{SU}$ ,  $T_{CO}$ , and  $T_{H}$  are not for fast input register or any special clocking features, ie. divider or doubler. The equations shown in Figure 7 are closely related to  $T_{SU1}/T_{SU2}$ ,  $T_{CO}$ , and  $T_{H}$  described in Table 3.



XAPP375\_07\_112801

Figure 7: Simple Registered Path

#### **Direct Input Register**

Figure 8 illustrates the CoolRunner-II direct input register architecture feature. Direct input registers allow a designer to capture data from a high speed external bus with minimal  $T_{SU}$ . The equations shown in Figure 8 are closely related to  $T_{SUD}$ ,  $T_{CO}$ , and  $T_{HD}$  described in Table 3.



Figure 8: Direct Input Register Path

### **Product Term Clocking**

Another architectural feature available in CoolRunner-II is product term register clocking. Product terms clocks available in each CoolRunner-II macrocell include, CTC and PTC shown in Figure 2. PTC is dedicated to each macrocell, while CTC is shared among macrocells within

WW.BDT<sup>www.xiliax.com</sup>/XILINX<sup>APP375</sup> (v1.5) February 28, 2003

a function block. Figure 9 illustrates the timing parameters for product term clocking on a single flip-flop. This implementation is similar to Figure 7 except the clock source is now a product/control term. The timing parameters,  $T_{PSU}$ ,  $T_{PCO}$ , and  $T_{PH}$  shown in Figure 9 are closely related to the equations for  $T_{PSU1}/T_{PSU2}$ ,  $T_{PCO}$ , and  $T_{PH}$  described in Table 3.



Figure 9: Product Term Clocking

## **Register Clock Enable**

CoolRunner-II CPLDs provide true clock enables at each flip-flop as shown in Figure 10. Each macrocell has one dedicated clock enable, PTC. The clock enable has both setup ( $T_{SUEC}$ ) and hold ( $T_{HEC}$ ) timing parameters. The  $T_{SUEC}$  and  $T_{HEC}$  equations shown in Figure 10 are closely related to  $T_{SUEC}$  and  $T_{HEC}$  shown in Table 3.



XAPP375\_10\_112801

Figure 10: Clock Enable Timing Parameters

### **Registered Logic with Multiple Levels**

Figure 11 illustrates multiple levels of logic clocked by the global clock, GCK. The calculation for maximum system frequency is shown in Figure 11. Maximum system frequency is determined by the time delay of one flip-flop output to the next flip-flip input. As shown in

Figure 11,  $f_{SYSTEM}$  is determined by the first flip-flop output,  $T_{CO}$ , the AIM feedback delay,  $T_{F}$ , the delay through the PLA,  $T_{LOGI^*}$ , and the register setup time,  $T_{SUI}$ .



Figure 11: Multiple Logic Levels

I/O Related Timing Examples

### **Global Output Enable**

Output enable timing can be calculated for both the CoolRunner-II global output enable, GTS and product term driven OE control. The timing delay from the CoolRunner-II global output enable, GTS to enabling or disabling the output is shown in Figure 12.



Figure 12: Global Output Enable Timing

#### **Product Term Output Enable**

For product output enable control, each macrocell has one dedicated OE and one function block OE control shown in Figure 2. The timing parameters when using one of these product term driven output enables is shown in Figure 13.



Figure 13: Product Term Output Enable Timing

#### Macrocell Driven Output Enable

The CoolRunner-II architecture also allows a macrocell to drive the global output enable. The macrocell output can be routed to one of the four available global output enables, GTS[3:0]. Figure 14 illustrates this case and the associated  $T_{MOE}/T_{MOD}$  timing parameters. Note the lower function block drawing is for the data output.



Figure 14: Macrocell Driven Ouput Enable Timing

### I/O Standard Timing

Figure 15 illustrates a registered timing example using multiple I/O standards. This example utilizes 3.3V LVCMOS tolerant inputs and drives 1.8V LVCMOS outputs. Note the addition of the 3.3V LVCMOS timing delay,  $T_{IN33}$  on both the data and GCK inputs. Also note the addition

of the 1.8V LVCMOS output delay adder,  $T_{OUT18}$ . The associated  $T_{SU}$ ,  $T_{CO}$  and  $T_{H}$  timing parameters are shown in Figure 15.





## DataGate Characteristics

For more information on using DataGate in CoolRunner-II devices, refer to the family data sheet found on <u>http://www.xilinx.com</u>.

Figure 16 illustrates the timing requirements when using DataGate. A description of each timing parameter can be found in Table 3, page 5. The timing parameter,  $T_{DGR}$ , is referred to as the DataGate latch recovery time.  $T_{DGR}$  represents the recovery time of the DataGate latch output with respect to the DataGate enable input, DGE. The delay,  $T_{PD}^*$ , shown in Figure 16 illustrates the delay incurred from the DataGate latch output to the pin output data.



#### Figure 16: DataGate Timing Requirements

## Clock Divider Reset Characteristics

The clock divider reset signal, CDRST, is available for use with the global clock divider in CoolRunner-II devices. The CDRST is an active high reset signal for the clock divider circuit on GCK2. The CDRST signal is asserted low (disable reset condition) and is recognized by the clock divider on the next falling edge of the incoming clock, GCK2. Once this condition is met, the output of the clock divider will toggle at the specified frequency.

Figure 17 illustrates the setup and hold time requirements with using the clock divider reset, CDRST, on CoolRunner-II devices.



to Table 3, page 5. Renamed  $T_{FIN}$  to  $T_{DIN}$ . Renamed  $T_{SUF}$  to  $T_{SUD}$ . Renamed  $T_{HF}$  to  $T_{HD}$ . Renamed  $T_{PSUF}$  to  $T_{PSUD}$ . Renamed  $T_{PHF}$  to

Updated Figure 16 T<sub>DGW</sub> specification.

Removed timing parameters T<sub>CDIV</sub> and T<sub>RAI</sub>.

1.4

1.5

02/11/03

2/28/03

T<sub>PHD</sub>.