

# Programmable Peripheral Interface-8255

The 8255 is a general purpose programmable I/O device used for parallel data transfer. It has 24 I/O pins which can be grouped in three 8-bit parallel ports : Port A, Port B and Port C. The eight bits of port C can be used as individual bits or be grouped in two 4-bit ports :  $C_{upper}$  ( $C_U$ ) and  $C_{lower}$  ( $C_L$ ).

The 8255, primarily, can be programmed in two basic modes : Bit Set/Reset (BSR) mode and I/O mode. The BSR mode is used to set or reset the bits in port C. The I/O mode is further divided into three modes :

Mode 0 : Simple Input/Output

Mode 1 : Input/Output with handshake

Mode 2 : Bi-directional I/O data transfer

The function of I/O pins (input or output) and modes of operation of I/O ports can be programmed by writing proper control word in the control word register. Each bit in the control word has a specific meaning and the status of these bits decides the function and operating mode of the I/O ports.

## 7.1 Features of 8255A

1. The 8255A is a widely used, programmable, parallel I/O device.
2. It can be programmed to transfer data under various conditions, from simple I/O to interrupt I/O.
3. It is compatible with all Intel and most other microprocessors.
4. It is completely TTL compatible.
5. It has three 8-bit ports : Port A, Port B, and Port C, which are arranged in two groups of 12 pins. Each port has an unique address, and data can be read from or written to a port. In addition to the address assigned to the three ports, another address is assigned to the control register into which control words are written for programming the 8255 to operate in various modes.
6. Its bit set/reset mode allows setting and resetting of individual bits of Port C.
7. The 8255 can operate in 3 I/O modes : (i) Mode 0, (ii) Mode 1, and (iii) Mode 2.

- a) In Mode 0, Port A and Port B can be configured as simple 8-bit input or output ports without handshaking. The two halves of Port C can be programmed separately as 4-bit input or output ports.
- b) In Mode 1, two groups each of 12 pins are formed. Group A consists of Port A and the upper half of Port C while Group B consists of Port B and the lower half of Port C. Ports A and B can be programmed as 8-bit Input or Output ports with three lines of Port C in each group used for handshaking.
- c) In Mode 2, only Port A can be used as a bidirectional port. The handshaking signals are provided on five lines of Port C ( $PC_3 - PC_7$ ). Port B can be used in Mode 0 or in Mode 1.
8. All I/O pins of 8255 has 2.5 mA DC driving capacity (i.e. sourcing current of 2.5 mA).

## 7.2 Pin Diagram

Fig. 7.1 shows the pin diagram of 8255.



Fig. 7.1 Pin diagram of 8255A

| Pin Symbols                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>0</sub> -D <sub>7</sub> (Data Bus) | These bi-directional, tri-state data bus lines are connected to the system data bus. They are used to transfer data and control word from microprocessor 8085 to 8255 or to receive data or status word from 8255 to the 8085.                                                                                                                                                                                                                                |
| PA <sub>0</sub> -PA <sub>7</sub> (Port A) | These 8-bit bi-directional I/O pins are used to send data to output device and to receive data from input device. It functions as an 8-bit data output latch/buffer, when used in output mode and an 8-bit data input buffer, when used in input mode.                                                                                                                                                                                                        |
| PB <sub>0</sub> -PB <sub>7</sub> (Port B) | These 8-bit bi-directional I/O pins are used to send data to output device and to receive data from input device. It functions as an 8-bit data, output latch/buffer when used in output mode and an 8-bit data input buffer, when used in input mode.                                                                                                                                                                                                        |
| PC <sub>0</sub> -PC <sub>7</sub>          | These 8-bit bi-directional I/O pins are divided into two groups PC <sub>L</sub> (PC <sub>3</sub> -PC <sub>0</sub> ) and PC <sub>U</sub> (PC <sub>7</sub> -PC <sub>4</sub> ). These groups individually can transfer data in or out when programmed for simple I/O, and used as handshake signals when programmed for handshake or bi-directional modes.                                                                                                       |
| RD (Read)                                 | When this pin is low, the CPU can read the data in the ports or the status word, through the data buffer.                                                                                                                                                                                                                                                                                                                                                     |
| WR (Write)                                | When this input pin is low, the CPU can write data on the ports or in the control register through the data bus buffer.                                                                                                                                                                                                                                                                                                                                       |
| CS (Chip Select)                          | This is an active low input which can be enabled for data transfer operation between the CPU and the 8255.                                                                                                                                                                                                                                                                                                                                                    |
| RESET                                     | This is an active high input used to reset 8255. When RESET input is high, the control register is cleared and all the ports are set to the input mode. Usually RESET OUT signal from 8085 is used to reset 8255.                                                                                                                                                                                                                                             |
| A <sub>0</sub> and A <sub>1</sub>         | These input signals along with RD and WR inputs control the selection of the control/status word registers or one of the three ports. Table 7.1 summarizes the status of A <sub>0</sub> , A <sub>1</sub> , CS, RD and WR to access the control word/ports. A <sub>0</sub> and A <sub>1</sub> are generally connected to the A <sub>0</sub> , A <sub>1</sub> pins of the address bus; the 8255 therefore occupies four consecutive locations in the I/O space. |

| Operations               |   |   |   |   |                              |
|--------------------------|---|---|---|---|------------------------------|
| Input (Read) operation   |   |   |   |   |                              |
| 0                        | 0 | 0 | 1 | 0 | Port A to Data Bus           |
| 0                        | 1 | 0 | 1 | 0 | Port B to Data Bus           |
| 1                        | 0 | 0 | 1 | 0 | Port C to Data Bus           |
| Output (Write) operation |   |   |   |   |                              |
| 0                        | 0 | 1 | 0 | 0 | Data Bus to Port A           |
| 0                        | 1 | 1 | 0 | 0 | Data Bus to Port B           |
| 1                        | 0 | 1 | 0 | 0 | Data Bus to Port C           |
| 1                        | 1 | 1 | 0 | 0 | Data Bus to Control Register |

|   |   |   |   |   |                     |
|---|---|---|---|---|---------------------|
| X | X | X | X | 1 | Disable function    |
| 1 | 1 | 0 | 1 | 0 | Data Bus Tri-stated |
| X | X | 1 | 1 | 0 | Illegal Condition   |
|   |   |   |   |   | Data Bus Tri-stated |

Table 7.1 Port and register select signals summary

### 7.3 Block Diagram

Fig. 7.2 shows the internal block diagram of 8255A. It consists of data bus buffer, control logic and Group A and Group B controls.



Fig. 7.2 Block diagram of 8255A

### 7.3.1 Data Bus Buffer

This tri-state bi-directional buffer is used to interface the internal data bus of 8255 to the system data bus. Input or Output instructions executed by the CPU either Read data from, or Write data into the buffer. Output data from the CPU to the ports or control register, and input data to the CPU from the ports or status register are all passed through the buffer.

### 7.3.2 Control Logic

The control logic block accepts control bus signals as well as inputs from the address bus, and issues commands to the individual group control blocks (Group A control and Group B control). It issues appropriate enabling signals to access the required data/control words or status word. The input pins for the control logic section are described here.

### 7.3.3 Group A and Group B Controls

Each of the Group A and Group B control blocks receives control words from the CPU and issues appropriate commands to the ports associated with it. The Group A control block controls Port A and PC<sub>7</sub>-PC<sub>4</sub> while the Group B control block controls Port B and PC<sub>3</sub>-PC<sub>0</sub>.

**Port A :** This has an 8-bit latched and buffered output and an 8-bit input latch. It can be programmed in three modes: mode 0, mode 1 and mode 2.

**Port B :** This has an 8-bit data I/O latch/buffer and an 8-bit data input buffer. It can be programmed in mode 0 and mode 1.

**Port C :** This has one 8-bit unlatched input buffer and an 8-bit output latch/buffer. Port C can be separated into two parts and each can be used as control signals for ports A and B in the handshake mode. It can be programmed for bit set/reset operation.

## 7.4 Operation Modes

### 7.4.1 Bit Set-Reset (BSR) Mode

The individual bits of Port C can be set or reset by sending out a single OUT instruction to the control register. When Port C is used for control/status operation, this feature can be used to set or reset individual bits.

## 7.4.2 I/O Modes

### Mode 0 : Simple input /output

In this mode, ports A and B are used as two simple 8-bit I/O ports and Port C as two 4-bit ports. Each port (or half - port, in case of C) can be programmed to function as simply an input port or an output port. The input/output features in Mode 0 are as follows :

1. Outputs are latched.
2. Inputs are buffered, not latched.
3. Ports do not have handshake or interrupt capability.

### Mode 1 : Input /Output with handshake

In this mode, input or output data transfer is controlled by handshaking signals. Handshaking signals are used to transfer data between devices whose data transfer speeds

are not same. For example, computer can send data to the printer with large speed but printer can't accept data and print data with this rate. So computer has to send data with the speed with which printer can accept. This type of data transfer is achieved by using handshaking signals alongwith data signals. Fig. 7.3 shows data transfer between computer and printer using handshaking signals.



**Fig. 7.3 Data transfer between computer and printer using handshaking signals**

These handshaking signals are used to tell computer whether printer is ready to accept the data or not. If printer is ready to accept the data then after sending data on data bus, computer uses another handshaking signal (STB) to tell printer that valid data is available on the data bus.

The 8255 mode 1 which supports handshaking has following features.

1. Two ports (A and B) function as 8-bit I/O ports. They can be configured either as input or output ports.
2. Each port uses three lines from Port C as handshake signals. The remaining two lines of Port C can be used for simple I/O functions.
3. Input and output data are latched.
4. Interrupt logic is supported.

### Mode 2 : Bi-directional I/O data transfer

This mode allows bi-directional data transfer (transmission and reception) over a single 8-bit data bus using handshaking signals. This feature is available only in Group A with Port A as the 8-bit bidirectional data bus; and  $PC_3 - PC_7$  are used for handshaking purpose. In this mode, both inputs and outputs are latched. Due to use of a single 8-bit

data bus for bi-directional data transfer, the data sent out by the CPU through Port A appears on the bus connecting it to the peripheral, only when the peripheral requests it. The remaining lines of Port C i.e. PC<sub>0</sub>-PC<sub>2</sub> can be used for simple I/O functions. The Port B can be programmed in mode 0 or in mode 1. When Port B is programmed in mode 1, PC<sub>0</sub>-PC<sub>2</sub> lines of Port C are used as handshaking signals.

## 7.5 Control Word Formats

A high on the RESET pin causes all 24 lines of the three 8-bit ports to be in the input mode. All flip-flops are cleared and the interrupts are reset. This condition is maintained even after the RESET goes low. The ports of the 8255 can then be programmed for any other mode by writing a single control word into the control register, when required.

### 7.5.1 For Bit Set/Reset Mode

Fig. 7.4 shows bit set/reset control word format.



Fig. 7.4 Bit set/reset control word format

The eight possible combinations of the states of bits D<sub>3</sub> - D<sub>1</sub> (B<sub>2</sub> B<sub>1</sub> B<sub>0</sub>) in the Bit Set-Reset format (BSR) determine particular bit in PC<sub>0</sub> - PC<sub>7</sub> being set or reset as per the status of bit D<sub>0</sub>. A BSR word is to be written for each bit that is to be set or reset. For example, if bit PC<sub>3</sub> is to be set and bit PC<sub>4</sub> is to be reset, the appropriate BSR words that will have to be loaded into the control register will be, 0×××0111 and 0×××1000, respectively, where X is don't care.

The BSR word can also be used for enabling or disabling interrupt signals generated by Port C when the 8255 is programmed for Mode 1 or 2 operation. This is done by setting or resetting the associated bits of the interrupts. This is described in detail in next section.

### 7.5.2 For I/O Mode

The mode definition format for I/O mode is shown in Fig. 7.5. The control words for both, mode definition and Bit Set-Reset are loaded into the same control register, with bit D<sub>7</sub> used for specifying whether the word loaded into the control register is a mode definition word or Bit Set-Reset word. If D<sub>7</sub> is high, the word is taken as a mode definition word, and if it is low, it is taken as a Bit Set-Reset word. The appropriate bits are set or reset depending on the type of operation desired, and loaded into the control register.



Fig. 7.5 8255 Mode definition format