

# **UM82C55A**

**CMOS Programmable** Peripheral Interface

#### **Features**

- Pin compatible with NMOS 8255A
- 24 programmable I/O pins
- Fully TTL compatible
- Bus-hold circuitry on all I/O ports eliminates pull-up
- High speed, no "wait state" operation with 8MHz

#### 80C86

- Direct bit set/reset capability
- Enhanced control word read capability
- Single 5V power supply
- 2.5mA drive capability on all I/O port outputs
- Low standby current I<sub>CCSB</sub> = 10μA

#### **General Description**

The UM82C55A is a high performance CMOS version of the industry standard 8255A and is manufactured using a self aligned silicon gate CMOS process. It is a general purpose programmable I/O device which may be used with many different microprocessors. There are 24 I/O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. The high

performance of the UM82C55A makes it compatible with microprocessors such as the 8086, 8048, 8051.

Static CMOS circuit design ensures low operating power. TTL compatibility of  $V_{IH}$  =2.0 volts over the industrial temperature range and bus hold circuitry eliminates the need for pull-up resistors.

# **Pin Configuration**

# **Block Diagram**







# Absolute Maximum Ratings\*

# Supply Voltage +8.0 VOLTS Operating Voltage Range +4V to +7V Input Voltage Applied GND-2.0V to 6.5V I/O Pin Voltage Applied GND-0.5V to VCC+0.5V Storage Temperature Range -65°C to +150°C Operating Temperature Range 0°C to +70°C Maximum Power Dissipation 1 Watt

# \*Comments

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

# D.C. Electrical Characteristics

 $(VCC = 5.0V + / -5\%; T_A = 0^{\circ}C \text{ to } +70^{\circ}C)$ 

| Symbol          | Parameter                     | Min.           | Max. | Units | Test Conditions                                                                                |
|-----------------|-------------------------------|----------------|------|-------|------------------------------------------------------------------------------------------------|
| ViH             | VIH Logical One Input Voltage |                |      | ٧     |                                                                                                |
| VIL -           | Logical Zero Input Voltage    |                | 0.8  | V     |                                                                                                |
| V <sub>OH</sub> | Logical One Output Voltage    | 3.0<br>VCC-0.4 |      | V     | l <sub>OH</sub> = -2.5mA<br>l <sub>OH</sub> = -100 μA                                          |
| VoL             | Logical Zero Output Voltage   | ·              | 0.4  | V     | I <sub>OL</sub> = +2.5 mA                                                                      |
| I∤L             | Input Leakage Current         | -1.0           | 1.0  | μА    | OV VIN VCC                                                                                     |
| lo l            | I/O Pin Leakage Current       | -10.0          | 10.0 | μΑ    | 0 <sub>V</sub> ≤V <sub>0</sub> ≤V <sub>CC</sub>                                                |
| Івнн            | Bus Hold High Leakage Current | -50            | 300  | μΑ    | V <sub>O</sub> = 3.0V<br>Ports A, B, C                                                         |
| IBHL            | Bus Hold Low Leakage Current  | +50            | +300 | μΑ    | V <sub>O</sub> = 1.0V<br>Port A only                                                           |
| DAR             | DAR Darlington Drive Current  |                |      | mA    | Ports A, B, C<br>Test Condition 3                                                              |
| Icc             | Power Supply Current          |                | 10   | μΑ    | V <sub>CC</sub> = 5.5V<br>V <sub>IN</sub> = V <sub>CC</sub> or G <sub>ND</sub><br>Outputs Open |

#### Capacitance

 $(T_A = 25^{\circ}C; V_{CC} = GND = 0V; V_{IN} = +5V \text{ or GND})$ 

| Symbol            | Parameter Min. Max  |  | Max. | Units | Test Conditions                                    |  |
|-------------------|---------------------|--|------|-------|----------------------------------------------------|--|
| C <sub>IN</sub> * | Input Capacitance   |  | 5    | pF    | FREQ = 1 MHZ<br>Unmeasured Pins<br>Returned to GND |  |
| C <sub>I/O*</sub> | I/O Pin Capacitance |  | 20   | pF    |                                                    |  |

<sup>\*</sup>Guaranteed and sampled, but not 100% tested





# A.C. Characteristics

 $(V_{CC} = +5V \pm 5\%, GND = 0V; T_A = 0^{\circ}C \text{ to } +70^{\circ}C)$ 

# READ

| Symbol                                                                          | Parameter                                                                                                                                         | Min.                       | Max.      | Unit                       | Test Conditions |
|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------|----------------------------|-----------------|
| t <sub>AR</sub> t <sub>RA</sub> t <sub>RB</sub> t <sub>RD</sub> t <sub>DF</sub> | Address Stable Before READ Address Stable After READ READ Pulse Width Data Valid From READ Data Float After READ Time Between READs and/or WRITEs | 0<br>0<br>150<br>10<br>300 | 100<br>75 | ns<br>ns<br>ns<br>ns<br>ns | 1 2             |

PC Mainboard

# WRITE

| Symbol | Parameter                   | Min. | Max. | Unit | Test Conditions |
|--------|-----------------------------|------|------|------|-----------------|
| tAW    | Address Stable Before WRITE | 0    |      | ns   |                 |
| twa    | Address Stable After WRITE  | 20   |      | ns   | Ports A & B     |
| -VVA   |                             | 60   | 1    | ns   | Port C          |
| tww    | WRITE Pulse Width           | 100  | 1    | ns   | ,               |
| t DW   | Data Valid to WRITE High    | 100  |      | ns   |                 |
| tWD    | Data Valid After WRITE High | 30   |      | ns   | Ports A & B     |
| -440   |                             | 60   | 1 1  | ns   | Port C          |

# OTHER TIMING

| Symbol           | Parameter                 | Min. | Max. | Unit  | Test Conditions |
|------------------|---------------------------|------|------|-------|-----------------|
| twa              | WR = 1 to Output          |      | 350  | ns    | 1               |
| tiB              | Peripheral Data Before RD | . 0  | 1 1  | ns    |                 |
| tHR              | Peripheral Data After RD  | 0    |      | ns    |                 |
| t <sub>AK</sub>  | ACK Pulse Width           | 100  |      | ns    |                 |
| t <sub>ST</sub>  | STB Pulse Width           | 100  |      | ns    | 1               |
| t <sub>PS</sub>  | Per, Data Before STB High | 20   |      | ns    | •               |
| t <sub>PH</sub>  | Per, Data After STB High  | 50   |      | ns    |                 |
|                  | ACK = 0 to Output         |      | 175  | ns    | 1 1             |
| t <sub>AD</sub>  | ACK = 1 to Output Float   | 20   | 250  | ns    | 2               |
| two p            | WR = 1 to OBF = 0         |      | 150  | ns    | 1               |
| twoB             | ACK = 0 to OBF = 1        | •    | 150  | ns    | 1               |
| t <sub>AOB</sub> | STB = 0 to IBF = 1        |      | 150  | ns    | 1               |
| t <sub>SIB</sub> | RD = 1 to IBF = 0         |      | 160  | ns    | 1               |
| t <sub>RIB</sub> | RD = 0 to INTR = 0        |      | 200  | ns    | 1               |
| <sup>t</sup> RIT | STB = 1 to INTR = 1       |      | 150  | ns    | 1               |
| t <sub>SIT</sub> | ACK = 1 to INTR = 1       |      | 150  | ns    | 1 1             |
| t <sub>AIT</sub> |                           |      | 200  | ns ns | i               |
| t <sub>WIT</sub> | WR = 0 to INTR = 0        | E00  | 200  | ns    | see note 1      |
| t <sub>RES</sub> | Reset Pulse Width         | 500  |      | (4)   | 366 (10/6-1     |

Note: Period of initial Reset pulse after power-on must be at least 50usec. Subsequent Reset pulses may be 500 ns minimum.





# A.C. Test Circuits



| Test Condition | . V1 | R1           | R2      | C1     |
|----------------|------|--------------|---------|--------|
| 1              | 1.7V | 523Ω         | Open    | 150 pf |
| 2              | 5.0V | 2kΩ          | . 1.7kΩ | 50 pf  |
| 3              | 1.5V | 750 <b>Ω</b> | Open    | Open   |

TEST CONDITION DEFINITION TABLE

# **Timing Waveforms**

# MODE 0 (BASIC INPUT)



# MODE 1 (STROBED INPUT)





# UM82C55A

# **Timing Waveforms (Continued)**



# PC Mainboar

# **MODE 2 (BIDIRECTIONAL)**



Note: Any sequence where WR occurs before ACK and STB occurs before RD is permissible. (INTR = IBF • MASK • STB • RD + OBF • MASK • ACK • WR)

# WRITE TIMING



# **READ TIMING**





#### Pin Description

#### **Data Bus Buffer**

This 3-state bidirectional 8-bit buffer is used to interface the UM82C55A to the system data bus. Data is transmitted or received by the buffer upon execution of input or output instructions by the CPU. Control words and status information are also transferred through the data bus buffer.

#### Read/Write and Control Logic

The function of this block is to manage all of the internal and external transfers of both Data and Control or Status words. It accepts inputs from the CPU Address and Control buses and in turn, issues commands to both of the Control Groups.

#### (CS)

Chip Select. A "low" on this input pin enables the communication between the UM82C55A and the CPU.

#### (RD

Read. A "low" on this input pin enables the UM82C55A to send the data or status information to the CPU on the data bus. In essence, it allows the CPU to "read from" the UM82C55A,

#### (WR)

Write. A "low" on this input pin enables the CPU to write data or control words into the UM82C55A.

#### (A<sub>0</sub> and A<sub>1</sub>)

Port Select 0 and Port Select 1. These input signals, in conjunction with the  $\overline{RD}$  and  $\overline{WR}$  inputs, control the selection of one of the three ports or the control word registers. They are normally connected to the least significant bits of the address bus  $(A_0 \text{ and } A_1)$ .

#### **UM82C55A BASIC OPERATION**

| A <sub>0</sub> | Aı | RD | WR | <u>CS</u> | Input Operation (Read)   |
|----------------|----|----|----|-----------|--------------------------|
| 0              | 0  | 0  | 1  | 0         | Port A → Data Bus        |
| 0              | 1  | 0  | 1  | 0         | Port B. → Data Bus       |
| 1              | 0  | 0  | 1  | 0         | Port C → Data Bus        |
| 1              | 1  | 0  | 1  | 0         | Control Word → Data Bus  |
|                |    |    |    |           | Output Operation (Write) |
| 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         |
| х              | Х  | ×  | x  | 1         | Data Bus → 3-State       |
| · ×            | x  | 1  | 1  | 0         | Data Bus → 3-State       |



Figure 1. UM82C55A Block Diagram Data Bus Buffer and Read/Write Control Logic Functions

#### (Reset)

Reset. A "high" on this input clears the control register and all ports (A, B, C) are set to the input mode. "Bus hold" devices internal to the UM82C55A will hold the I/O port inputs to a logic "1" state with a maximum hold current of  $300~\mu\text{A}$ .

#### Group A and Group B Controls

The functional configuration of each port is programmed by the system software. In essence, the CPU "outputs" a control word to the UM82C55A. The control word contains information such as "mode", "bit set", "bit reset", etc., that initializes the functional configuration of the UM82C55A.

Each of the Control blocks (Group A and Group B) accepts "commands" from the Read/Write Control Logic, receives "control words" from the internal data bus and issues the proper commands to its associated ports.

Control Group A—Port A and Port C upper (C7-C4) Control Group B—Port B and Port C lower (C3-C0)

The control word register can be both written and read as shown in the "Basic Operation" table. Figure 4 shows the control word format for both Read and Write operations. When the control word is read, bit D7 will always be a logic "1", as this implies control word mode information.

#### Ports A, B and C

The UM82C55A contains three 8-bit ports (A, B, and C). All can be configured to a wide variety of functional characteristics by the system software but each has its own special features or "personality" to further enhance the power and flexibility of the UM82C55A.

Port A One 8-bit data output latch/buffer and one 8-bit data input latch. Both "pull-up" and "pull-down" bus-hold devices are present on Port A.



Port B One 8-bit data input/output latch/buffer and one 8-bit data input buffer.

Port C One 8-bit data output latch/buffer and one 8-bit data input buffer (no latch for input) This port can be divided into two 4-bit ports under the mode control. Each 4-bit port contains a 4-bit latch and it can be used for the control signal outputs and status signal inputs in conjunction with ports A and B.



Figure 2. UM82C55A Block Diagram Showing Group A and Group B Control Functions

# **Operational Description**

#### **Mode Selection**

There are three basic modes of operation that can be selected by the system software:

Mode 0 — Basic Input/Output Mode 1 — Strobed Input/Output Mode 2 — Bi-Directional Bus

Mode 2 — BI-Directional Bus

When the reset input goes "high", all ports will be set to
the input mode with all 24 port lines held at a logic "one"
level by internal bus hold devices. After the reset is
removed, the UM82C55A can remain in the input mode
with no additional initialization required. This eliminates
the need for pullup or pulldown resistors in all-CMOS
designs. During the execution of the system program,
any of the other modes may be selected using a single
output instruction. This allows a single UM82C55A to
service a variety of peripheral devices with a simple
software maintenance routine.

software maintenance routine.

The modes for Port A and Port B can be separately defined, while Port C is divided into two portions as required by the Port A and Port B definitions. All of the output registers, including the status flip-flops, will be reset whenever the mode is changed. Modes may be combined so that their functional definition can be "tailored" to almost any I/O structure. For instance; Group B can be programmed in Mode 0 to monitor simple switch closings or display computational results, Group A could be programmed in Mode 1 to monitor a keyboard or tape reader on an interrupt-driven basis.



Figure 3. Basic Mode Definitions and Bus Interface



Figure 4. Mode Definition Format



# UNICORN MICROELECTRONICS

T-52-33-15



# UM82C55A

The mode definitions and possible mode combinations may seem confusing at first but after a cursory review of the complete device operation a simple, logical I/O approach will surface. The design of the UM82C55A has taken into account things such as efficient PC board layout,

control signal definition vs PC layout and complete functional flexibility to support almost any peripheral device with no external logic. Such design represents the maximum use of the available pins.



Figure 5. Bit Set/Reset Format

#### Single Bit Set/Reset Feature

Any of the eight bits of Port C can be Set or Reset using a single OUT put instruction. This feature reduces software requirements in control-based applications.

When Port C is being used as status/control for Port A or B, these bits can be set or reset by using the Bit Set/Reset operation just as if they were data output ports.

#### **Interrupt Control Functions**

When the UM82C55A is programmed to operate in mode 1 or mode 2, control signals are provided that can be used as interrupt request inputs to the CPU. The interrupt request signals, generated from port C, can be inhibited or enabled by setting or resetting the associated INTE flip-flop, using the bit set/reset function of port C.

This function allows the programmer to enable or disable a CPU interrupt by a specific I/O device without affecting any other device in the interrupt structure.

#### **INTE Flip-flop Definition**

(BIT-SET) — INTE is SET — Interrupt enable. (BIT—RESET) — INTE is RESET — Interrupt disable.

Note: All Mask flip-flops are automatically reset during mode selection and device Reset.

# **Operating Modes**

Mode O (Basic Input/Output). This functional configuration provides simple input and output operations for each of the three ports. No handshaking is required, data is simply written to or read from a specific port.

#### Mode O Basic Functional Definitions:

- Two 8-bit ports and two 4-bit ports
- Any port can be input or output
- Outputs are latched
- Inputs are not latched
- 16 different Input/Output configurations possible,



# UM82C55A

# MODE 0 (BASIC INPUT)



# MODE O (BASIC OUTPUT)



# **Mode 0 Port Definition**

| Þ              | \              | E              | В              |        | up A              |    | Gro     | up B              |
|----------------|----------------|----------------|----------------|--------|-------------------|----|---------|-------------------|
| D <sub>4</sub> | D <sub>3</sub> | D <sub>1</sub> | D <sub>0</sub> | Port A | Port C<br>(Upper) | #  | Port B  | Port C<br>(Lower) |
| 0              | 0              | 0              | 0.             | Output | Output            | 0  | Output  | Output            |
| 0              | 0              | 0              | 1              | Output | Output            | 1  | Output  | Input             |
| 0              | 0              | 1              | 0              | Output | Output            | 2  | Input   | Output            |
| 0              | 0              | 1              | 1              | Output | Output            | 3  | Input   | Input             |
| 0              | 1              | 0              | 0              | Output | Input             | 4  | Output  | Output            |
| 0              | 1              | 0              | 1              | Output | Input             | 5  | Output  | Input             |
| 0              | 1              | -1             | 0              | Output | Input             | 6  | Input   | Output            |
| 0              | 1              | 1              | 1              | Output | Input             | 7  | Input   | Input             |
| 1              | 0              | 0              | 0              | Input  | Output            | 8  | Output  | Output            |
| 1              | 0              | 0              | 1              | Input  | Output            | 9  | Output  | Input             |
| 1              | 0              | 1              | 0              | Input  | Output            | 10 | Input   | Output            |
| 1              | 0              | 1              | 1              | Input  | Output            | 11 | . Input | Input             |
| 1              | 1              | 0              | 0              | Input  | Input             | 12 | Output  | Output            |
| 1              | 1              | 0              | 1              | Input  | Input             | 13 | Output  | Input             |
| 1              | 1              | 1              | 0              | Input  | Input             | 14 | Input   | Output            |
| 1              | 1              | 1              | 1              | Input  | Input             | 15 | Input   | Input             |







# **CONTROL WORD #0**

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #4**

D7 D6 D5 D4 D3 D2 D1 D0



#### **CONTROL WORD #1**

D7 D6 D5 D4 D3 D2 D1 D0



#### CONTROL WORD #5

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #2**

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #6**

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #3**

D7 D6 D5 D4 D3 D2 D1 D0



# CONTROL WORD #7

D7 D6 D5 D4 D3 D2 D1 D0



2-88



D7 D6 D5 D4 D3 D2 D1 D0



#### . CONTROL WORD #9

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #10**

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #11**

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #12**

D7 D6 D5 D4 D3 D2 D1 D0



#### **CONTROL WORD #13**

D7 D6 D5 D4 D3 D2 D1 D0



# **CONTROL WORD #14**

D7 D6 D5 D4 D3 D2 D1 D0



# CONTROL WORD #15

D7 D6 D5 D4 D3 D2 D1 D0



2-89

PC Mainboard



#### **Operating Modes**

Mode 1 (Strobed Input/Output). This functional configuration provides a means for transferring I/O data to or from a specified port in conjunction with strobes or "handshaking" signals. In mode 1, port A and port B use the lines on port C to generate or accept these "handshaking" signals.

# Mode 1 Basic Functional Definitions

- Two Groups (Group A and Group B)
- Each group contains one 8-bit port and one 4-bit control/data port.
- The 8-bit data port can be either input or output. Both inputs and outputs are latched.
- The 4-bit port is used for control and status of the 8-bit port.

# **Input Control Signal Definition**

STB (Strobe Input)

A "low" on this input loads data into the input latch,

#### IBF (Input Buffer Full F/F)

A "high" on this output indicates that the data has been loaded into the input latch; in essence, an acknowledgement. IBF is set by  $\overline{\text{STB}}$  input being low and is reset by the rising edge of the  $\overline{\text{RD}}$  input.

# **INTR (Interrupt Request)**

A "high" on this output can be used to interrupt the CPU when an input device is requesting service. INTR is set by the condition; STB is a "one", IBF is a "one" and INTE is a "one". It is reset by the falling edge of RD. This procedure allows an input device to request service from the CPU by simply strobing its data into the port.

# INTE A

Controlled by bit set/reset of PC4.

#### INTE B

Controlled by bit set/reset of PC2.

# MODE 1 (PORT A)



#### ·MODE 1 (PORT B)



Figure 6. MODE 1 Input



Figure 7. MODE 1 (Strobed Input)



T-52-33-15 UM82C55A

#### **Output Control Signal Definition**

 $\overline{\text{OBF}}$  (Output Buffer Full F/F). The OBF output will go "low" to indicate that the CPU has written data out to the specified port. The  $\overline{\text{OBF}}$  F/F will be set by the rising edge of the  $\overline{\text{WR}}$  input and reset by  $\overline{\text{ACK}}$  Input being low,

ACK (Acknowledge Input). A "low" on this input informs the UM82C55A that the data from port A or port B has been accepted. In essence, a response from the peripheral device indicating that it has received the data output by the CPU.

INTR (Interrupt Request). A "high" on this output can be used to interrupt the  $\overline{\text{CPU}}$  when an output device has accepted data transmitted by the CPU. INTR is set when  $\overline{\text{ACK}}$  is a "one", OBF is a "one" and INTE is a "one". It is reset by the falling edge of  $\overline{\text{WR}}$ .

#### INTE A

Controlled by Bit Set/Reset of PC6.

#### INTE B

Controlled by Bit Set/Reset of PC2:

# MODE 1 (PORT A)



# MODE 1 (PORT B)



Figure 8. MODE 1 Output



Figure 9. MODE 1 (Strobed Output)

UM82C55A

Combinations of MODE 1; Port A and Port B can be individually defined as input or output in Mode 1 to support a wide a variety of strobed I/O applications:



Figure 10. Combinations of MODE 1

# **Operating Modes**

#### MODE 2 (Strobed Bidirectional Bus I/O)

The functional configuration provides a means for communicating with a peripheral device or structure on a single 8-bit bus for both transmitting and receiving data (bidirectional bus I/O). "Handshaking" signals are provided to maintain proper bus flow discipline similar to MODE 1. Interrupt generation and enable/disable functions are also available.

# MODE 2 Basic Function Definitions:

- Used in Group A only.
- One 8-bit, bi-directional bus Port (Port A) and a 5-bit control Port (Port C).
- Both inputs and outputs are latched.
- The 5-bit control port (Port C) is used for control and status for the 8-bit, bi-directional bus port (Port A).

#### **Bidirectional Bus I/O Control Signal Definition**

INTR (Interrupt Request). A high on this output can be used to interrupt the CPU for both input or output operations.

# Output Operations

OBF (Output Buffer Full). The OBF output will go "low" to indicate that the CPU has written data out to port A.

ACK (Acknowledge). A "Low" on this input enables the tri-state output buffer of port A to send out the data. Otherwise, the output buffer will be in the high impedance state.

INTE 1 (The INTE Flip-Flop Associated with OBF). Controlled by bit set/reset of PC<sub>6</sub>

#### Input Operations

STB (Strobe Input). A "low" on this input loads data into the input latch.

IBF (Input Buffer Full F/F). A "high" on this output indicates that data has been loaded into the input latch.

INTE 2 (The INTE Flip-Flop Associated with IBF). Controlled by bit set/reset of PC4.

2.3

# UM82C55A



Figure 11. MODE Control Word

Figure 12. MODE 2



Figure 13. MODE 2 (Bidirectional)

Note: Any sequence where  $\overline{\text{WR}}$  occurs before  $\overline{\text{ACK}}$  and  $\overline{\text{STB}}$  occurs before RD is permissible. (INTR = IBF · MASK ·  $\overline{\text{STB}}$  ·  $\overline{\text{RD}}$  +  $\overline{\text{OBF}}$  · MASK ·  $\overline{\text{ACK}}$  ·  $\overline{\text{WR}}$ )

UM82C55A



Figure 14. MODE 2 Combinations

# **Mode Definition Summary**

|               | MODE 2                                                          | DE 1                                               | МО               | 7       | DE 0       | MC       |                                    |
|---------------|-----------------------------------------------------------------|----------------------------------------------------|------------------|---------|------------|----------|------------------------------------|
|               | Group A Only                                                    | OUT                                                | IN               | ]       | OUT        | IN       |                                    |
|               | ·                                                               | OUT                                                | IN               | 7 1     | OUT        | IN       | PA <sub>0</sub>                    |
|               | <del></del>                                                     | OUT                                                | IN               |         | OUT        | . IN     | PAi                                |
|               |                                                                 | OUT<br>OUT                                         | IN<br>IN         |         | OUT<br>OUT | IN<br>IN | PA <sub>2</sub>                    |
|               | <del>4</del>                                                    | ŏŭ†                                                | iñ l             |         | ŏŭ†        | iÑ I     | PA <sub>3</sub><br>PA <sub>4</sub> |
|               | ◄                                                               | OUT                                                | IN               | 1 1     | OUT        | IN I     | PA <sub>5</sub><br>PA <sub>6</sub> |
| •             | <del></del>                                                     | OUT                                                | IN               |         | OUT        | IN I     | PA <sub>6</sub>                    |
| <del></del> - |                                                                 | OUT                                                | IN               | -1 1    | OUT        | IN       | PA <sub>7</sub>                    |
|               |                                                                 | OUT .                                              | IN<br>IN         | 1 1     | OUT<br>OUT | IN<br>IN | PBo<br>PB <sub>1</sub>             |
| MODE 0        |                                                                 | out                                                | IN I             | 1. [    | OUT        | in       | PR <sub>a</sub>                    |
| OR MODE 1     |                                                                 | OUT                                                | IN I             | 1 1     | OUT        | IN I     | PB <sub>2</sub><br>PB <sub>3</sub> |
| ONLY          | <del></del> ; ;                                                 | QUT                                                | IN               | 1 1     | OUT        | IŅ -     | PB₄ I                              |
| J.V.L.        |                                                                 | OUT                                                | IN<br>IN         | - 1 - 1 | OUT<br>OUT | IN<br>IN | PBs<br>PB6                         |
|               | <del></del>                                                     | ŏŭt                                                | in l             | -1 1    | ŏŭ†        | ,iÑ      | PB <sub>7</sub>                    |
|               | I/O                                                             | INTRB                                              | INTRB            | 7       | OUT        | IN       | PC <sub>0</sub>                    |
|               | 1/0<br>1/0<br>1/0                                               | OBF <sub>B</sub><br>ACK <sub>B</sub>               | IRE <sub>D</sub> | li      | OUT        | IN       | PC <sub>1</sub><br>PC <sub>2</sub> |
|               | 1/0                                                             | ACKB                                               | STBB             | 1 1     | OUT        | ĮŅ.      | PC₂                                |
|               | INTRA                                                           | INTRA<br>I/O                                       | INTRA<br>STBA    | -1-1    | OUT<br>OUT | IN<br>IN | PC₃<br>PC₄                         |
|               | STB <sub>A</sub><br>IBF <sub>A</sub><br><u>ACK</u> <sub>A</sub> | i/ŏ                                                | IBF <sub>A</sub> | 1 1     | ουτ        | İN       | PC.                                |
|               | <u>ACK</u> A                                                    | <u>i/O</u><br>ACK <sub>A</sub><br>OBF <sub>A</sub> | IBFA<br>I/O      |         | OUT        | IN       | PCs<br>PC6                         |
|               | OBFA                                                            | OBFA                                               | 1/0              | _       | OUT        | IN       | PC <sub>7</sub>                    |



**GROUP B** 

#### Special Mode Combination Considerations:

There are several combinations of modes possible. For any combination, some or all of Port C lines are used for control or status. The remaining bits are either inputs or outputs as defined by a "Set Mode" command.

During a read of Port C, the state of all the Port C lines except the  $\overline{ACK}$  and  $\overline{STB}$  lines, will be placed on the data bus. In place of the  $\overline{ACK}$  and  $\overline{STB}$  line states, flag status will appear on the data bus in the PC2, PC4, and PC6 bit positions as illustrated by Figure 17.

Through a "Write Port C" command, only the Port C pins programmed as outputs in a Mode 0 group can be written. No other pins can be affected by a "Write Port C" command, nor can the interrupt enable flags be accessed. To write to any Port C output programmed as an output in a Mode 1 group or to change an interrupt enable flag, the "Set/Reset Port C Bit" command must be used,

With a "Set/Reset Port C Bit" command, any Port C line programmed as an output (including INTR, IBF and OBF) can be written, or an interrupt enable flag can be either set or reset. Port C lines programmed as inputs, including  $\overline{ACK}$  and  $\overline{STB}$  lines, associated with Port C are not affected by a "Set/Reset Port C Bit" command. Writing to the corresponding Port C bit positions of the  $\overline{ACK}$  and  $\overline{STB}$  lines with the "Set/Reset Port C Bit" command will affect the Group A and Group B interrupt enable flags, as illustrated in Figure 17.



Figure 15. MODE 1 Status Word Format

**GROUP A** 



(DEFINED BY MODE 0 OR MODE 1 SELECTION)

Figure 16. MODE 2 Status Word Format

| Interrupt Enable Flag | Position | Alternate Port C Pin Signal (Mode)                                  |
|-----------------------|----------|---------------------------------------------------------------------|
| INTE B                | PC2      | ACK <sub>B</sub> (Output Mode 1) or STB <sub>B</sub> (Input Mode 1) |
| INTE A2               | PC4      | STBA (Input Mode 1 or Mode 2)                                       |
| INTE A1               | PC6      | ACK <sub>A</sub> (Output Mode 1 or Mode 2)                          |

Figure 17. Interrupt Enable Flags in Modes 1 and 2

#### **Current Drive Capability:**

Any output on Port A, B or C can sink or source 2.5mA. This feature allows the UM82C55A to directly drive Darlington type drivers and high-voltage displays that require such sink or source current.

# Reading Port C Status

In Mode 0, Port C transfers data to or from the peripheral device. When the UM82C55A is programmed to function

in Modes 1 or 2, Port C generates or accepts "hand-shaking" signals with the peripheral device. Reading the contents of Port C allows that programmer to test or verify the "status" of each peripheral device and change the program flow accordingly.

There is no special instruction to read the status information from Port C. A normal read operation of Port C is executed to perform this function.



# Applications of the UM82C55A

The UM82C55A is a very powerful tool for interfacing peripheral equipment to the microcomputer system. It represents the optimum use of available pins and is flexible enough to interface almost any I/O device without the need for additional external logic.

Each peripheral device in a microcomputer system usually has a "service routine" associated with it. The routine manages the software interface between the device and the CPU. The functional definition of the UM82C55A is programmed by the I/O service routine and becomes an extension of the system software. By examining the I/O devices interface characteristics for both data transfer and timing, and matching this information to the examples and tables in the detailed operational description, a control word can easily be developed to initialize the UM82C55A to exactly "fit" the application. Figures 18 through 24 present a few examples of typical applications of the UM82C55A.



Figure 18. Printer Interface



Figure 19. Keyboard and Display Interface



Figure 20. Keyboard and Terminal Address Interface





Figure 21. Digital to Analog, Analog to Digital

Figure 22. Basic CRT Controller Interface



Figure 23. Basic Floppy Disk Interface



Figure 24. Machine Tool Controller Interface

2-97