# 8 ## μPD8255A PROGRAMMABLE PERIPHERAL INTERFACE ## **Description** The $\mu$ PD8255A-2 and $\mu$ PD8255A-5 are general purpose programmable input/output devices designed for use with the 8080A/8085A microprocessors. Twenty-four 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 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 bidirectional 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/8085 microprocessor families - ☐ All inputs and outputs TTL compatible - ☐ 24 programmable I/O pins - ☐ Direct bit set/reset eases control application interfaces - ☐ Eight Darlington drive outputs for printers and displays - □ LSI drastically reduces system package count #### **Ordering Information** | Part Number | Package Type | Max System<br>Clock Frequency | |-------------|--------------------|-------------------------------| | μPD8255AC-2 | 40-pin plastic DIP | 5 MHz | | μPD8255AC-5 | 40-pin plastic DIP | 4 MHz | ## Pin Configuration ### Pin Identification | No. | Symbol | Function | | |------------|----------------------------------|------------------------|--| | 1-4, 37-40 | PA <sub>7</sub> -PA <sub>0</sub> | Port A (I/O) | | | 5 | RD | Read input | | | 6 | CS | Chip select input | | | 7 | GND | Ground | | | 8,9 | A <sub>1</sub> ,A <sub>0</sub> | Port address inputs | | | 10-17 | PC <sub>7</sub> -PC <sub>0</sub> | Port C (1/0) | | | 18-25 | PB <sub>7</sub> -PB <sub>0</sub> | Port B (I/O) | | | 26 | Vcc | +5 V power supply | | | 27-34 | D <sub>7</sub> -D <sub>0</sub> | Bidirectional data bus | | | 35 | RESET | Reset input | | | 36 WR | | Write input | | #### **Pin Functions** ### D<sub>7</sub>-D<sub>0</sub> (Data Bus Buffer) These pins form a three-state, bidirectional data bus buffer that is controlled by input and output instructions executed by the processor. Control words and status information are also transmitted via D<sub>7</sub>-D<sub>0</sub>. ## **CS** (Chip Select) A low input to this pin enables the $\mu$ PD8255A for communication with the 8080A/8085A. ## RD (Read) A low input to this pin enables the μPD8255A for communication with the 8080A/8085A. ## WR (Write) A low input to this pin enables the data bus buffer to receive data or control words from the processor. ### A<sub>1</sub>, A<sub>0</sub> (Port Address) These inputs are used in conjunction with $\overline{CS}$ , $\overline{RD}$ , and $\overline{WR}$ to control the selection of one of the 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 (Reset)** A high level input to this pin clears the control register and places ports A, B, and C in input mode. The input latches in ports A, B, and C are not cleared. ## PA<sub>7</sub>-PA<sub>0</sub>, PB<sub>7</sub>-PB<sub>0</sub>, PC<sub>7</sub>-PC<sub>0</sub> (Ports A, B, and C) These three 8-bit I/O ports can be configured to meet a variety of functional requirements through system software. The effectiveness and flexibility of the $\mu$ PD8255A are further enhanced by special features unique to each of the ports, as follows: - Port A has an 8-bit data output latch/buffer, data input latch/buffer, and data input latch. - Port B has an 8-bit data I/O latch/buffer and an 8-bit data input buffer. - Port C has 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. #### Vcc +5 V power supply. ## **GND (Ground)** Connection to ground. ## **Block Diagram** ### **Functional Description** The read/write and control logic manages all internal and external transfers of data, control, and status. It is through this block that the processor address and control buses control the peripheral interfaces. Through an OUT instruction in system software from the processor, a control word is transmitted to the $\mu$ PD8255A. Information such as the mode, bit set, and bit reset is used to initialize the functional configuration of each I/O port. Both group I and group II accept commands from the read/write control logic and control words from the internal data bus and in turn controls its associated I/O ports, as follows: - 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 to, the contents cannot be read back to the processor. ## **Absolute Maximum Ratings** $T_A = 25$ °C | Operating temperature, T <sub>OPT</sub> | 0°C to +70°C | |----------------------------------------------------|-----------------| | Storage temperature, T <sub>STG</sub> | -65°C to +150°C | | Voltage on any pin with respect to V <sub>SS</sub> | -0.5 to +7 V | Comment: Stresses 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. #### **DC Characteristics** $T_A = 0 \text{ to } +70 \,^{\circ}\text{C}; V_{CC} = +5 \text{ V} \pm 10\%; V_{SS} = 0 \text{ V}$ | | | Limits | | | | |--------------------------|---------------------|--------|-----------------|------|-------------------------------------------------| | Parameter | Symbol | Min | Max | Unit | Test Conditions | | Input low voltage | V <sub>IL</sub> | -0.5 | 0.8 | ٧ | | | Input high voltage | V <sub>IH</sub> | 2 | V <sub>CC</sub> | ٧ | | | Output low voltage | V <sub>OL</sub> | | 0.45 | ٧ | (2) | | Output high voltage | V <sub>OH</sub> | 2.4 | | ٧ | (3) | | Darlington drive current | l <sub>OH</sub> (1) | -1 | -4 | mA | $V_{EXT} = 1.5 \text{ V}$ $R_{EXT} = 750\Omega$ | | Power supply current | lcc | | 120 | mA | V <sub>CC</sub> = +5 V,<br>output open | | Input leakage current | LIH | | 10 | μΑ | $V_{IN} = V = V_{CC}$ | | Input leakage current | ILIL | | 10 | μΑ | $V_{IN} = 0.4 V$ | | Output leakage current | loh | | ±10 | μΑ | $V_{OUT} = V_{CC};$ $CS = 2.0 \text{ V}$ | | Output leakage current | llol. | | -10 | μΑ | $V_{OUT} = 0.4 \text{ V};$<br>CS = 2.0 V | #### Note: - (1) Any set of eight outputs from either port A, B, C can source 4 mA into 1.5 V. - (2) $I_{OL}$ = 2.5 mA for DB port; 1.7 mA for peripheral ports. - (3) $I_{OH} = -400\mu A$ for DB port; $-200 \mu A$ for peripheral ports. #### Capacitance $T_A = 25$ °C; $V_{CC} = 0$ V | Parameter | | Li | imits | | Test<br>Conditions | |-------------------|-----------------|-----|-------|------|---------------------------------------------| | | Symbol | Min | Max | Unit | | | Input capacitance | CI | | 10 | ρF | f <sub>c</sub> = 1 MHz | | I/O capacitance | C <sub>IO</sub> | | 20 | pF | Unmeasured pins returned to V <sub>SS</sub> | ## **AC Characteristics** $T_A$ = 0°C to +70°C; $V_{CC}$ = +5 V ±5%; $V_{SS}$ = 0 V | Parameter | | | 5A-2<br>nits | | 5A-5<br>nits | | Test | |------------------------------------------|------------------|-----|--------------|-----|--------------|----------|---------------------------------------------| | | Symbol | Min | Max | Min | Max | Unit | Conditions | | Address stable before READ | t <sub>AR</sub> | 0 | | 0 | | ns | | | Address stable after READ | t <sub>RA</sub> | 0 | | 0 | | ns | · · · · · · · · · · · · · · · · · · · | | READ pulse width | t <sub>RR</sub> | 200 | | 250 | | ns | | | Data valid from READ | t <sub>RD</sub> | | 140 | | 170 | ns | C <sub>L</sub> = 150 pF | | Data float after READ | t <sub>DF</sub> | 10 | 100 | 10 | 100 | ns<br>ns | $C_L = 100 pF$ $C_L = 15 pF$ | | Time between READS and /WRITES | t <sub>RV</sub> | 200 | | 850 | | ns | (Note 2) | | Write | | | | | | | | | Address stable before WRITE | t <sub>AW</sub> | 0 | | 0 | | ns | | | Address stable after WRITE | t <sub>WA</sub> | 20 | | 20 | | ns | | | WRITE pulse width | tww | 200 | | 250 | | ns | | | Data valid to WRITE (T.E.) | t <sub>DW</sub> | 100 | | 100 | | ns | | | Data valid after WRITE | t <sub>WD</sub> | 0 | | 0 | | ns | | | Other Timing | | | | | | | | | WR = 0 to output | t <sub>WB</sub> | | 350 | - | 350 | ns | C <sub>L</sub> = 150 pF | | Peripheral data before RD | t <sub>IR</sub> | 0 | | 0 | | ns | | | Peripheral data after RD | t <sub>HR</sub> | 0 | | 0 | | ns | | | ACK pulse width | t <sub>AK</sub> | 300 | _ | 300 | | ns | | | STB pulse width | tst | 350 | | 350 | | ns | | | Per. data before T.E. of STB | tps | 0 | | 0 | | ns | | | Per. data after T.E. of STB | t <sub>PH</sub> | 150 | | 150 | | ns | | | ACK = 0 to output | tad | | 300 | | 300 | ns | C <sub>L</sub> = 150 pF | | ACK = 0 to output float | t <sub>KD</sub> | 20 | 250 | 20 | 250 | ns | $C_L = 50 \text{ pF}$ $C_L = 15 \text{ pF}$ | | $\overline{WR} = 1 \text{ to } OBF = 0$ | t <sub>WOB</sub> | | 300 | | 650 | ns | | | $\overline{ACK} = 0$ to $OBF = 1$ | t <sub>AOB</sub> | | 350 | | 350 | ns | | | $\overline{STB} = 0 \text{ to } IBF = 1$ | t <sub>SIB</sub> | | 300 | | 300 | ns | | | RD = 1 to IBF = 0 | t <sub>RIB</sub> | | 300 | | 300 | ns | | | $\overline{RD} = 0$ to $INTR = 0$ | t <sub>RIT</sub> | | 400 | | 400 | ns | | | STB = 1 to INTR = 1 | t <sub>SIT</sub> | | 300 | | 300 | ns | $C_L = 150 \text{ pF}$ | | ACK = 1 to INTR = 1 | tAIT | | 350 | | 350 | ns | | | $\overline{WR} = 0 \text{ to INTR} = 0$ | t <sub>WIT</sub> | | 450 | _ | 850 | ns | $C_L = 150 pF$ (Note 3 | #### Note: (1) Period of reset pulse must be at least 50 $\mu s$ during or after power on. Subsequent reset pulse can be 500 ns min. (3) INTRt may occur as early as WR↓. ## AC Testing Load Circuit ## **Timing Waveforms** ## AC Testing Input, Output Waveform #### Mode 0 www.agelectronica.com www.agelectronica.com ## **Timing Waveforms (cont)** ### Mode 1 ## **Timing Waveforms (cont)** ### Mode 2 8 #### Modes The $\mu$ PD8255A can be operated in modes 0, 1 or 2 which are selected by appropriate control words and are detailed below. #### Mode 0 Mode 0 provides basic input and output operations through each of the ports A, B, and C. Output data is latched and input data follows the peripheral. No "handshaking" strobes are needed. - 16 different configurations in mode 0 - Two 8-bit ports and two 4-bit ports - Inputs are not latched - Outputs are latched #### Mode 1 Mode 1 provides for strobed input and output operations with data transferred through port A or B and handshaking through port C. - Two I/O groups (I and II) - Both groups contain an 8-bit data port and a 4-bit control/data port - Both 8-bit data ports can be either latched input or latched output #### Mode 2 Mode 2 provides for strobed bidirectional operation using PA $_0$ PA $_7$ as the bidirectional latched data bus. PC $_3$ PC $_7$ is used for interrupts and "handshaking" bus flow control similar to mode 1. Note that PB $_0$ PB $_7$ and PC $_0$ PC $_2$ may be defined as mode 0 or 1, input or output in conjunction with port A in mode 2. - An 8-bit latched bidirectional bus port (PA₀-PA₂) and a 5-bit control port (PC₃PC₂) - Both inputs and outputs are latched - An additional 8-bit input or output port with a 3-bit control port. ## **Basic Operation** #### Input Operation (Read) | Aı | A <sub>0</sub> | RD | WR | CS | | |----|----------------|----|----|----|-------------------| | 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 | #### **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 →<br>HIGH Z STATE | | Х | Х | 1 | 1 | 0 | DATA BUS →<br>HIGH Z STATE | #### Note: - (1) X means "DO NOT CARE" - (2) All conditions not listed are illegal and should be avoided. ### **Formats** ## Mode Definition, Bit/Rest Format