

# ispPAC<sup>-</sup>POWR604

In-System Programmable Power Supply Sequencing Controller and Monitor

Data Sheet DS1032

#### August 2004

### **Features**

- Monitor and Control Multiple Power Supplies
  - Simultaneously monitors and sequences up to six power supplies
  - Sequence controller for power-up conditions
  - Provides four output control signals
  - · Programmable digital and analog circuitry

### Embedded PLD for Sequence Control

- Implements state machine and input conditional events
- In-System Programmable (ISP<sup>™</sup>) through JTAG and on-chip E<sup>2</sup>CMOS<sup>®</sup>

#### Embedded Programmable Timers

- Two Programmable 8-bit timers (32µs to 524ms)
- Programmable time delay for pulse stretching or other power supply management

#### Analog Comparators for Monitoring

- Six analog comparators for monitoring
  192 precise programmable threshold levels
- spanning 1.03V to 5.72VEach comparator can be independently config-
- ured around standard logic supply voltages of 1.2V, 1.5V, 1.8V, 2.5V, 3.3V, 5V
- Other user-defined voltages possible
- Six direct comparator outputs

### Embedded Oscillator

- Built-in clock generator, 250kHz
- Programmable clock frequency
- Programmable timer pre-scaler
- External clock support

### Programmable Open-Drain Outputs

- Four digital outputs for logic and power supply control
- Expandable with ispMACH<sup>™</sup> 4000 CPLD

#### 2.25V to 5.5V Supply Range

- In-system programmable at 3.0V to 5.5V
- Industrial temperature range: -40°C to +85°C
- Automotive temperature range: -40°C to +125°C
- 44-pin TQFP package
- Lead-free package option

# Application Block Diagram



# Description

The Lattice ispPAC®-POWR604 incorporates both insystem programmable logic and in-system programmable analog circuits to perform special functions for power supply sequencing and monitoring. The ispPAC-POWR604 device has the capability to be configured through software to control up to four outputs for power supply sequencing and six comparators monitoring supply voltage limits, along with four digital inputs for interfacing to other control circuits or digital logic. Once configured, the design is downloaded into the device through a standard JTAG interface. The circuit configuration and routing are stored in non-volatile E<sup>2</sup>CMOS. PAC-Designer,® an easy-to-use Windows-compatible software package, gives users the ability to design the logic and sequences that control the power supplies or regulator circuits. The user has control over timing functions, programmable logic functions and comparator threshold values as well as I/O configurations.

© 2004 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal. All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

www.latticesemi.com

# Power Supply Sequence Controller and Monitor

The ispPAC-POWR604 device is specifically designed as a fully-programmable power supply sequencing controller and monitor for managing up to four separate power supplies, as well as monitoring up to six analog inputs or supplies. The ispPAC-POWR604 device contains an internal PLD that is programmable by the user to implement digital logic functions and control state machines. The internal PLD connects to two programmable timers, special purpose I/O and the programmable monitoring circuit blocks. The internal PLD and timers can be clocked by either an internal programmable clock oscillator or an external clock source.

The voltage monitors are arranged as six independent comparators each with 192 programmable trip point settings. Monitoring levels are set around the following standard voltages: 1.2V, 1.5V, 1.8V, 2.5V, 3.3V or 5.0V.

All six voltages can be monitored simultaneously (i.e., continuous-time operation). Other non-standard voltage levels can be accounted for using various scale factors.

For added robustness, the comparators feature a variable hysteresis that scales with the voltage they monitor. Generally, a larger hysteresis is better. However, as power supply voltages get smaller, that hysteresis increasingly affects trip-point accuracy. Therefore, the hysteresis is +/-16mV for 5V supplies and scales down to +/-3mV for 1.2V supplies, or about 0.3% of the trip point.

The programmable logic functions consist of a block of 20 inputs with 41 product terms and eight macrocells. The architecture supports the sharing of product terms to enhance the overall usability.

The four output pins are open-drain outputs. These outputs can be used to drive enable lines for DC/DC converters or other control logic associated with power supply control. The four outputs are driven from the macrocells.



#### Figure 2-1. ispPAC-POWR604 Block Diagram

# **Pin Descriptions**

| Number | Name              | Pin Type           | Voltage Range           | Description                                                                   |
|--------|-------------------|--------------------|-------------------------|-------------------------------------------------------------------------------|
| 1      | NC                | —                  | —                       | No Connect                                                                    |
| 2      | NC                | —                  | —                       | No Connect                                                                    |
| 3      | NC                | —                  | —                       | No Connect                                                                    |
| 4      | NC                | —                  | —                       | No Connect                                                                    |
| 5      | VDD               | Power              | 2.25V-5.5V              | Main Power Supply                                                             |
| 6      | IN1               | CMOS Input         | VDDINP <sup>1, 3</sup>  | Input 1                                                                       |
| 7      | IN2               | CMOS Input         | VDDINP <sup>1, 3</sup>  | Input 2                                                                       |
| 8      | IN3               | CMOS Input         | VDDINP <sup>1, 3</sup>  | Input 3                                                                       |
| 9      | IN4               | CMOS Input         | VDDINP <sup>1, 3</sup>  | Input 4                                                                       |
| 10     | RESET             | CMOS input         | VDD <sup>6</sup>        | PLD Reset Input. Active Low                                                   |
| 11     | VDDINP            | Power              | 2.25V-5.5V <sup>3</sup> | Digital Inputs Power Supply                                                   |
| 12     | OUT5 <sup>8</sup> | O/D Output         | 2.25V-5.5V <sup>2</sup> | Open-Drain Output                                                             |
| 13     | OUT6 <sup>8</sup> | O/D Output         | 2.25V-5.5V <sup>2</sup> | Open-Drain Output                                                             |
| 14     | OUT7 <sup>8</sup> | O/D Output         | 2.25V-5.5V <sup>2</sup> | Open-Drain Output                                                             |
| 15     | OUT8 <sup>8</sup> | O/D Output         | 2.25V-5.5V <sup>2</sup> | Open-Drain Output                                                             |
| 16     | NC                | —                  |                         | No Connect                                                                    |
| 17     | NC                | -                  |                         | No Connect                                                                    |
| 18     | COMP6             | O/D Output         | 2.25V-5.5V <sup>2</sup> | VMON6 Comparator Output (Open-Drain)                                          |
| 19     | COMP5             | O/D Output         | 2.25V-5.5V <sup>2</sup> | VMON5 Comparator Output (Open-Drain)                                          |
| 20     | COMP4             | O/D Output         | 2.25V-5.5V <sup>2</sup> | VMON4 Comparator Output (Open-Drain)                                          |
| 21     | COMP3             | O/D Output         | 2.25V-5.5V <sup>2</sup> | VMON3 Comparator Output (Open-Drain)                                          |
| 22     | COMP2             | O/D Output         | 2.25V-5.5V <sup>2</sup> | VMON2 Comparator Output (Open-Drain)                                          |
| 23     | COMP1             | O/D Output         | 2.25V-5.5V <sup>2</sup> | VMON1 Comparator Output (Open-Drain)                                          |
| 24     | тск               | TTL/LVCMOS Input   | VDD                     | Test Clock (JTAG Pin)                                                         |
| 25     | POR               | O/D Output         | 2.25V-5.5V              | Power-On-Reset Output                                                         |
| 26     | CLK               | Bi-directional I/O | VDD <sup>2, 5</sup>     | Clock Output (Open-Drain) or Clock Input                                      |
| 27     | GND               | Ground             |                         | Ground                                                                        |
| 28     | TDO               | TTL/LVCMOS Output  | VDD                     | Test Data Out (JTAG Pin)                                                      |
| 29     | TRST              | TTL/LVCMOS Input   | VDD                     | Test Reset, Active Low, 50k Ohm Internal Pull-up (JTAG Pin, Optional Use)     |
| 30     | TDI               | TTL/LVCMOS Input   | VDD                     | Test Data In, 50k Ohm Pull-up (JTAG Pin)                                      |
| 31     | тмѕ               | TTL/LVCMOS Input   | VDD                     | Test Mode Select, 50k Ohm Internal Pull-up (JTAG Pin)                         |
| 32     | VMON1             | Analog Input       | 0V-5.72V <sup>4</sup>   | Voltage Monitor Input 1                                                       |
| 33     | VMON2             | Analog Input       | 0V-5.72V <sup>4</sup>   | Voltage Monitor Input 2                                                       |
| 34     | VMON3             | Analog Input       | 0V-5.72V <sup>4</sup>   | Voltage Monitor Input 3                                                       |
| 35     | VMON4             | Analog Input       | 0V-5.72V <sup>4</sup>   | Voltage Monitor Input 4                                                       |
| 36     | VMON5             | Analog Input       | 0V-5.72V <sup>4</sup>   | Voltage Monitor Input 5                                                       |
| 37     | VMON6             | Analog Input       | 0V-5.72V <sup>4</sup>   | Voltage Monitor Input 6                                                       |
| 38     | NC                | —                  | -                       | No Connect                                                                    |
| 39     | CREF              | Reference          | 1.17V <sup>7</sup>      | Reference for Internal Use, Decoupling Capacitor (.1uf Required, CREF to GND) |
| 40     | NC                | —                  | -                       | No Connect                                                                    |
| 41     | NC                | —                  | —                       | No Connect                                                                    |

# **Pin Descriptions (Continued)**

| Number | Name | Pin Type | Voltage Range | Description |
|--------|------|----------|---------------|-------------|
| 42     | NC   | —        | —             | No Connect  |
| 43     | NC   | —        |               | No Connect  |
| 44     | NC   | —        |               | No Connect  |

1. IN1...IN4 are digital inputs to the PLD. The thresholds for these pins are referenced by the voltage on VDDINP.

2. The open-drain outputs can be powered independently of VDD and pulled up as high as +6.0V (referenced to ground). Exception, CLK pin 26 can only be pulled as high as VDD.

- 3. VDDINP can be chosen independent of  $V_{DD}$ . It applies only to the four logic inputs IN1-IN4.
- 4. The six VMON inputs can be biased independently of VDD. The six VMON inputs can be as high as 7.0V Max (referenced to ground).

5. CLK is the PLD clock output in master mode. It is re-routed as an input in slave mode. The clock mode is set in software during design time. In output mode it is an open-drain type pin and requires an external pull-up resistor (pullup voltage must be ≤ V<sub>DD</sub>). Multiple ispPAC-POWR604 devices can be tied together with one acting as the master, the master can use the internal clock and the slave can be clocked by the master. The slave needs to be set up using the clock as an input.

- 6. RESET is an active low INPUT pin, external pull-up resistor required. When driven low it resets all internal PLD flip-flops to zero, and may turn "ON" or "OFF" the output pins, depending on the polarity configuration of the outputs in the PLD. If a reset function is needed for the other devices on the board, the PLD inputs and outputs can be used to generate these signals. The RESET connected to the POR pin can be used if multiple ispPAC-POWR604 devices are cascaded together in expansion mode or if a manual reset button is needed to reset the PLD logic to the initial state. While using the ispPAC-POWR604 in hot-swap applications it is recommended that either the RESET pin be connected to the POR pin, or connect a capacitor to ground (such that the time constant is 10 ms with the pull-up resistor) from the RESET pin.
- The CREF pin requires a 0.1µF capacitor to ground, near the device pin. This reference is used internally by the device. No additional
  external circuitry should be connected to this pin.
- 8. The four digital outputs (pins 12-15) are named OUT5-OUT8 to match ispPAC-POWR1208 pin names and to allow easy design migration.

# **Absolute Maximum Ratings**

Absolute maximum ratings are shown in the table below. Stresses above those listed values may cause permanent damage to the device. Functional operation of the device at these or any other conditions above those indicated in the operating sections of this specification is not implied.

| Symbol                          | Parameter                                                                            | Čonditions | Min. | Max. | Units |
|---------------------------------|--------------------------------------------------------------------------------------|------------|------|------|-------|
| VDD                             | Core supply voltage at pin                                                           | _          | -0.5 | 6.0  | V     |
| VDD <sub>INP</sub> <sup>1</sup> | Digital input supply voltage for IN1-IN4                                             | —          | -0.5 | 6.0  | V     |
| V <sub>IN</sub> <sup>2</sup>    | Input voltage applied, digital inputs                                                | _          | -0.5 | 6.0  | V     |
| VMON                            | Input voltage applied, V <sub>MON</sub> voltage monitor inputs                       |            | -0.5 | 7.0  | V     |
| V <sub>TRI</sub>                | Tristated or open drain output, external voltage applied (CLK pin 26 pull-up ≤ VDD). | _          | -0.5 | 6.0  | V     |
| Τ <sub>S</sub>                  | Storage temperature                                                                  | _          | -65  | 150  | °C    |
| T <sub>A</sub>                  | Ambient temperature with power applied                                               |            | -55  | 125  | °C    |
| T <sub>SOL</sub>                | Maximum soldering temperature (10 sec. at 1/16 in.)                                  | —          | —    | 260  | °C    |

1. V<sub>DDINP</sub> is the supply pin that controls logic inputs IN1-IN4 only. Place 0.1µF capacitor to ground and supply the V<sub>DDINP</sub> pin with appropriate supply voltage for the given input logic range.

2. Digital inputs are tolerant up to 5.5V, independent of the V<sub>DDINP</sub> voltage.

# **Recommended Operating Conditions**

| Symbol                           | Parameter                                                    | Conditions                                                                | Min. | Max. | Units  |
|----------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------|------|------|--------|
| V <sub>DD</sub>                  | Core supply voltage at pin                                   |                                                                           | 2.25 | 5.5  | V      |
| V <sub>DDPROG</sub> <sup>1</sup> | Core supply voltage at pin                                   | During E <sup>2</sup> cell programming                                    | 3.0  | 5.5  | V      |
| V <sub>DDINP</sub> <sup>2</sup>  | Digital input supply voltage for IN1-IN4                     |                                                                           | 2.25 | 5.5  | V      |
| V <sub>IN</sub> <sup>3</sup>     | Input voltage digital inputs                                 |                                                                           | 0    | 5.5  | V      |
| V <sub>MON</sub>                 | Voltage monitor inputs V <sub>MON1</sub> - V <sub>MON6</sub> |                                                                           | 0    | 6.0  | V      |
| Erase/Program<br>Cycles          |                                                              | EEPROM, programmed at<br>V <sub>DD</sub> = 3.0V to 5.5V<br>-40°C to +85°C | 1000 | _    | Cycles |
| T <sub>APROG</sub>               | Ambient temperature during programming                       |                                                                           | -40  | +85  | °C     |
| т.                               | Ambient temperature                                          | Power applied - Industrial                                                | -40  | +85  | °C     |
| T <sub>A</sub>                   |                                                              | Power applied - Automotive                                                | -40  | +125 | °C     |

1. The ispPAC-POWR604 device must be powered from 3.0V to 5.5V during programming of the E<sup>2</sup>CMOS memory.

2. V<sub>DDINP</sub> is the supply pin that controls logic inputs IN1-IN4 only. Place 0.1µF capacitor to ground and supply the V<sub>DDINP</sub> pin with appropriate supply voltge for the given input logic range.

3. Digital inputs are tolerant up to 5.5V, independent of the V<sub>DDINP</sub> voltage.

# **Analog Specifications**

### **Over Recommended Operating Conditions**

| Symbol          | Parameter      | Conditions              | Min. | Тур. | Max. | Units |
|-----------------|----------------|-------------------------|------|------|------|-------|
| I <sub>DD</sub> | Supply Current | Internal Clock = 250kHz |      | 5    | 10   | mA    |

### Reference

| Symbol                        |           | Parameter             |  | Conditions | Min. | Тур. | Max. | Units |
|-------------------------------|-----------|-----------------------|--|------------|------|------|------|-------|
| V <sub>REF</sub> <sup>1</sup> | Reference | e voltage at CREF pin |  | T = 25°C   | —    | 1.17 |      | V     |
| 1 CREE pip roquiro            |           | conscitor to ground   |  |            | -    |      |      |       |

1. CREF pin requires a  $0.1\mu$ F capacitor to ground.

# **Voltage Monitors**

| Symbol                               | Parameter                                                                                            | Conditions                           | Min. | Тур.                                 | Max. | Units   |
|--------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------|------|--------------------------------------|------|---------|
| R <sub>IN</sub>                      | Input impedance                                                                                      |                                      | 70   | 100                                  | 130  | kΩ      |
| V <sub>MON</sub> Range               | Programmable voltage monitor trip<br>point (192 steps)                                               |                                      | 1.03 |                                      | 5.72 | V       |
| V <sub>MON</sub> Accuracy            | Absolute accuracy of any trip point                                                                  | T = 25 °C,<br>V <sub>DD</sub> = 3.3V | -0.9 |                                      | +0.9 | %       |
| V <sub>MON</sub> Tempco <sup>1</sup> | Temperature drift of any trip point                                                                  | -40°C to +85°C                       |      | 50                                   |      | ppm/ °C |
|                                      |                                                                                                      | -40°C to +125°C                      |      | 76                                   |      | ppm/ °C |
| HYST                                 | Hysteresis of V <sub>MON</sub> input,<br>V <sub>HYST</sub> = HYST*V <sub>MON</sub> (+/-3 to +/-13mV) | V <sub>DD</sub> = 3.3V, 25°C         |      | +/- 0.3% of<br>trip point<br>setting |      | %       |
| PSR                                  | Trip point sensitivity to V <sub>DD</sub>                                                            | V <sub>DD</sub> = 3.3V               |      | 0.06                                 |      | %/V     |

1. See typical performance curves.

# **Power-on-Reset**

| Symbol            | Parameter                                                                                                                     | Conditions                              | Min. | Тур. | Max. | Units |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------|------|------|-------|
| V <sub>LPOR</sub> | V <sub>DD</sub> supply threshold beyond which POR output is guaranteed to be driven low                                       | V <sub>DD</sub> ramping up <sup>1</sup> | _    | _    | 1.15 | V     |
| V <sub>HPOR</sub> | $V_{\text{DD}}$ supply threshold above which $\overline{\text{POR}}$ output is guaranteed driven high, and device initializes | V <sub>DD</sub> ramping up <sup>1</sup> | _    | _    | 2.1  | V     |

1. POR tests run with  $10 k \Omega$  resistor pulled up to  $V_{\text{DD.}}$ 

# **AC/Transient Characteristics**

### **Over Recommended Operating Conditions**

| Symbol            | Parameter                                                     | Conditions                                                                                              | Min. | Тур. | Max. | Units. |
|-------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------|------|------|--------|
| Voltage Mon       | itors                                                         |                                                                                                         |      |      |      |        |
| t <sub>PD5</sub>  | Propagation Delay. Output transitions after a step input.     | Glitch filter set to 5µs. <sup>1</sup><br>Input V <sub>TRIP</sub> + 100mV to V <sub>TRIP</sub> - 100mV  | -    | 5    |      | μs     |
| t <sub>PD20</sub> | Propagation Delay. Output transitions after a step input.     | Glitch filter set to 20us. <sup>1</sup><br>Input V <sub>TRIP</sub> + 100mV to V <sub>TRIP</sub> - 100mV |      | 20   | -    | μs     |
| Oscillators       |                                                               |                                                                                                         |      |      |      |        |
| f <sub>CLK</sub>  | Internal master clock frequency                               | Note 2                                                                                                  | 230  | _    | 330  | kHz    |
| PLDCLK<br>Range   | Programmable frequency range<br>of PLD clock (8 binary steps) | Internal Osc 250kHz                                                                                     | 1.95 | _    | 250  | kHz    |
| PLDCLKext         | Max frequency of applied external clock source                | External clock applied                                                                                  |      | —    | 1    | MHz    |
| Timers            |                                                               |                                                                                                         |      |      |      |        |
| Timeout<br>Range  | Range of programmable time-out duration (15 steps)            | Internal Osc 250kHz                                                                                     | 0.03 | —    | 524  | ms     |

1. See Typical Performance Graphs.

2. f<sub>CLK</sub> frequency deviation with respect to VDD, 0.4%/volt, typical.

# **Digital Specifications**

### Over Recommended Operating Conditions

| Symbol                           | Parameter                                                                  | Conditions                                                | Min. | Тур. | Max.  | Units |
|----------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------|------|------|-------|-------|
| I <sub>IL,</sub> I <sub>IH</sub> | Input or I/O leakage current, no pull-<br>up                               | $0V \le V_{IN} \le V_{DDINP} \text{ or } V_{DD}$<br>25 °C |      |      | +/-10 | μA    |
| I <sub>PU</sub>                  | Input pull-up current (TMS, TDI,<br>TRST)                                  | 25 °C                                                     |      | 70   |       | μA    |
| V <sub>OL</sub>                  | Open-drain output set LOW                                                  | I <sub>SINKOUT</sub> = 4mA                                |      |      | 0.4   | V     |
| ISINKOUT                         | Maximum sink current for logic out-<br>puts [OUT5-OUT8], [COMP1-<br>COMP6] | (Note 1)                                                  |      |      | 20    | mA    |
| ISINKTOTAL                       | Total combined sink currents from all<br>outputs [OUT, COMP]               | (Note 1)                                                  |      |      | 80    | mA    |

1. [OUT5-OUT8] and [COMP1-COMP6] can sink up to 20mA max. per pin for LEDs, etc. However, output voltage levels may exceed V<sub>OL</sub>. Total combined sink currents from all outputs (OUT, COMP) should not exceed I<sub>SINKTOTAL</sub>.

# **DC Input Levels: IN1-IN4**

|                             | V <sub>IL</sub> | (V)  | V <sub>IH</sub> (V) |      |  |
|-----------------------------|-----------------|------|---------------------|------|--|
| Standard                    | Min.            | Max. | Min.                | Max. |  |
| CMOS, LVCMOS3.3, LVTTL, TTL | -0.3            | 0.8  | 2.0                 | 5.5  |  |
| LVCMOS2.5                   | -0.3            | 0.7  | 1.7                 | 5.5  |  |

Note: V<sub>DDINP</sub> is the input supply pin for IN1-IN4 digital logic input pins. The logic threshold trip point of IN1-IN4 is dependent on the voltage at V<sub>DDINP</sub>.

# **Transient Characteristics**

#### Over Recommended Operating Conditions

| Symbol                   | Parameter                                                                                                          | Conditions                              | Min. | Тур. | Max. | Units |
|--------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------|------|------|-------|
| PLD Timing               | ,                                                                                                                  |                                         |      |      |      |       |
| Digital Glitch<br>Filter | Minimum pulse width to transition through glitch filter.                                                           | Applied to IN1-IN4                      | 20   |      |      | μs    |
| t <sub>CO</sub>          | Clock to Out Delay. Rising edge of clock to output transition.                                                     | Stable input before clock edge (Note 1) |      |      | 300  | ns    |
| t <sub>SU</sub>          | Time that input needs to be present when using a registered function with the clock.                               | Data valid before clock<br>(Note 1)     | 20   |      |      | μs    |
| t <sub>H</sub>           | Time that input needs to be held valid after<br>the clock edge when using a registered<br>function with the clock. | Hold data after clock                   | 0    |      |      | μs    |
| t <sub>PD</sub>          | Propagation delay internal to the embedded PLD                                                                     |                                         |      |      | 90   | ns    |
| t <sub>RST</sub>         | RESET pulse width                                                                                                  |                                         | 25   |      |      | μs    |

1. External clock 1MHz. Open drain outputs with 2k pull-up resistor to  $V_{\text{DD}}$ 

Note: All the above parameters apply to signal paths from the digital inputs [IN1-IN4].



### **Timing for JTAG Operations**

| Symbol              | Parameter                                     | Conditions | Min | Тур. | Max | Units |
|---------------------|-----------------------------------------------|------------|-----|------|-----|-------|
| t <sub>CKMIN</sub>  | Minimum clock period                          |            | 1   |      |     | μs    |
| t <sub>СКН</sub>    | TCK high time                                 |            | 200 |      |     | ns    |
| t <sub>CKL</sub>    | TCK low time                                  |            | 200 |      |     | ns    |
| t <sub>MSS</sub>    | TMS setup time                                |            | 15  |      |     | ns    |
| t <sub>MSH</sub>    | TMS hold time                                 |            | 50  |      |     | ns    |
| t <sub>DIS</sub>    | TDI setup time                                |            | 15  |      |     | ns    |
| t <sub>DIH</sub>    | TDI hold time                                 |            | 50  |      |     | ns    |
| t <sub>DOZX</sub>   | TDO float to valid delay                      |            |     |      | 200 | ns    |
| t <sub>DOV</sub>    | TDO valid delay                               |            |     |      | 200 | ns    |
| t <sub>DOXZ</sub>   | TDO valid to float delay                      |            |     |      | 200 | ns    |
| t <sub>RSTMIN</sub> | Minimum reset pulse width                     |            | 40  |      |     | ns    |
| t <sub>PWP</sub>    | Time for a programming operation <sup>1</sup> |            | 40  |      | 100 | ms    |
| t <sub>PWE</sub>    | Time for an erase operation                   |            | 40  |      | 100 | ms    |

1. t<sub>PWP</sub> represents programming pulse width for a single row of E<sup>2</sup>CMOS cells.



# **Typical Performance Graphs**



| 1.2 low | 1.2 high | 1.5 low | 1.5 high | 1.8 low | 1.8 high | 2.5 low             | 2.5 high            | 3.3 low | 3.3 high      | 5.0 low | 5.0 high |
|---------|----------|---------|----------|---------|----------|---------------------|---------------------|---------|---------------|---------|----------|
| 1.036   | 1.202    | 1.291   | 1.502    | 1.549   | 1.801    | 2.153               | 2.500               | 2.842   | 3.297         | 4.299   | 4.991    |
| 1.046   | 1.213    | 1.303   | 1.516    | 1.564   | 1.818    | 2.173               | 2.524               | 2.869   | 3.328         | 4.340   | 5.038    |
| 1.056   | 1.225    | 1.316   | 1.531    | 1.579   | 1.836    | 2.195               | 2.549               | 2.897   | 3.361         | 4.383   | 5.088    |
| 1.066   | 1.237    | 1.329   | 1.546    | 1.595   | 1.854    | 2.216               | 2.574               | 2.926   | 3.394         | 4.426   | 5.138    |
| 1.076   | 1.249    | 1.341   | 1.560    | 1.609   | 1.871    | 2.237               | 2.597               | 2.952   | 3.425         | 4.466   | 5.185    |
| 1.087   | 1.261    | 1.354   | 1.575    | 1.625   | 1.889    | 2.258               | 2.622               | 2.981   | 3.458         | 4.509   | 5.235    |
| 1.096   | 1.272    | 1.366   | 1.590    | 1.639   | 1.906    | 2.279               | 2.646               | 3.008   | 3.489         | 4.550   | 5.282    |
| 1.107   | 1.284    | 1.379   | 1.605    | 1.655   | 1.924    | 2.300               | 2.671               | 3.036   | <b>3</b> .522 | 4.593   | 5.332    |
| 1.117   | 1.295    | 1.391   | 1.619    | 1.669   | 1.941    | 2.320               | 2.694               | 3.063   | 3.553         | 4.633   | 5.379    |
| 1.127   | 1.307    | 1.404   | 1.634    | 1.685   | 1.959    | 2.342               | 2.719               | 3.091   | 3.586         | 4.676   | 5.429    |
| 1.137   | 1.319    | 1.417   | 1.649    | 1.700   | 1.977    | 2.363               | 2.744               | 3.120   | 3.619         | 4.719   | 5.479    |
| 1.147   | 1.331    | 1.429   | 1.663    | 1.715   | 1.994    | 2.3 <mark>84</mark> | 2.768               | 3.147   | 3.650         | 4.760   | 5.526    |
| 1.157   | 1.343    | 1.442   | 1.678    | 1.730   | 2.012    | 2.405               | 2.7 <mark>93</mark> | 3.175   | 3.683         | 4.803   | 5.576    |
| 1.168   | 1.355    | 1.455   | 1.693    | 1.746   | 2.030    | 2.427               | 2.818               | 3.203   | 3.716         | 4.846   | 5.626    |
| 1.178   | 1.366    | 1.467   | 1.707    | 1.761   | 2.047    | 2.447               | 2.841               | 3.230   | 3.747         | 4.886   | 5.673    |
| 1.188   | 1.378    | 1.480   | 1.722    | 1.776   | 2.065    | 2.469               | 2.866               | 3.259   | 3.780         | 4.929   | 5.723    |

#### Table 2-1. V<sub>MON</sub> Trip Point Table<sup>1</sup>

1.All possible comparator trip voltages using internal attenuation settings.

Table 2-1 shows all possible comparator trip point voltage settings. The internal resistive divider allows ranges for 1.2V, 1.8V, 2.5V, 3.3V and 5.0V. There are 192 available voltages, ranging from 1.036V to 5.723V. In addition to the 192 voltage monitor trip points, the user can add additional resistors outside the device to divide down the voltage and achieve virtually any voltage trip point. This allows the capability to monitor higher voltages such and 12V, 15V, 24V, etc. Voltage monitor trip points are set in the graphical user interface of the PAC-Designer software by simple pull-down menus. The user simply selects the given range and corresponding trip point value. Attenuation and reference values are set internally using E<sup>2</sup>CMOS configuration bits internal to the device.

Figure 2-2 shows a single comparator, the attenuation network and reference used to program the monitor trip points. Each of the six comparators are independently set in the same way.

# **Theory Of Operation**

The ispPAC-POWR604 incorporates programmable voltage monitors along with digital inputs and outputs. The eight macrocell PLD inputs are from the six voltage monitors and four digital inputs. There are two embedded programmable timers that interface with the PLD, along with an internal programmable oscillator.

The six independently programmable voltage monitors each have 192 programmable trip points.

Figure 2-2 shows a simplified schematic representation of one of these monitors.

### Figure 2-2. Voltage Monitors



Each monitor consists of three major subsystems. The core of the monitor is a voltage comparator. This comparator outputs a HIGH signal to the PLD array if the voltage at its positive terminal is greater than that at its negative terminal, otherwise it outputs a LOW signal. A small amount of hysteresis is provided by the comparator to reduce the effects of input noise.

The input signal is attenuated by a programmable resistive divider before it is fed into the comparator. This feature is used to determine the coarse range in which the comparator should trip (e.g. 1.8V, 3.3V, 5V). Twelve possible ranges are available from the input divider network. The comparator's negative terminal is obtained from a programmable reference source (Reference), which may be set to one of 16 possible values scaled in approximately 1% increments from each other, allowing for fine tuning of the voltage monitor's trip points. This combination of coarse and fine adjustment supports 192 possible trip-point voltages for a given monitor circuit. Because each monitor's reference and input divider settings are completely independent of those of the other monitor circuits, the user can set any input monitor to any of the 192 available settings.

### **Comparator Hysteresis**

| F | V <sub>MON</sub><br>Range Setting | 1 | Typical Hysteresis or<br>Over Voltage Range | Typical Hysteresis on<br>Under Voltage Range | Units |
|---|-----------------------------------|---|---------------------------------------------|----------------------------------------------|-------|
|   | 5.0V                              |   | +/- 16.2                                    | +/- 14.0                                     | mV    |
|   | 3.3V                              |   | +/- 10.7                                    | +/- 9.2                                      | mV    |
|   | 2.5V                              |   | +/- 8.1                                     | +/- 7.0                                      | mV    |
|   | 1.8V                              |   | +/- 5.8                                     | +/- 5.0                                      | mV    |
|   | 1.5V                              |   | +/- 4.9                                     | +/- 4.2                                      | mV    |
|   | 1.2V                              |   | +/- 3.9                                     | +/- 3.4                                      | mV    |

1. The hysteresis scales depending on the voltage monitor range that is selected. The values show are typical and are centered around the nominal voltage trip point for a given range selection.

# **PLD Architecture**

The ispPAC-POWR604 digital logic is composed of an internal PLD that is programmed to perform the sequencing functions. The PLD architecture allows flexibility in designing various state machines and control logic used for monitoring. The macrocell shown in Figure 2-3 is the heart of the PLD. There are eight macrocells that can be used

### Lattice Semiconductor

to control the functional states of the sequencer state machine or other control or monitoring logic. The PLD AND array shown in Figure 2-4 has 20 inputs and 41 product terms (PTs). The resources from the AND array feed the eight macrocells. The resources within the macrocells share routing and contain a product-term allocation array. The product term allocation array greatly expands the PLD's ability to implement complex logical functions by allowing logic to be shared between adjacent blocks and distributing the product terms to allow for wider decode functions.

The basic macrocell has five product terms that feed the OR gate and the flip-flop. The flip-flop in each macrocell is independently configured. It can be programmed to function as a D-Type or T-Type flip-flop. The combinatorial functions are achieved through the bypass MUX function shown. By having the polarity control XOR, the logic reduction can be best fit to minimize the number of product terms. The flip-flop's clock drives from a common clock that can be generated from a pre-scaled, on-board clock source or from an external clock. The macrocell also supports asynchronous reset and preset functions, derived from product terms, the global reset input, or the power-on reset signal.



### Lattice Semiconductor

Figure 2-4. PLD and Timer Functional Block Diagram



### **Clock and Timer Systems**

Figure 2-5 shows a block diagram of the ispPAC-POWR604's internal clock and timer systems. The PLD clock can be programmed with eight different frequencies based on the internal oscillator frequency of 250kHz.

#### Figure 2-5. Clock and Timer Block



The internal oscillator runs at a fixed frequency of 250kHz. This main signal is then fed to the PLD clock pre-scaler and also the Timer Clock pre-scaler (Figure 2-5). For the PLD Clock, the main 250kHz oscillator is divided down to eight selectable frequencies shown in the Table 2-2. The architecture of the clock network allows the PLD clock to be driven to the CLK pin. This enables the user access to the PLD clock as an output for expansion mode or other uses of the (CLK) clock pin.

Schematically, when the switch is in the upper position, the internal oscillator drives the PLD clock pre-scaler and the timer pre-scaler. In this mode, the CLK pin is an open-drain output and represents the same frequency as the PLD clock. This is used when operating other devices (such as "slave" sequencing devices) in a synchronized mode. When the switch is in the lower position, the CLK pin is an input and must be driven with an external clock source. When driven from an external source, the same PLD clock pre-scaler is available to this external clock. The frequencies available for the PLD clock will be the external clock frequency divided by 1, 2, 4, 8, 16, 32, 64 or 128, depending on the programmable value chosen.

The Timer Clock Pre-Scaler divides the internal 250kHz oscillator (or external clock, if selected) down before it generates the clock for the two programmable timers. The pre-scaler has eight different divider ratios: Divide by 4, 8, 16, 32, 64, 128, 256 and 512 (Table 2-3). After the clock for the timers is divided down, it is used to drive the programmable timers. The two timers share the same timer clock frequency but may have different end count values. The timers can cover a range from 32us to 524ms for the internal oscillator. Longer delays can be achieved by using the external clock as an input.

#### Table 2-3. Timer Values<sup>1</sup>

| ÷ 4<br>62 kHz | ÷ 8<br>31.2 kHz | ÷ 16<br>15.6 kHz | ÷ 32<br>7.8 kHz | ÷ 64<br>3.9 kHz        | ÷ 128<br>2 kHz | ÷ 256<br>1 kHz | ÷ 512<br>0.5 kHz |
|---------------|-----------------|------------------|-----------------|------------------------|----------------|----------------|------------------|
|               |                 |                  |                 |                        |                |                |                  |
| 0.032 ms      |                 |                  |                 |                        |                |                |                  |
| 0.064 ms      | 0.064 ms        |                  |                 |                        |                |                |                  |
| 0.128 ms      | 0.128 ms        | 0.128 ms         |                 |                        |                |                |                  |
| 0.256 ms      | 0.256 ms        | 0.256 ms         | 0.256 ms        |                        |                |                |                  |
| 0.512 ms      | 0.512 ms        | 0.512 ms         | 0.512 ms        | 0.512 ms               |                |                |                  |
| 1.024 ms      | 1.024 ms        | 1.024 ms         | 1.024 ms        | 1.024 ms               | 1.024 ms       |                |                  |
| 2.048 ms      | 2.048ms         | 2.048ms          | 2.048ms         | 2.048ms                | 2.048ms        | 2.048ms        |                  |
| 4.096 ms      | 4.096 ms        | 4.096 ms         | 4.096 ms        | 4.0 <mark>96</mark> ms | 4.096 ms       | 4.096 ms       | 4.096 ms         |
|               | 8.192 ms        | 8.192 ms         | 8.192 ms        | 8.192 ms               | 8.192 ms       | 8.192 ms       | 8.192 ms         |
|               |                 | 16.384 ms        | 16.384 ms       | 16.384 ms              | 16.384 ms      | 16.384 ms      | 16.384 ms        |
|               |                 |                  | 32.768 ms       | 32.768 ms              | 32.768 ms      | 32.768 ms      | 32.768 ms        |
|               |                 |                  |                 | 65.536 ms              | 65.536 ms      | 65.536 ms      | 65.536 ms        |
|               |                 |                  |                 |                        | 131.072 ms     | 131.072 ms     | 131.072 ms       |
|               |                 |                  |                 |                        |                | 262.144 ms     | 262.144 ms       |
|               |                 |                  |                 |                        |                |                | 524.288 ms       |
|               |                 |                  |                 |                        |                |                |                  |

1. Timer values based on 250kHz clock.

For design entry, the user can select the source for the clock and the PAC-Designer software will calculate the appropriate delays in an easy-to-select menu format.

The control inputs for Timer1 and Timer2 can be driven by any of the eight PLD macrocell outputs. The reset for the timers is a function of the Global Reset pin (RESET), a power-on reset or when the timer input goes low. The waveforms in Figure 2-6 show the basic timer start and reset functions. Timer and clock divider values are specified in during the design phase using the PAC-Designer software, while simple pull-down menus allow the user to select the clocking mode and the values for the timers and the PLD clock.

#### Figure 2-6. Timer Waveforms



Note that if the clock module is configured as "slave" (i.e. the CLK is an input), the actual time-out of the two timers is determined by the external clock frequency.

# IEEE Standard 1149.1 Interface

In-system programming of the ispPAC-POWR604 is facilitated via an IEEE 1149.1 test access port (TAP). It is used by the ispPAC-POWR604 as a serial programming interface, boundary scan test is not supported. There are no boundary scan logic registers in the ispPAC-POWR604 architecture. This does not prevent the ispPAC-POWR604 from functioning correctly, however, when placed in a valid serial chain with other IEEE 1149.1 compliant devices. Since the ispPAC-POWR604 is used to powerup other devices, it should be programmed in a separate chain from PLDs, FPGAs or other JTAG devices.

A brief description of the ispPAC-POWR604 serial interface follows. For complete details of the reference specification, refer to the publication, Standard Test Access Port and Boundary-Scan Architecture, IEEE Std 1149.1-1990 (which now includes IEEE Std 1149.1a-1993).

### **Overview**

An IEEE 1149.1 test access port (TAP) provides the control interface for serially accessing the digital I/O of the isp-PAC-POWR604. The TAP controller is a state machine driven with mode and clock inputs. Instructions are shifted into an instruction register, which then determines subsequent data input, data output, and related operations. Device programming is performed by addressing various registers, shifting data in, and then executing the respective program instruction. The programming instructions transfer the data into internal E<sup>2</sup>CMOS memory. It is these non-volatile memory cells that determine the configuration of the ispPAC-POWR604. By cycling the TAP controller through the necessary states, data can also be shifted out of the various registers to verify the current ispPAC-POWR604 configuration. Instructions exist to access all data registers and perform internal control operations.

For compatibility between compliant devices, two data registers are mandated by the IEEE 1149.1 specification. Other registers are functionally specified, but inclusion is strictly optional. Finally, there are provisions for optional user data registers that are defined by the manufacturer. The two required registers are the bypass and boundary-scan registers. For ispPAC-POWR604, the bypass register is a 1-bit shift register that provides a short path through the device when boundary testing or other operations are not being performed. The ispPAC-POWR604, as mentioned earlier has no boundary-scan logic and therefore no boundary scan register. All instructions relating to boundary scan operations place the ispPAC-POWR604 in the BYPASS mode to maintain compliance with the specification.

The optional identification (IDCODE) register described in IEEE 1149.1 is also included in the ispPAC-POWR604. Six additional user data registers are included in the TAP of the ispPAC-POWR604 as shown in Figure 2-7. Most of these additional registers are used to program and verify the analog configuration (CFG) and PLD bits. A status register is also provided to read the status of the six analog comparators.



### Figure 2-7. TAP Registers



TAP Controller Specifics

The TAP is controlled by the Test Clock (TCK) and Test Mode Select (TMS) inputs. These inputs determine whether an Instruction Register or Data Register operation is performed. Driven by the TCK input, the TAP consists of a small 16-state controller. In a given state, the controller responds according to the level on the TMS input as shown in Figure 2-8. Test Data In (TDI) and TMS are latched on the rising edge of TCK, with Test Data Out (TDO) becoming valid on the falling edge of TCK. There are six steady states within the controller: Test-Logic-Reset, Run-Test/ Idle, Shift-Data-Register, Pause-Data-Register, Shift-Instruction-Register, and Pause-Instruction-Register. But there is only one steady state for the condition when TMS is set high: the Test-Logic-Reset state. This allows a reset of the test logic within five TCKs or less by keeping the TMS input high. Test-Logic-Reset is the power-on default state.

When the correct logic sequence is applied to the TMS and TCK inputs, the TAP will exit the Test-Logic-Reset state and move to the desired state. The next state after Test-Logic-Reset is Run-Test/Idle. Until a data or instruction scan is performed, no action will occur in Run-Test/Idle (steady state = idle). After Run-Test/Idle, either a data or instruction scan is performed. The states of the Data and Instruction Register blocks are identical to each other differing only in their entry points. When either block is entered, the first action is a capture operation. For the Data Registers, the Capture-DR state is very simple; it captures (parallel loads) data onto the selected serial data path (previously chosen with the appropriate instruction). For the Instruction Register, the Capture-IR state will always load the IDCODE instruction. It will always enable the ID Register for readout if no other instruction is loaded prior to a Shift-DR operation. This, in conjunction with mandated bit codes, allows a "blind" interrogation of any device in a compliant IEEE 1149.1 serial chain.

#### Figure 2-8. TAP States



Note: The value shown adjacent to each state transition represents the signal present at TMS at the time of a rising edge at TCK.

From the Capture state, the TAP transitions to either the Shift or Exit1 state. Normally the Shift state follows the Capture state so that test data or status information can be shifted out or new data shifted in. Following the Shift state, the TAP either returns to the Run-Test/Idle state via the Exit1 and Update states or enters the Pause state via Exit1. The Pause state is used to temporarily suspend the shifting of data through either the Data or Instruction Register while an external operation is performed. From the Pause state, shifting can resume by re-entering the Shift state via the Exit2 state or be terminated by entering the Run-Test/Idle state via the Exit2 and Update states. If the proper instruction is shifted in during a Shift-IR operation, the next entry into Run-Test/Idle initiates the test mode (steady state = test). This is when the device is actually programmed, erased or verified. All other instructions are executed in the Update state.

### **Test Instructions**

Like data registers, the IEEE 1149.1 standard also mandates the inclusion of certain instructions. It outlines the function of three required and six optional instructions. Any additional instructions are left exclusively for the manufacturer to determine. The instruction word length is not mandated other than to be a minimum of two bits, with only the BYPASS and EXTEST instruction code patterns being specifically called out (all ones and all zeroes respectively). The ispPAC-POWR604 contains the required minimum instruction set as well as one from the optional instruction set. In addition, there are several proprietary instructions that allow the device to be configured, verified, and monitored. For ispPAC-POWR604, the instruction word length is 6-bits. All ispPAC-POWR604 instructions available to users are shown in Table 2-4.

| Instruction               | Code   | Description                                                                |
|---------------------------|--------|----------------------------------------------------------------------------|
| EXTEST                    | 000000 | External Test. Defaults to BYPASS.                                         |
| ADDPLD <sup>1</sup>       | 000001 | Address PLD address register (43 bits).                                    |
| DATAPLD <sup>1</sup>      | 000010 | Address PLD column data register (81 bits).                                |
| ERASEAND <sup>1, 2</sup>  | 000011 | Bulk Erase AND array.                                                      |
| ERASEARCH <sup>1, 2</sup> | 000100 | Bulk Erase Architect array.                                                |
| PROGPLD <sup>1, 2</sup>   | 000101 | Program PLD column data register into E <sup>2</sup> .                     |
| PROGESF <sup>1, 2</sup>   | 000110 | Program the Electronic Security Fuse bit.                                  |
| BYPASS                    | 000111 | Bypass (connect TDI to TDO).                                               |
| READPLD <sup>1</sup>      | 001000 | Reads PLD column data from E <sup>2</sup> to the register (81 bits).       |
| DISCHARGE <sup>1</sup>    | 001001 | Fast VPP discharge.                                                        |
| ADDCFG <sup>1</sup>       | 001010 | Address CFG array address (4 bits).                                        |
| DATACFG <sup>1</sup>      | 001011 | Address CFG data (41 bits).                                                |
| ERASECFG <sup>1, 2</sup>  | 001100 | Bulk Erase CFG data.                                                       |
| PROGCFG <sup>1, 2</sup>   | 001101 | Program CFG data register into E <sup>2</sup> .                            |
| READCFG <sup>1</sup>      | 001110 | Read CFG column data from E <sup>2</sup> to the register (41 bits).        |
| CFGBE <sup>1, 2</sup>     | 010110 | Bulk Erase all E <sup>2</sup> memory (CFG, PLD, USE, and ESF).             |
| SAFESTATE <sup>1</sup>    | 010111 | Digital outputs hiZ (FET pulled L)                                         |
| PROGRAMEN <sup>1</sup>    | 011000 | Enable program mode (SAFESTATE IO)                                         |
| IDCODE                    | 011001 | Address Identification Code data register (32 bits).                       |
| PROGRAMDIS                | 011010 | Disable Program mode (normal IO)                                           |
| ADDSTATUS                 | 011011 | Address STATUS register (6 bits).                                          |
| SAMPLE                    | 011100 | Sample/Preload. Default to Bypass.                                         |
| ERASEUES <sup>1, 2</sup>  | 011101 | Bulk Erase UES.                                                            |
| SHIFTUES                  | 011110 | Reads UES data from E <sup>2</sup> and selects the UES register (16 bits). |
| PROGUES <sup>1, 2</sup>   | 011111 | Program UES data register into E <sup>2</sup> .                            |
| BYPASS                    | 1xxxxx | Bypass (connect TDI to TDO).                                               |

1. When these instructions are executed, the outputs are placed in the same mode as the instruction SAFESTATE (as described later) to prevent invalid and potentially destructive power supply sequencing.

2. Instructions that erase or program the E<sup>2</sup>CMOS memory must be executed only when the supply to the device is maintained at 3.0V to 5.5V.

**BYPASS** is one of the three required instructions. It selects the Bypass Register to be connected between TDI and TDO and allows serial data to be transferred through the device without affecting the operation of the ispPAC-POWR604. The IEEE 1149.1 standard defines the bit code of this instruction to be all ones (11111).

The required **SAMPLE/PRELOAD** instruction dictates the Boundary-Scan Register be connected between TDI and TDO. The ispPAC-POWR604 has no boundary scan register, so for compatibility it defaults to the BYPASS mode whenever this instruction is received. The bit code for this instruction is defined by Lattice as shown in Table 2-4.

The **EXTEST** (external test) instruction is required and would normally place the device into an external boundary test mode while also enabling the boundary scan register to be connected between TDI and TDO. Again, since the ispPAC-POWR604 has no boundary scan logic, the device is put in the BYPASS mode to ensure specification compatibility. The bit code of this instruction is defined by the 1149.1 standard to be all zeros (000000).

The optional **IDCODE** (identification code) instruction is incorporated in the ispPAC-POWR604 and leaves it in its functional mode when executed. It selects the Device Identification Register to be connected between TDI and TDO. The Identification Register is a 32-bit shift register containing information regarding the IC manufacturer,

### Lattice Semiconductor

device type and version code (Figure 2-9). Access to the Identification Register is immediately available, via a TAP data scan operation, after power-up of the device, or by issuing a Test-Logic-Reset instruction. The bit code for this instruction is defined by Lattice as shown in Table 2-4.

#### Figure 2-9. ID Code



### ispPAC-POWR604 Specific Instructions

There are 21 unique instructions specified by Lattice for the ispPAC-PWR604. These instructions are primarily used to interface to the various user registers and the E<sup>2</sup>CMOS non-volatile memory. Additional instructions are used to control or monitor other features of the device. A brief description of each unique instruction is provided in detail below, and the bit codes are found in Table 2-4.

**ADDPLD** – This instruction is used to set the address of the PLD AND/ARCH arrays for subsequent program or read operations. This instruction also forces the outputs into the SAFESTATE.

**DATAPLD** – This instruction is used to shift PLD data into the register prior to programming or reading. This instruction also forces the outputs into the SAFESTATE.

**ERASEAND** – This instruction will bulk erase the PLD AND array. The action occurs at the second rising edge of TCK in Run-Test-Idle JTAG state. The device must already be in programming mode PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

**ERASEARCH** – This instruction will bulk erase the PLD ARCH array. The action occurs at the second rising edge of TCK in Run-Test-Idle JTAG state. The device must already be in programming mode (PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

**PROGPLD** – This instruction programs the selected PLD AND/ARCH array column. The specific column is preselected by using ADDPLD instruction. The programming occurs at the second rising edge of the TCK in Run-Test-Idle JTAG state. The device must already be in programming mode (PROGRAMEN instruction) and operated at 3.3V to 5.0V. This instruction also forces the outputs into the SAFESTATE.

**PROGESF** – This instruction is used to program the electronic security fuse (ESF) bit. Programming the ESF bit protects proprietary designs from being read out. The programming occurs at the second rising edge of the TCK in Run-Test-Idle JTAG state. The device must already be in programming mode (PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

**READPLD** – This instruction is used to read the content of the selected PLD AND/ARCH array column. This specific column is preselected by using ADDPLD instruction. This instruction also forces the outputs into the SAF-ESTATE.

**DISCHARGE** – This instruction is used to discharge the internal programming supply voltage after an erase or programming cycle and prepares ispPAC-POWR604 for a read cycle. This instruction also forces the outputs into the SAFESTATE.

### Lattice Semiconductor

**ADDCFG** – This instruction is used to set the address of the CFG array for subsequent program or read operations. This instruction also forces the outputs into the SAFESTATE.

**DATACFG** – This instruction is used to shift data into the CFG register prior to programming or reading. This instruction also forces the outputs into the SAFESTATE.

**ERASECFG** – This instruction will bulk erase the CFG array. The action occurs at the second rising edge of TCK in Run-Test-Idle JTAG state. The device must already be in programming mode (PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

**PROGCFG** – This instruction programs the selected CFG array column. This specific column is preselected by using ADDCFG instruction. The programming occurs at the second rising edge of the TCK in Run-Test-Idle JTAG state. The device must already be in programming mode (PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

**READCFG** – This instruction is used to read the content of the selected CFG array column. This specific column is preselected by using ADDCFG instruction. This instruction also forces the outputs into the SAFESTATE.

**CFGBE** – This instruction will bulk erase all E<sup>2</sup>CMOS bits (CFG, PLD, UES, and ESF) in the ispPAC-POWR604. The device must already be in programming mode (PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

**SAFESTATE** – This instruction turns off all of the open-drain output transistors. Pins that are programmed as FET drivers will be placed in the active low state. This instruction is effective after Update-Instruction-Register JTAG state.

**PROGRAMEN** – This instruction enables the programming mode of the ispPAC-POWR604. This instruction also forces the outputs into the SAFESTATE.

**IDCODE** – This instruction connects the output of the Identification Code Data Shift (IDCODE) Register to TDO (Figure 2-10), to support reading out the identification code.

Figure 2-10. IDCODE Register



**PROGRAMDIS** – This instruction disables the programming mode of the ispPAC-POWR604. The Test-Logic-Reset JTAG state can also be used to cancel the programming mode of the ispPAC-POWR604.

**ADDSTATUS** – This instruction is used to both connect the status register to TDO (Figure 2-11) and latch the 6 voltage monitor (comparator outputs) into the status register. Latching of the 6 comparator outputs into the status register occurs during Capture-Data-Register JTAG state.

Figure 2-11. Status Register

| VMON | VMON | VMON | VMON | VMON | VMON |  |
|------|------|------|------|------|------|--|
| 1    | 2    | 3    | 4    | 5    | 6    |  |

**ERASEUES** – This instruction will bulk erase the content of the UES E<sup>2</sup>CMOS memory. The device must already be in programming mode (PROGRAMEN instruction) and operated. This instruction also forces the outputs into the SAFESTATE.

**SHIFTUES** – This instruction both reads the E<sup>2</sup>CMOS bits into the UES register and places the UES register between the TDI and TDO pins (as shown in Figure U), to support programming or reading of the user electronic signature bits.

#### Figure 2-12. UES Register

|           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          | TDO |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|-----|
| Bit<br>15 | Bit<br>14 | Bit<br>13 | Bit<br>12 | Bit<br>11 | Bit<br>10 | Bit<br>9 | Bit<br>8 | Bit<br>7 | Bit<br>6 | Bit<br>5 | Bit<br>4 | Bit<br>3 | Bit<br>2 | Bit<br>1 | Bit<br>0 |     |
|           |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          |     |

**PROGUES** – This instruction will program the content of the UES Register into the UES E<sup>2</sup>CMOS memory. The device must already be in programming mode (PROGRAMEN instruction). This instruction also forces the outputs into the SAFESTATE.

#### Notes:

In all of the descriptions above, SAFESTATE refers both to the instruction and the state of the digital output pins, in which the open-drains are tri-stated and the FET drivers are pulled low.

Before any of the above programming instructions are executed, the respective E<sup>2</sup>CMOS bits need to be erased using the corresponding erase instruction.

## **Application Example**

The ispPAC-POWR604 device has six comparators to monitor various power supply levels. The comparators each have a programmable trip point that is programmed by the user at design time. The output of the comparators feed into the PLD logic array to drive the state machine logic or monitor logic. The outputs of comparators COMP1...COMP6 are also routed to external pins to be monitored directly or can be used to drive additional control logic if expansion is required. The comparator outputs are open-drain type output buffers and require a pull up resistor to drive a logic high. All six comparators have hysteresis, the hysteresis is dependent on the voltage trip point scale that is set, it ranges from 3.4mV for the 1.2V monitor supply range to 16.2mV for the 5.0V monitor supply range. The comparators can be set with a trip point from 1.03V to 5.72V, with 192 different values. The application diagram shows a set-up that can monitor and control multiple power supplies. The digital outputs and inputs are also used to interface with the board that is being powered up.

Figure 2-13. Typical Application Example: ispPAC-POWR604 Interfacing to CPU Board Using Four Outputs, Four Inputs and Six VMON Voltage Monitoring Signals



# **Software-Based Design Environment**

### **Design Entry Software**

All functions within the ispPAC-POWR604 are controlled through a Windows-based software development tool called PAC-Designer. PAC-Designer has an easy-to-use graphical user interface (Figure 2-14) that allows the user to set up the ispPAC-POWR604 to perform required functions, such as timed sequences for power supply or monitor trip points for the voltage monitor inputs. The software tool gives the user control over how the device drives the outputs and the functional configurations for all I/O pins. User-friendly dialog boxes are provided to set and edit all of the analog features of the ispPAC-POWR604. An extension to the schematic screen is the LogiBuilder design environment (Figure 2-15) that is used to enter and edit control sequences. Again, user-friendly dialog boxes are provided in this window to help the designer quickly implement sequences that take advantage of the powerful built-in PLD. Once the configurations are chosen and the sequence has been described by the utilities, the device is ready to program. A standard JTAG interface is used to program the E<sup>2</sup>CMOS memory. The PAC-Designer software supports downloading the device through the PC's parallel port. The ispPAC-POWR604 can be reprogrammed in-system using the software and an ispDOWNLOAD<sup>®</sup> Cable assembly to compensate for variations in supply timing, sequencing or scaling of voltage monitor inputs.

#### Figure 2-14. PAC-Designer Schematic Screen



The user interface (Figure 2-14) provides access to various internal function blocks within the ispPAC-POWR604 device.

Analog Inputs: Accesses the programmable threshold trip-points for the comparators and pin naming conventions.

**Digital Inputs**: Digital input naming configurations and digital inputs feed into the internal PLD for the sequence controller.

**Sequence Controller**: Incorporates a PLD architecture for designing the state machine to control the order and functions associated with the user-defined power-up sequence/monitor and control.

**Logic Outputs**: These pins are configured and assigned in the Logic Output Functional Block. The four digital outputs are open-drain and require an external pull-up resistor.

**Internal Clock**: The internal clock configuration and clock prescaler values are user-programmable, as well as the four internal programmable timers used for sequence delay.

User Electronic Signature (UES): Stores 16 bits of ID or board information in non-volatile E<sup>2</sup>CMOS.

Figure 2-15. PAC-Designer LogiBuilder Screen



Programming of the ispPAC-POWR604 is accomplished using the Lattice ispDOWNLOAD Cable. This cable connects to the parallel port of a PC and is driven through the PAC-Designer software. The software controls the JTAG TAP interface and shifts in the JEDEC data bits that set the configuration of all the analog and digital circuitry that the user has defined during the design process.

Power to the device must be set at 3.0V to 5.5V during programming, once the programming steps have been completed, the power supply to the ispPAC-POWR604 can be set from 2.25V to 5V. Once programmed, the on-chip non-volatile E<sup>2</sup>CMOS bits hold the entire design configuration for the digital circuits, analog circuits and trip points for comparators etc. Upon powering the device up, the non-volatile E<sup>2</sup>CMOS bits control the device configuration. If design changes need to be made such as adjusting comparator trip points or changes to the digital logic functions, the device is simply re-programmed using the ispDOWNLOAD Cable.

## Design Simulation Capability

Support for functional simulation of the control sequence is provided using the design tools Waveform Editor and Waveform Viewer. Both applications are spawned from the LogiBuilder environment of PAC-Designer. The simulation engine combines the design file with a stimulus file (edited by the user with the Waveform Editor) to produce an output file that can be observed with the Waveform Viewer (Figure 2-16).





## **In-System Programming**

The ispPAC-POWR604 is an in-system programmable device. This is accomplished by integrating all E<sup>2</sup>CMOS configuration memory and control logic on-chip. Programming is performed through a 4-wire, IEEE 1149.1 compliant serial JTAG interface. Once a device is programmed, all configuration information is stored on-chip, in non-volatile E<sup>2</sup>CMOS memory cells. The specifics of the IEEE 1149.1 serial interface and all ispPAC-POWR604 instructions are described in the JTAG interface section of this data sheet.

# **User Electronic Signature**

The User Electronic Signature (UES), allows the designer to include identification bits or serial numbers inside the device, stored in E<sup>2</sup>CMOS memory. The ispPAC-POWR604 contains 16 UES bits that can be configured by the user to store unique data such as ID codes, revision numbers or inventory control codes.

# **Electronic Security**

An Electronic Security Fuse (ESF) bit is provided to prevent unauthorized readout of the E<sup>2</sup>CMOS bit pattern. Once programmed, this cell prevents further access to the functional user bits in the device. This cell can only be erased by reprogramming the device; this way the original configuration cannot be examined or copied once programmed. Usage of this feature is optional.

# Production Programming Support

Once a final configuration is determined, an ASCII format JEDEC file can be created using the PAC-Designer software. Devices can then be ordered through the usual supply channels with the user's specific configuration already preloaded into the devices. By virtue of its standard interface, compatibility is maintained with existing production programming equipment, giving customers a wide degree of freedom and flexibility in production planning.

# Package Diagrams

### 44-Pin TQFP (Dimensions in Millimeters)



## **Part Number Description**



# **Package Options**

