# INTERRUPT CONTROLLER INTEL 8259



#### 8259 Programmable Interrupt Controller (PIC)

- 1. This IC is designed to simplify the implementation of the interrupt interface in the 8088 and 8086 based microcomputer systems.
- 2. This device is known as a 'Programmable Interrupt Controller' or PIC.
- 3. It is manufactured using the NMOS technology and It is available in 28-pin DIP.
- 4. The operation of the PIC is programmable under software control (Programmable) and it can be configured for a wide variety of applications.
- 5. 8259A is treated as peripheral in a microcomputer system.
- 6. 8259A PIC adds eight vectored priority encoded interrupts to the microprocessor.
- 7. This controller can be expanded without additional hardware to accept up to 64 interrupt request inputs. This expansion required a master 8259A and eight 8259A slaves.
- 8. Some of its programmable features are:
  - $\cdot$  The ability to accept level-triggered or edge-triggered inputs.
  - $\cdot$  The ability to be easily cascaded to expand from 8 to 64 interrupt-inputs.
  - $\cdot$  Its ability to be configured to implement a wide variety of priority schemes.

## 8259A PIC- PIN DIGRAM



#### 8259 PIC



The processor is interrupted whenever the Interrupting device delivers a signal to the 8259.

#### **ASSINGMENT OF SIGNALS FOR 8259:**

- **1. D7-D0** is connected to microprocessor data bus D7-D0 (AD7-AD0).
- **2. IR7- IR0**, Interrupt Request inputs are used to request an interrupt and to connect to a slave in a system with multiple 8259As.
- **3.** WR the write input connects to write strobe signal of microprocessor.
- **4. RD** the read input connects to the IORC signal.
- **5. INT -** the interrupt output connects to the INTR pin on the microprocessor from the master, and is connected to a master IR pin on a slave.
- **6. INTA -** the interrupt acknowledge is an input that connects to the INTA signal on the system. In a system with a master and slaves, only the master INTA signal is connected.
- 7. A0 this address input selects different command words within the 8259A.
- **8. CS** chip select enables the 8259A for programming and control.
- **9. SP/EN -** Slave Program/Enable Buffer is a dual-function pin.

- When the 8259A is in buffered mode, this pin is an output that controls the data bus transceivers in a large microprocessor-based system.
- When the 8259A is not in buffered mode, this pin programs the device as a master (1) or a slave (0).
- CAS2-CAS0, the cascade lines are used as outputs from the master to the slaves for cascading multiple 8259As in a system.

### 8259A PIC- BLOCK DIAGRAM





#### The Internals of 8259 INTA INT Data D7-D0 Bus Control Logic Buffer Internal Data – IR<sub>0</sub> RD - IR1 Read/Write In Interrupt $-IR_2$ WR Priority Service Request Logic - IR<sub>3</sub> Resolver Register Register A<sub>0</sub> - IR4 (PR) (ISR) (IRR) Bus - IR5 - IR6 CS - IR7 CAS<sub>04</sub> Cascade Interrupt Mask Register (IMR) CAS14 Buffer/ Comparator CAS24 SP/EN These signals are used to interface Vcc GND Power Supply to the 8086 Microprocessor.

































### Programming the 8259A: -

The 82C59A accepts two types of command words generated by the CPU:

#### 1. Initialization Command Words (ICWs):

Before normal operation can begin, each 82C59A in the system must be brought to a starting point - by a sequence of 2 to 4 bytes timed by WR pulses.

#### 2. Operational Command Words (OCWs):

These are the command words which command the 82C59A to operate in various interrupt modes. Among these modes are:

a. Fully nested mode.

b. Rotating priority mode.

c. Special mask mode.

d. Polled mode.

The OCWs can be written into the 82C59A anytime after initialization.



- To program this ICW for 8086 we place a logic 1 in bit IC4.
- Bits D7, D6, D5and D2 are don't care for microprocessor operation and only apply to the 8259A when used with an 8-bit 8085 microprocessor.
- This ICW selects single or cascade operation by programming the SNGL bit. If cascade operation is selected, we must also program ICW3.
- The LTIM bit determines whether the interrupt request inputs are positive edge triggered or level-triggered.



- Selects the vector number used with the interrupt request inputs.
- For example, if we decide to program the 8259A so that it functions at vector locations 08H-0FH, we place a 08H into this command word.
- ✤ Likewise, if we decide to program the 8259A for vectors 70H-77H, we place a 70H in this ICW.  $A_0 \quad D_7 \quad D_6 \quad D_5 \quad D_4 \quad D_3 \quad D_2 \quad D_1 \quad D_0$

| _ | 0 |                       | ~0             |                |                | ر <i>ح</i> د          |          | - 1        |       |
|---|---|-----------------------|----------------|----------------|----------------|-----------------------|----------|------------|-------|
|   | 1 | <b>T</b> <sub>7</sub> | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | <b>T</b> <sub>3</sub> | $A_{10}$ | <b>A</b> 9 | $A_8$ |
|   |   |                       |                |                |                |                       |          |            |       |

- T<sub>7</sub> T3 are A3 A0 of interrupt address
- A<sub>10</sub> A<sub>9</sub>, A<sub>8</sub> Selected according to interrupt request level. They are not the address lines of Microprocessor
  A0 =1 selects ICW<sub>2</sub>



- ✤ Is used only when ICW1 indicates that the system is operated in cascade mode.
- This ICW indicates where the slave is connected to the master.
- For example, if we connected a slave to IR2, then to program ICW3 for this connection, in both master and slave, we place a 04H in ICW3.
- Suppose we have two slaves connected to a master using IR0 and IR1. The master is programmed with an ICW3 of 03H; one slave is programmed with an ICW3 of 01H and the other with an ICW3 of 02H.

ICW4:



- Is programmed for use with the 8088/8086. This ICW is not programmed in a system that functions with the 8085 microprocessors.
- The rightmost bit must be logic 1 to select operation with the 8086 microprocessor, and the remaining bits are programmed as follows:

### **Operation Command Words**



- Is used to set and read the interrupt mask register.
- When a mask bit is set, it will turn off (mask) the corresponding interrupt input. The mask register is read when OCW1 is read.
- Because the state of the mask bits is known when the 8259A is first initialized, OCW1 must be programmed after programming the ICW upon initialization.



✤ Is programmed only when the AEOI mod is not selected for the 8259A.

- ✤ In this case, this OCW selects how the 8259A responds to an interrupt.
- The modes are listed as follows in next slide:



- Selects the register to be read, the operation of the special mask register, and the poll command.
- If polling is selected, the P-bit must be set and then output to the 8259A. The next read operation would read the poll word. The rightmost three bits of the poll word indicate the active interrupt request with the highest priority.
- The leftmost bit indicates whether there is an interrupt, and must be checked to determine whether the rightmost three bits contain valid information.