# **Basic I/O Interface**

CEN433 King Saud University Dr. Mohammed Amer Arafah

## **I/O Instructions**

- Two types:
  - Transfer data between the processor accumulator (AL, AX, EAX) register and I/O device: IN and OUT
  - Transfer string data between memory and I/O device *directly*. INS and OUTS (for processors above 8086)

#### IN & OUT:

- The IN instruction (I/O Read): Inputs data from an external I/O device to the accumulator.
- The OUT instruction (I/O Write): Copies the contents of the accumulator out to an external I/O device.
- The accumulator is:
  - $\Box$  AL (for 8-bit I/O),
  - $\Box$  AX (for 16-bit I/O),
  - $\Box$  EAX (for 32-bit I/O).

### **I/O Addresses**

- As with memory, I/O devices have I/O addresses (addresses for the I/O port)
- Up to 64K I/O bytes can be addressed
- The 16-bit port address appears on address bus bits A15-A0 This allows I/O devices at addresses 0000H-FFFFH



A 16-bit address located in register DX. For example: "O space
OUT DX, AL ; Outputs the byte in AL to the port whose address is in DX
0000H-FFFFH (upto 64K addresses).

i.e. High port addresses are accessible only through DX addressing

FFFF

### **I/O Addresses**

- As with memory, I/O ports are also organized as bytes
- A port can be 1, 2, or 4 bytes wide



### **I/O Instructions**

| Instruction | Data Width | Function                                                                                                                                    |  |  |
|-------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| IN AL, p8   | 8          | A byte is input into AL from port p8                                                                                                        |  |  |
| IN AX, p8   | 16         | A word is input into AX from port p8                                                                                                        |  |  |
| IN EAX, p8  | 32         | A doubleword is input into EAX from port p8                                                                                                 |  |  |
| IN AL, DX   | 8          | A byte is input into AL from the port addressed by DX                                                                                       |  |  |
| IN AX, DX   | 16         | A word is input into AX from the port addressed by DX                                                                                       |  |  |
| IN EAX, DX  | 32         | A doubleword is input into EAX from the port addressed by DX                                                                                |  |  |
| INSB        | 8          | A byte is input from the port addressed by DX and stored into the extra segment memory location addressed by DI, then $DI = DI \pm 1$       |  |  |
| INSW        | 16         | A word is input from the port addressed by DX and stored into the extra segmer memory location addressed by DI, then $DI = DI \pm 2$        |  |  |
| INSD        | 32         | A doubleword is input from the port addressed by DX and stored into the extra segment memory location addressed by DI, then $DI = DI \pm 4$ |  |  |
| OUT p8, AL  | 8          | A byte is output from AL into port p8                                                                                                       |  |  |
| OUT p8, AX  | 16         | A word is output from AL into port p8                                                                                                       |  |  |
| OUT p8, EAX | 32         | A doubleword is output from EAX into port p8                                                                                                |  |  |
| OUT DX, AL  | 8          | A byte is output from AL into the port addressed by DX                                                                                      |  |  |
| OUT DX, AX  | 16         | A word is output from AX into the port addressed by DX                                                                                      |  |  |
| OUT DX, EAX | 32         | A doubleword is output from EAX into the port addressed by DX                                                                               |  |  |
| OUTSB       | 8          | A byte is output from the data segment memory location addressed by SI into the port addressed by DX, then SI = SI $\pm$ 1                  |  |  |
| OUTSW       | 16         | A word is output from the data segment memory location addressed by SI into the port addressed by DX, then SI = SI $\pm$ 2                  |  |  |
| OUTSD       | 32         | A doubleword is output from the data segment memory location addressed by SI into the port addressed by DX, then SI = SI $\pm$ 4            |  |  |

## Isolated vs. Memory Mapped I/O

- I/O can be either:
  - □ Isolated, or
  - Memory mapped
- Isolated I/O: uses the dedicated I/O instructions (IN, OUT and INS, OUTS) and has its own address space for I/O ports (0000H-FFFFH)- isolated from the memory address space
- Memory mapped I/O: uses memory reference instructions, e.g. MOV, and a region of the memory address map. So address space is shared between memory and I/O (used by only one of them)
- Both techniques can be used with Intel processors
- But most Intel-based systems e.g. the PC, use isolated I/O
- Some other processors do not have dedicated I/O instructions and therefore use only memory-mapped I/O addressing, e.g. the PowerPC microprocessor (Macintosh computers)

### Isolated vs. Memory Mapped I/O



#### Memory-Mapped I/O

CEN433 - King Saud University

FFFFF

### Isolated I/O



## The PC I/O space

- The PC I/O space mainly exists at locations below I/O port 0400H
- Main board devices appear at addresses 0000H through 00FFH
- Modern components appear at I/O locations above 0400H
- The slide on the next page shows many of the I/O devices found in the personal computer

### The PC I/O space



CEN433 - King Saud University

## **IN & OUT Instructions**

#### ; To read a byte from Input port address 71H

IN AL,71H

; or

; or

MOV DX,71H IN AL,DX

; To write the data 00H into Output port 62H

|     | AL,00H<br>62H,AL |
|-----|------------------|
| MOV | AL,00H           |
|     | DX,62H           |
| OUT | DX,AL            |

CEN433 - King Saud University

## **Basic Input Port (for I/O Reads)**

- The basic input port connects an external set of bits to the microprocessor data bus whenever the microprocessor executes the IN instruction with the I/O port address
- External device puts data on the microprocessor data bus

→ Must include a 3-state (Tri-State) buffer to limit access to the processor data bus to the duration of executing the I/O instruction only

### **Basic Input Port (for I/O Reads)**



CEN433 - King Saud University

### **Basic Input Port (for I/O Reads)**



CEN433 - King Saud University

## **Basic Output Port (for I/O Writes)**

- The basic output port writes data from the microprocessor data bus to an output port whenever the microprocessor executes the OUT instruction with the I/O port address
- Must latch the processor data put on the bus during the I/O instruction to make it available indefinitely for the port
- No need for 3-state (Tri-State) buffers as the data bus is at the input side of the latch

## **Basic Output Port (for I/O Writes)**



CEN433 - King Saud University

## **Basic Output Port (for I/O Writes)**



CEN433 - King Saud University

## **Requirements of Input Ports**

- An Input Port should include a tri-state buffer.
- The tri-state buffer isolates the input device from the microprocessor's data bus.
- The buffer enable is placed under the control of an Input Device Select Pulse (IDSP) which is generated by a decoding logic.
- The decoding logic takes into consideration the Address, IO/#M, and RD/.
- A latch is not always essential in an input port. For example, we do not have a latch in the case of the switches, which are all the time holding the information ready for the microprocessor to read it.
- If input device does not hold the information ready all the time ready to be read by the microprocessor, e.g. a keyboard, we need a latch to act as **buffer storage**. However, we need a **status register** to indicate new arrival of data.

## **Requirements of Output Ports**

- An Output Port does not require a tri-state buffer because the output port never tries to drive the microprocessor's data bus.
- An Output Device Select Pulse (ODSP) is generated by a decoding logic.
- The decoding logic takes into consideration the Address, IO/#M, and WR/.
- A latch is essential in the case of output port.

#### **Timing Waveforms for Fetching and Execution of the IN Instruction**



#### **Timing Waveforms for Fetching and Execution of the IN Instruction**



• Execution of the instruction: IN AL, DX



#### Timing Waveforms for Fetching and Execution of the OUT Instruction



#### **Timing Waveforms for Fetching and Execution of the OUT Instruction**



Execution of the instruction: OUT DX, AL



# **Optional Topic**

### **Conditional I/O**

| START:<br>AGAIN: | MOV<br>IN<br>TEST<br>JZ | DX, STATUS_PORT<br>AL, DX<br>AL, 00000001B<br>AGAIN | START:<br>AGAIN: |           | BX, STATUS_PORT<br>AL, [BX]<br>AL, 0000001B<br>AGAIN |
|------------------|-------------------------|-----------------------------------------------------|------------------|-----------|------------------------------------------------------|
| ,                | MOV<br>IN               | DX, DATA_PORT<br>AL, DX                             | ;                | MOV<br>IN | BX, DATA_PORT<br>AL, [BX]                            |
|                  | JMP                     | START                                               |                  | JMP       | START                                                |

#### Isolated I/O

Memory-Mapped I/O





CEN433 - King Saud University







#### **Conditional I/O - Timing Waveforms of Conditional Input Device Interface**



CEN433 - King Saud University



32

CEN433 - King Saud University



**Conditional I/O - Timing Waveforms of Conditional Output Device Interface** 



| ; To Read the Input Port |                  |  |  |  |
|--------------------------|------------------|--|--|--|
| MOV                      | DX, IDSP_STATUS1 |  |  |  |
| AGAIN1: IN               | AL, DX           |  |  |  |
| TEST                     | AL, 00000001B    |  |  |  |
| JZ                       | AGAIN1           |  |  |  |
| MOV                      | DX, IDSP_DATA    |  |  |  |
| IN                       | AL, DX           |  |  |  |
| MOV                      | VAR1, AL         |  |  |  |

| ; To Write the Value to the Output Port |      |                  |  |  |
|-----------------------------------------|------|------------------|--|--|
| ]                                       | MOV  | DX, IDSP_STATUS2 |  |  |
| AGAIN2: ]                               | IN   | AL, DX           |  |  |
| ,<br>,                                  | TEST | AL, 00000010B    |  |  |
| •                                       | JNZ  | AGAIN2           |  |  |
| ]                                       | MOV  | DX, ODSP_DATA    |  |  |
| ]                                       | MOV  | AL, VAR1         |  |  |
|                                         | OUT  | DX, AL           |  |  |