

## Lecture 07: 8255 PPI Chip

8255

# Reference Book: The 80x86 IBM PC and Compatible Computers

---

## Chapter 11.4 8255 PPI Chip



**PPI: Programmable Parallel Interface (so it is an I/O module)**



# Recall in Lecture 02: I/O Module Diagram

Systems Bus Interface

CPV

Data  
Lines

Address  
Lines

control  
Lines



External Device Interface

Device



SRAM

# Package & Internal Structure



# Internal Structure and Pins

---

- Three data ports: A, B, and C
  - Port A ( $PA_0 \sim PA_7$ ): can be programmed **all** as input/output
  - Port B ( $PB_0 \sim PB_7$ ): can be programmed **all** as input/output
  - Port C ( $PC_0 \sim PC_7$ ): can be split into two separate parts PCU and PCL; any bit can be programmed **individually**
- Control register (CR)
  - Internal register: used to setup the chip
- Group A, Group B and control logic
  - Group A ( $PA$  &  $PCU$ )
  - Group B ( $PB$  &  $PCL$ )

# Internal Structure and Pins

## Data bus buffer

- | An interface between CPU and 8255
- | Bidirectional, tri-state, 8-bit



| $\sim CS$ | $A_1$ | $A_0$ | $\sim RD$ | $\sim WR$ | Function                |
|-----------|-------|-------|-----------|-----------|-------------------------|
| 0         | 0     | 0     | 0         | 1         | PA->Data bus            |
| 0         | 0     | 1     | 0         | 1         | PB->Data bus            |
| 0         | 1     | 0     | 0         | 1         | PC->Data bus            |
| 0         | 0     | 0     | 1         | 0         | Data bus->PA            |
| 0         | 0     | 1     | 1         | 0         | Data bus->PB            |
| 0         | 1     | 0     | 1         | 0         | Data bus->PC            |
| 0         | 1     | 1     | 1         | 0         | Data bus->CR            |
| 1         | x     | x     | 1         | 1         | $D_0 \sim D_7$ in float |

(1)

(2)

# Operation Modes

## Input/output modes

### Mode 0, simple I/O mode:

- | **PA, PB, PC**: PCU{PC<sub>4</sub>~PC<sub>7</sub>}, PCL{PC<sub>0</sub>~PC<sub>3</sub>}
- | **No Handshaking**: *negotiation between two entities before communication*
- | Each port can be programmed as input/output port

### Mode 1:

- | **PA, PB** can be used as input/output ports with *handshaking*
- | **PCU{PC<sub>3</sub>~PC<sub>7</sub>}, PCL{PC<sub>0</sub>~PC<sub>2</sub>}** are used as handshake lines for PA and PB, respectively

### Mode 2:

- | Only **PA** can be used for *bidirectional handshake* data transfer
- | **PCU{PC<sub>3</sub>~PC<sub>7</sub>}** are used as handshake lines for PA

## Bit set/reset (BSR) mode

- | Only **PC** can be used as output port
- | Each line of PC can be set/reset individually

# Control Register & Op. Modes

## Control Register

| A 8-bit internal register in 8255

| Selected when  $A_1=1, A_0=1$

| Mode selection word

| Input/output modes



| BSR mode



8255

Command

Byte

Encoding

# Select Input/output Modes

---

## ■ Input/output modes



# Select Input/output Modes

## Input/output modes



# Select Input/output Modes

---

## Input/output modes



# Select Input/output Mode Examples

---

- 1. Write ASM instructions for setting the 8255 in simple I/O mode with PA and PB being output port and PC being input port.

```
MOV AL, 10001001B  
MOV DX, ControlPort  
OUT DX, AL
```

- 2. Assume that the address of the control register of the 8255 is 63H, give out the instructions that set up the 8255 in mode 0 where PA, PB and PCU are used as input ports and PCL is used as output port.

```
MOV AL, 10011010B  
OUT 63H, AL
```

10011010

# Select BSR Mode

---

## ■ BSR Mode



# Select BSR Mode Examples

- Assume PC is used as an output port which connects to 8 LED segments, now turn off the second LED segment with the rest unchanged (e.g., for LED segments in this case, 1-on, 0-off).



- Using BSR mode instead:

0.02

```
MOV AL, 00000010B
OUT ControlPort, AL
```

A<sub>1</sub> A<sub>0</sub>  
[ ]

# Select BSR Mode Examples

- Assume the address range for a 8255 is 60H~63H, PC<sub>5</sub> is outputting a low level, write code to generate a positive pulse.

```
MOV AL, 00001011B ; set PC5 high level
OUT 63H, AL
-
MOV AL, 00001010B ; set PC5 low level
OUT 63H, AL
```



# Mode 0 (Simple I/O)

---

- For simple input/output scenario
  - No handshaking needed
  - Any port of PA, PB and PC (PCU, PCL) can be programmed as input or output port independently
  - PCU=PC<sub>4</sub>~PC<sub>7</sub>, PCL=PC<sub>0</sub>~PC<sub>3</sub>
  - CPU directly read from or write to a port using IN and OUT instructions
  - Input data are **not** latched, Output data are latched
  - E.g., setting up the control register for Mode 0



8088

# Mode 0 Example

The 8255 shown in Figure 11-13 is configured as follows: port A as input, B as output, and all the bits of port C as output.

- (a) Find the port addresses assigned to A, B, C, and the control register.
- (b) Find the control byte (word) for this configuration.
- (c) Program the ports to input data from port A and send it to both ports B and C.

8255

**Solution:**

- (a) The port addresses are as follows:

| CS         | A1 | A0 | Address |
|------------|----|----|---------|
| 11 0001 00 | 0  | 0  | 310H    |
| 11 0001 00 | 0  | 1  | 311H    |
| 11 0001 00 | 1  | 0  | 312H    |
| 11 0001 00 | 1  | 1  | 313H    |



- (b) The control word is 90H, or 1001 0000.

- (c) One version of the program is as follows:

```

MOV AL,90H      ;control byte PA=in, PB=out, PC=out
MOV DX,313H     ;load control reg address
OUT DX,AL       ;send it to control register
MOV DX,310H     ;load PA address
IN  AL,DX       ;get the data from PA
MOV DX,311H     ;load PB address
OUT DX,AL       ;send it to PB
MOV DX,312H     ;load PC address
OUT DX,AL       ;and to PC

```

Figure 11-13

# Mode 1 (Strobe I/O)

## For handshake input/output scenario

- | PA and PB can be used as input or output ports
- | PC<sub>3</sub>~PC<sub>5</sub> used as handshake lines for PA
- | PC<sub>0</sub>~PC<sub>2</sub> used as handshake lines for PB
- | Both input and output data are latched

# Mode 1: As Input Ports



- PC<sub>3</sub>~PC<sub>5</sub> and PC<sub>0</sub>~PC<sub>2</sub> are used as handshake lines for PA and PB, respectively
  - ■ ~STB: the strobe *input* signal from input device loads data into the port latch
  - ■ IBF: Input Buffer Full output signal to the device indicates that the input latch contains information (can also be used for programmed I/O)
  - ■ INTR: Interrupt request is an output to CPU that requests an interrupt (for interrupted I/O)
- PC<sub>6</sub> and PC<sub>7</sub> can be used as separate I/O lines for any purpose
  - 7 ■ **INTE**: the interrupt enable signal is neither an input nor an output; it is an internal bit programmed via the PC<sub>4</sub> (port A) or PC<sub>2</sub> (port B); 1-allowed, 0-forbidden



# Mode 1: As Input Ports

## Control register



Indicates  
Group A  
Mode 1

PA: Input

PC<sub>6</sub>, PC<sub>7</sub>:  
1-input  
0-output



Indicates  
Group B  
Mode 1

PB: Input

## PC stores all status information



I/O Device handshaking

8255E

# Timing in Mode 1 Input

- Input device first puts data on  $PA_0 \sim PA_7$ , then activates  $\sim STB_A$ , data is latched in Port A;
- 8255 activates  $IBF_A$  which indicates the device that the input latch contains information but CPU has not taken it yet. So device cannot send new data until  $IBF_A$  is cleared;
- When  $IBF_A$ ,  $\sim STB_A$  and  $INTE_A$  are all high, 8255 activates  $INTR_A$  to inform CPU to take data in PA by interruption;
- CPU responds to the interruption and read in data from PA; the  $\sim RD$  signal will clear  $INTR_A$  signal;
- After CPU finishes reading data from PA (i.e.,  $\sim RD$  signal goes high), the  $IBF_A$  signal is cleared.



# Timing in Mode 1 Input

---





# Mode 1: As Output Ports

- **PC<sub>3</sub>, PC<sub>6</sub>, PC<sub>7</sub>** and **PC<sub>0</sub>~PC<sub>2</sub>** are used as handshake lines for **PA** and **PB**, respectively
  - **$\sim\text{OBF}$** : Output buffer full is an output signal that indicates the data has been latched in the port
  - **$\sim\text{ACK}$** : The acknowledge input signal indicates that the external device has taken the data
  - **INTR**: Interrupt request is an output to CPU that requests an interrupt
- **PC<sub>4</sub>** and **PC<sub>5</sub>** can be used as separate I/O lines for any purpose
- **INTE**: the interrupt enable signal is neither an input nor an output; it is an internal bit programmed via the **PC<sub>6</sub>** (port A) or **PC<sub>2</sub>** (port B); 1-allowed, 0-forbidden



# Mode 1: As Output Ports

## Control register



## PC stores all status information



# Timing in Mode 1 Output

---

- If  $\text{INTR}_A$  active, CPU responds to the interruption and writes data to PA and clears the  $\text{INTR}_A$  signal;
- When data has been latched in PA, 8255 activates  $\sim\text{OBF}_A$  which informs the output device to pick up data;
- After the output device has taken the data, it sends  $\sim\text{ACK}_A$  signal to 8255 which indicates that the device has received the data, and also makes  $\sim\text{OBF}_A$  go high, indicating CPU can write new data to 8255;
- When  $\sim\text{OBF}_A$ ,  $\sim\text{ACK}_A$  and  $\text{INTE}_A$  are all high, 8255 sends an  $\text{INTR}_A$  to inform CPU to write new data to PA by interruption.

# Timing in Mode 1 Output

---



# Mode 2 (Bidirectional Bus)

---

- For **bidirectional handshake** input/output scenario
  - Only PA can be used as *both input and output port*
  - PCU=PC<sub>3</sub>~PC<sub>7</sub>, used as handshake lines for PA
  - Both input and output data are latched

# Mode 2: As Input & Output Port

- $\text{PC}_3 \sim \text{PC}_7$  are used as handshake lines for PA
- $\sim\text{OBF}_A, \sim\text{ACK}, \text{IBF}_A, \sim\text{STB}_A, \text{INTR}_A$  5
- $\text{PC}_0 \sim \text{PC}_2$  can be used as separate I/O lines for any purpose, or as handshake lines for PB → mode 0
- When CPU responds to an interrupt of 8255 working in Mode 2, the interrupt handler has to check the  $\sim\text{OBF}_A$  and  $\text{IBF}_A$  in order to tell whether the input process or the output process is generating the interrupt.



# Mode 2: As Input & Output Port

## Control register



## PC stores all status information



# ~~polling~~ vs. Interruptions

- In Mode 1 and 2, PC stores status of Group A and/or Group B
- By reading from PC using IN instruction, you can use polling method to check the state of I/O devices



# Programming with 8255

- As shown in the figure, PA and PB of the 8255 are working in mode 0. PA used as input port connects to 4 switches, and PB used as output port connects to a 7-segment LED. Write a program to display a hex digit that the switches can represent.





# Address Decoding

- What are the addresses of ports and the control register?

| A <sub>19</sub> | A <sub>18</sub> | A <sub>17</sub> | A <sub>16</sub> | A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>11</sub> | A <sub>10</sub> | A <sub>9</sub> | A <sub>8</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> |   |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|
| 0               | 0               | 0               | 0               | 1               | 0               | 0               | 0               | 0               | 0               | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0 |

- PA : 8020H
- PB : ?
- PC : ?
- CR : ?

# A Solution Program

---

```
A_PORT EQU 8020H
B_PORT EQU 8022H
C_PORT EQU 8024H
CTRL_PORT EQU 8026H

DATA SEGMENT
    TAB1 DB C0H, F9H, C4H, ..., 0DH
DATA ENDS

CODE SEGMENT
    ASSUME CS:CODE, DS:DATA
START: MOV AX, DATA
        MOV DS, AX
```

256 → 255

array[16]

# A Solution Program

```
MOV AL, 90H ; Set up the mode of 8255
MOV DX, CTRL_PORT
OUT DX, AL

ADD1: MOV DX, A_PORT
IN AL, DX ; read the status of switches
AND AL, 0FH
MOV BX, OFFSET TAB1
XLAT
AL <- array[AL]
MOV DX, B_PORT ; output to LED
OUT DX, AL

MOV CX, 0600H ; delay for lighting the LED
ADD2: LOOP ADD2
JMP ADD1

CODE ENDS
END START
```

# Experiment 2

0-9 A-F

7-Segment

