

# NTE8255 Integrated Circuit Programmable Peripheral Interface

# **Description:**

The NTE8255 is a general purpose programmable INPUT/OUTPUT device in a 40-Lead DIP type package designed for use with the 8080A/8085A microprocessors. Twenty-four (24) I/O lines may be programmed in two groups of twelve (Group I and Group II) and used in three modes of operation. In the Basic mode, (MODE 0), each group of twelve I/O pins may be programmed in sets of 4 to be input or output. In the Strobed mode, (MODE 1), each group may be programmed to have 8 lines of input or output. Three of the remaining four pins in each group are used for handshaking strobes and interrupt control signals. The Bi-directional Bus mode, (MODE 2), uses the 8 lines of Port A for a bi-directional bus, and five lines from Port C for bus control signals.

# Features:

- Fully Compatible with the 8080A/8085A Microprocessor Families
- All Inputs and Outputs TTL Compatible
- 24 Programmable I/O Pins
- Direct Bit SET/RESET Eases Control Application Interfaces
- 8 4mA Darlington Drive Outputs for Printers and Displays
- LSI Drastically Reduces System Package Count

| Absolute Maximum Ratings: $(T_A = +25^{\circ}C, \text{ Note 1, unless otherwise specified})$ |
|----------------------------------------------------------------------------------------------|
| Voltage on Any Pin With Respect to V <sub>SS</sub>                                           |
| Operating Temperature Range, T <sub>A</sub>                                                  |
| Storage Temperature Range, T <sub>stg</sub> 65° to +150°C                                    |

- Note 1. With respect to V<sub>SS</sub>
- Note 2. Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# <u>DC Characteristics:</u> (T<sub>A</sub> = $0^{\circ}$ to $+70^{\circ}$ C, V<sub>CC</sub> = +5V $\pm 10\%$ , V<sub>SS</sub> = 0V unless otherwise specified)

| Parameter                | Symbol           | Test Conditions                                   | Min  | Тур | Max      | Unit |
|--------------------------|------------------|---------------------------------------------------|------|-----|----------|------|
| Input Low Voltage        | V <sub>IL</sub>  |                                                   | -0.5 | _   | 0.8      | V    |
| Input High Voltage       | V <sub>IH</sub>  |                                                   | 2    | _   | $V_{CC}$ | V    |
| Output Low Voltage       | V <sub>OL</sub>  | Note 4                                            | _    | _   | 0.45     | V    |
| Output High Voltage      | V <sub>OH</sub>  | Note 5                                            | 2.4  | _   | _        | V    |
| Darlington Drive Current | I <sub>OH</sub>  | $V_{EXT} = 1.5V$ , $R_{EXT} = 750\Omega$ , Note 3 | -1   | _   | -4       | mA   |
| Power Supply Current     | I <sub>CC</sub>  | V <sub>CC</sub> = +5V, Output Open                | _    | _   | 120      | mA   |
| Input Leakage Current    | I <sub>LIH</sub> | $V_{IN} = V_{CC}$                                 | _    | _   | 10       | μΑ   |
|                          | I <sub>LIL</sub> | V <sub>IN</sub> = 0.4V                            | _    | _   | -10      | μΑ   |
| Output Leakage Current   | I <sub>LOH</sub> | $V_{OUT} = V_{CC}$ , $\overline{CS} = 2V$         | _    | _   | ±10      | μΑ   |
|                          | I <sub>LOL</sub> | $V_{OUT} = 0.4V, \overline{CS} = 2C$              | _    | _   | -10      | μΑ   |

Note 3. Any set of eight (8) outputs from either Port A, B, or C can source 4mA into 1.5V.

Note 4.  $I_{OL} = 2.5 \text{mA}$  for DB Port; 1.7mA for Peripheral Ports.

Note 5.  $I_{OH} = -400\mu A$  for dB Port;  $-200\mu A$  for Peripheral Ports.

# Capacitance: (T<sub>A</sub> = +25°C, V<sub>CC</sub> = V<sub>SS</sub> = 0V onless otherwise specified)

| Parameter         | Symbol           | Test Conditions                        | Min | Тур | Max | Unit |
|-------------------|------------------|----------------------------------------|-----|-----|-----|------|
| Input Capacitance | C <sub>IN</sub>  | f <sub>c</sub> = 1MHz, Unmeasured pins | 1   | -   | 10  | pF   |
| I/O Capacitance   | C <sub>I/O</sub> | returned to V <sub>SS</sub>            | _   | -   | 20  | рF   |

# <u>AC Characteristics:</u> $(T_A = 0^{\circ} \text{ to } +70^{\circ}\text{C}, V_{CC} = +5\text{V} \pm 5\%, V_{SS} = 0\text{V} \text{ unless otherwise specified})$

| Parameter                     | Symbol          | Test Conditions        | Min | Тур | Max | Unit |
|-------------------------------|-----------------|------------------------|-----|-----|-----|------|
| READ                          |                 |                        |     |     |     |      |
| Address Stable Before READ    | t <sub>AR</sub> |                        | 0   | _   | _   | ns   |
| Address Stable After READ     | t <sub>RA</sub> |                        | 0   | -   | _   | ns   |
| READ Pulse Width              | t <sub>RR</sub> |                        | 200 | _   | _   | ns   |
| Data Valid From READ          | t <sub>RD</sub> | C <sub>L</sub> = 150pF | _   | _   | 140 | ns   |
| Data Float After READ         | t <sub>DF</sub> | C <sub>L</sub> = 100pF | _   | _   | 100 | ns   |
|                               |                 | C <sub>L</sub> = 15pF  | 10  | _   | _   | ns   |
| Time Between READS and/WRITES | t <sub>RV</sub> | Note 7                 | 200 | _   | _   | ns   |
| WRITE                         |                 |                        | •   | •   |     |      |
| Address Stable Before WRITE   | t <sub>AW</sub> |                        | 0   | _   | _   | ns   |
| Address Stable After WRITE    | t <sub>WA</sub> |                        | 20  | _   | _   | ns   |
| WRITE Pulse Width             | t <sub>WW</sub> |                        | 200 | _   | _   | ns   |
| Data Valid to WRITE (T.E.)    | t <sub>DW</sub> |                        | 100 | _   | _   | ns   |
| Data Valid After WRITE        | t <sub>WD</sub> |                        | 0   | _   | _   | ns   |

# <u>AC Characteristics (Cont'd):</u> $(T_A = 0^\circ \text{ to } +70^\circ \text{C}, V_{CC} = +5\text{V} \pm 5\%, V_{SS} = 0\text{V} \text{ unless otherwise specified})$

| Parameter                    | Symbol           | Test Conditions                | Min | Тур | Max | Unit |
|------------------------------|------------------|--------------------------------|-----|-----|-----|------|
| OTHER TIMING                 | •                |                                |     |     |     |      |
| WR = 0 to Output             | t <sub>WB</sub>  | C <sub>L</sub> = 150pF         | _   | _   | 350 | ns   |
| Peripheral Data Before RD    | t <sub>IR</sub>  |                                | 0   | _   | _   | ns   |
| Peripheral Data After RD     | t <sub>HR</sub>  |                                | 0   | _   | _   | ns   |
| ACK Pulse Width              | t <sub>AK</sub>  |                                | 300 | _   | _   | ns   |
| STB Pulse Width              | t <sub>ST</sub>  |                                | 350 | _   | _   | ns   |
| Per. Data Before T.E. of STB | t <sub>PS</sub>  |                                | 0   | _   | _   | ns   |
| Per. Data After T.E. of STB  | t <sub>PH</sub>  |                                | 150 | -   | _   | ns   |
| ACK = 0 to Output            | t <sub>AD</sub>  | C <sub>L</sub> = 150pF         | _   | _   | 300 | ns   |
| ACK = 0 to Output Float      | t <sub>KD</sub>  | C <sub>L</sub> = 50pF          | _   | _   | 250 | ns   |
|                              |                  | C <sub>L</sub> = 15pF          | 20  | _   | _   | ns   |
| WR = 1 to OBF = 0            | t <sub>WOB</sub> |                                | _   | _   | 300 | ns   |
| ACK = 0 to OBF = 1           | t <sub>AOB</sub> |                                | _   | _   | 350 | ns   |
| STB = 0 to IBF = 1           | t <sub>SIB</sub> |                                | _   | _   | 300 | ns   |
| RD = 1 to IBF = 0            | t <sub>RIB</sub> | C <sub>L</sub> = 150pF         | _   | _   | 300 | ns   |
| RD = 0 to INTR = 0           | t <sub>RIT</sub> |                                | _   | _   | 400 | ns   |
| STB = 1 to INTR = 1          | t <sub>SIT</sub> |                                | _   | -   | 300 | ns   |
| ACK = 1 to INTR = 1          | t <sub>AIT</sub> |                                | _   | -   | 350 | ns   |
| WR = 0 to INTR = 0           | t <sub>WIT</sub> | C <sub>L</sub> = 150pf, Note 8 | _   | -   | 450 | ns   |

Note 6. Period of Reset pulse must be at least  $50\mu s$  during or after power on. Subsequent Reset pulse can be 500ns Min.

# Note 7.



Note 8. INTR $\uparrow$  may occur as early as  $\overline{WR} \downarrow$ .

# **Basic Operation:**

|                       | Input Operation (READ) |    |    |    |                               |  |  |  |  |  |
|-----------------------|------------------------|----|----|----|-------------------------------|--|--|--|--|--|
| <b>A</b> <sub>1</sub> | A <sub>0</sub>         | RD | WR | CS |                               |  |  |  |  |  |
| 0                     | 0                      | 0  | 1  | 0  | PORT A $\rightarrow$ Data Bus |  |  |  |  |  |
| 0                     | 1                      | 0  | 1  | 0  | PORT B → Data Bus             |  |  |  |  |  |
| 1                     | 0                      | 0  | 1  | 0  | PORT C → Data Bus             |  |  |  |  |  |

Note 9. All conditions not listed are illegal and should be avoided.

Note 10. X means "DO NOT CARE".

## **Basic Operation (Cont'd):**

|                | Output Operation (WRITE) |    |    |    |                    |  |  |  |  |  |
|----------------|--------------------------|----|----|----|--------------------|--|--|--|--|--|
| A <sub>1</sub> | A <sub>0</sub>           | RD | WR | CS |                    |  |  |  |  |  |
| 0              | 0                        | 1  | 0  | 0  | Data Bus → PORT A  |  |  |  |  |  |
| 0              | 1                        | 1  | 0  | 0  | Data Bus → PORT B  |  |  |  |  |  |
| 1              | 0                        | 1  | 0  | 0  | Data Bus → PORT C  |  |  |  |  |  |
| 1              | 1                        | 1  | 0  | 0  | Data Bus → CONTROL |  |  |  |  |  |

|                | Disable Function |    |    |    |                                     |  |  |  |  |  |
|----------------|------------------|----|----|----|-------------------------------------|--|--|--|--|--|
| A <sub>1</sub> | A <sub>0</sub>   | RD | WR | CS |                                     |  |  |  |  |  |
| Х              | Х                | Х  | Х  | 1  | Data Bus $\rightarrow$ High Z State |  |  |  |  |  |
| Х              | Х                | 1  | 1  | 0  | Data Bus $\rightarrow$ High Z State |  |  |  |  |  |

# **Functional Description:**

#### General

The NTE8255 Programmable Peripheral Interface (PPI) is designed for use in 8080A/8085A micro-processor systems. Peripheral equipment can be effectively and efficiently interfaced to the 8080A/8085A data and control busses with the NTE8255. The NTE8255 is functionally configured to be programmed by system software to avoid external logic for peripheral interfaces.

#### **Data Bus Buffer**

The 3–State, bi–directional, 8–Bit Data Bus Buffer ( $D_0$  –  $D_7$ ) of the NTE8255 can be directly interfaced to the processor's system Data Bus ( $D_0$  –  $D_7$ ). The Data Bus Buffer is controlled by execution in IN and OUT instructions by the processor. Control Words and Status information are also transmitted via the Data Bus Buffer.

# Read/Write and Control Logic

This block manages all of the internal and external transfers of Data, Control, and Status. Through this block, the processor Address and Control busses can control the peripheral interfaces.

## Chip Select, CS (Pin6)

A Logic Low, V<sub>II</sub>, on this input enables the NTE8255 for communication with the 8080A/8085A.

## Read, RD (Pin5)

A Logic Low,  $V_{IL}$ , on this input enables the NTE8255 to send Data or Status to the processor via the Data Bus Buffer.

# Write, WR (Pin36)

A Logic Low,  $V_{\text{IL}}$ , on this input enables the Data Bus Buffer to receive Data or Control Words from the processor.

# Port Select 0, A<sub>0</sub> (Pin9) Port Select 1, A<sub>1</sub> (Pin8)

These two inputs are used in conjunction with  $\overline{CS}$ ,  $\overline{RD}$ , and  $\overline{WR}$  to control the selection of one of three ports on the Control Word Register.  $A_0$  and  $A_1$  are usually connected to  $A_0$  and  $A_1$  of the processor Address Bus.

#### Reset (Pin35)

A Logic High,  $V_{IH}$ , on this input clears the Control Register and sets ports A, B, and C to the input mode. The input latches in ports A, B, and C are not cleared.

# Functional Description (Cont'd):

## **Group I and Group II Controls**

Through an OUT instruction in System Software from the processor, a control word is transmitted to the NTE8255. Information such as "MODE", "Bit SET", and "Bit RESET" is used to initialize the functional configuration of each I/O port.

Each group (I and II) accepts "commands" from the Read/Write Control Logic and "control words" from the internal data bus and in turn controls its associated I/O ports.

Group I – Port A and upper Port C (PC<sub>7</sub> – PC<sub>4</sub>) Group II – Port B and lower Port C (PC<sub>3</sub> – PC<sub>0</sub>)

While the Control Word Register can be written into, the contents cannot be read back to the processor.

#### Ports A, B, and C

The three 8-bit I/O ports (A, B, and C) in the NTE8255 can all be configured to meet a wide variety of functional requirements through system software. The effectiveness and flexibility of the NTE8255 are further enhanced by special features unique to each of the ports.

Port A = An 8-bit data output latch/buffer and data input latch.

Port B = An 8-bit data input/output latch/buffer and an 8-bit data input buffer. Port C = An 8-bit output latch/buffer and a data input buffer (input not latched).

Port C may be divided into two independent 4-bit control and status ports for use with Ports A and B.



