



**BITS** Pilani

Microprocessors & Interfacing

8259A

Dr. Gargi Prabhu Department of CS & IS

- The 8259A programmable interrupt controller (PIC) adds eight vectored priority encoded interrupts to the microprocessor.
- This controller can be expanded, without additional hardware, to accept up to 64 interrupt requests.
- This expansion requires a master 8259A and eight 8259A slaves.

# innovate achieve lead

#### **8259A Chip**

|                                                                                      |                                                                |                                                      |                      | $D_0-D_7$                         | The bidirectional <b>data connections</b> are normally connected to the data bus on the microprocessor.                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------|----------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11                                                                                   |                                                                | 8259A                                                |                      | IR <sub>0</sub> -IR <sub>7</sub>  | <b>Interrupt request inputs</b> are used to request an interrupt and to connect to a slave in a system with multiple 8259As.                                                                                                                                                                              |
| 10<br>9<br>8<br>7<br>6<br>5<br>4<br>27<br>1<br>3<br>2<br>16<br>17<br>26 <sub>0</sub> | D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7<br>A0<br>CS<br>RD | IR0<br>IR1<br>IR2<br>IR3<br>IR4<br>IR5<br>IR6<br>IR7 | 20<br>21<br>22<br>23 | WR                                | The <b>write input</b> connects to write strobe signal ( $\overline{IOWC}$ ) on the microprocessor.                                                                                                                                                                                                       |
|                                                                                      |                                                                |                                                      |                      | $\overline{\mathbf{R}\mathbf{D}}$ | The <b>read input</b> connects to the $\overline{IORC}$ signal.                                                                                                                                                                                                                                           |
|                                                                                      |                                                                |                                                      |                      | INT                               | The <b>interrupt output</b> connects to the INTR pin on the microprocessor from the master and is connected to a master IR pin on a slave.                                                                                                                                                                |
|                                                                                      |                                                                |                                                      |                      | INTA                              | <b>Interrupt acknowledge</b> is an input that connects to the $\overline{INTA}$ signal on the system. In a system with a master and slaves, only the master $\overline{INTA}$ signal is connected.                                                                                                        |
|                                                                                      |                                                                |                                                      |                      | $\mathbf{A_0}$                    | The $A_0$ address input selects different command words within the 8259A.                                                                                                                                                                                                                                 |
|                                                                                      | WR_<br>SP/EN                                                   |                                                      |                      | $\overline{\mathbf{CS}}$          | Chip select enables the 8259A for programming and control.                                                                                                                                                                                                                                                |
|                                                                                      | INT<br>INTA                                                    |                                                      |                      | SP/EN                             | <b>Slave program/enable buffer</b> is a dual-function pin. When the 8259A is in buffered mode, this is an output that controls the data bus transceivers in a large microprocessor-based system. When the 8259A is not in the buffered mode, this pin programs the device as a master (1) or a slave (0). |
|                                                                                      |                                                                |                                                      |                      | CAS <sub>0</sub> -C               | The cascade lines are used as outputs from the master to the slaves for                                                                                                                                                                                                                                   |

cascading multiple 8259As in a system.

## innovate achieve lead

#### **Block Diagram**





**Data Bus Buffer**: 8259 has tri-stated bidirectional 8-bit data bus buffer (i.e.,  $D_0$  to  $D_7$ ) that interfaces with the internal bus of the processor. The 8085 microprocessor sends/ receives, control or status words to/ from the 8259 using data bus buffer.



**Read/Write Logic**: This unit is responsible for controlling the internal read-write operations of the system. It holds initialization command word register and operation command word register inside which various control formats exist that are needed for the device operation.



**Control Logic**: This unit is the heart of the architecture of 8259. It controls the overall operation of the system by sending the INTR signal to the processor whenever an interrupt request is generated.



**Control Logic**: This unit is the heart of the architecture of 8259. It controls the overall operation of the system by sending the INTR signal to the processor whenever an interrupt request is generated.



Interrupt request register (IRR): This unit stores the interrupt requests generated by the peripheral devices. We know that 8259 has 8 interrupt request pins (i.e., IR<sub>0</sub> to IR<sub>7</sub>). So, the unit can store 8 interrupt requests that are requesting the service from the processor.



**Priority Resolver**: This logic unit decides that among all the interrupt request present in the IRR which holds the highest priority and needs to be executed first.



*In-service register*: Here the name of the unit is itself indicating the operation performed by it. This register unit stores the interrupts which are currently being executed by the processor.



*In-service register*: Here the name of the unit is itself indicating the operation performed by it. This register unit stores the interrupts which are currently being executed by the processor.



*Interrupt mask register*: This register unit holds the masking bit of those interrupts which are to be masked. Through operation command word (OCW) the processor sends the required information and programs the interrupt mask register.



*Cascade buffer/comparator*: As we have already discussed that by cascading multiple 8259, the number of interrupts handled by 8259 can be expanded up to 64. The unit allows the comparison of IDs of different 8259s cascaded together..



### **Thank You**