INTEL 8259A Programmable Interrupt Controller
INTEL 8259A Programmable Interrupt Controller
INTEL 8259A Programmable Interrupt Controller
Interrupt Controller
8259 PIC
• The 8259A is a programmable interrupt controller(PIC) specially designed
to work with Intel microprocessor 8080, 8085A, 8086, 8088.
• It is a tool for managing the interrupt requests and functions as an overall
manager in an Interrupt-Driven system environment.
• It accepts requests from the peripheral equipment, determines which of
the incoming requests is of the highest priority, ascertains whether the
incoming request has a higher priority value than the level currently being
serviced, and issues an interrupt to the CPU based on this determination.
• The PIC, after issuing an Interrupt to the CPU, must somehow input
information into the CPU that can ``point'' the Program Counter to the
service routine associated with the requesting device.
8259 PIC
• 8259 PIC can handle up to 8 vectored priorities interrupts for the
processor and it can be cascaded in master-slave configuration to
handle 64 levels of interrupts without any additional circuitry.
• It can be programmed either in level triggered or in edge triggered
interrupt level and also we can masked individual bits of interrupt
request register.
• It has Internal priority resolver which can be programmed into fixed
priority mode and rotating priority mode.
Block Diagram of 8259
These Signals are used to interface 8259 with
microprocessor
Data bus buffer:
• This, bidirectional 8-bit buffer is used to interface the 8259A to the
system data bus.
• Control words and status information from the microprocessor to PIC
and from PIC to microprocessor respectively, are transferred through
the data bus buffer.
• The processor sends control word to data bus buffer through D0-D7.
• The processor read status word from data bus buffer through D0-D7
• Also, after selection of Interrupt by 8259 microprocessor, it transfer
the opcode of the selected Interrupt and address of the Interrupt
service sub routine to the other connected microprocessor.
Read/Write & Control Logic
• The function of this block is to accept output commands sent from the
CPU.
• It contains the initialization command word (ICW) registers and operation
command word (OCW) registers which store the various control formats
for device operation.
• ICW and OCW are two types of command words of 8259, where ICW is
used to initialize 8259 where as OCW are issued to control the operation of
8259.
• This function block also allows the status of 8259A to be transferred to the
data bus.
• Control Logic
• The function of control logic is to control all the internal operations, generates an INT
signal to 8085 and receives INTA signal from 8085.
Pins Connected with Read/Write & Control
Logic
• RD, WR, CS and A0 are the control signals used in Read/Write
and Control Logic.
• The processor uses the RD (low), WR (low) and A0 to read or
write 8259.
• A LOW on WR input enables the CPU to write control words
(ICWs and OCWs) to the 8259A.
• A LOW on RD input enables the 8259A to send the status of
the Interrupt Request Register (IRR), In Service Register (ISR),
the Interrupt Mask Register (IMR), or the Interrupt level onto
the Data Bus.
• A0 input signal is used in conjunction with WR and RD signals
to write commands into the various command registers, as well
as reading the various status registers of the chip. This line can
be tied directly to one of the address lines
This Sub System of 8259 handles all the
external Interrupt requests
Interrupt Request Register (IRR):
• This block accepts and stores the actual interrupt
requests from external interrupting devices on IR0 –
IR7 lines.
• Interrupt request register (IRR) stores all the incoming
interrupt inputs that are requesting service.
• It is an 8-bit register – one bit for each interrupt
request.
• Basically, it keeps track of which interrupt inputs are
asking for service and also stores the pending
interrupt requests.
• If an interrupt input is unmasked, and has an
interrupt signal on it, then the corresponding bit in
the IRR will be set.
Interrupt Mask Register (IMR):
• This logic block masks interrupt lines based on
programming by the processo and prevents
masked interrupt lines from interrupting the
processor.
• The IMR is used to disable (Mask) or enable
(Unmask) individual interrupt request inputs.
• This is also an 8-bit register. Each bit in this
register corresponds to the interrupt input with
the same number.
• The IMR operates on the IRR. Masking of higher
priority input will not affect the interrupt request
lines of lower priority.
• To unmask any interrupt the corresponding bit is
set ‘0’
In-service Register (ISR):
• The in-service register keeps track of which interrupt
inputs are currently being serviced.
• For each input that is currently being serviced the
corresponding bit of in-service register (ISR) will be
set.
• In 8259A, during the service of an interrupt request,
if another higher priority interrupt becomes active, it
will be acknowledged and the control will be
transferred from lower priority interrupt service
subroutine (ISS) to higher priority ISS.
• Thus, more than one bit of ISR will be set indicating
the number of interrupts being serviced.
• Each of these 3-registers can be read as status
register.
Priority Resolver:
• This logic block determines the priorities of
the incoming interrupts set in the IRR.
• It takes the information from IRR, IMR and ISR
to determine whether the new interrupt
request is having highest priority or not.
• If the new interrupt request is having the
highest priority, it is selected and processed.
• The corresponding bit of ISR will be set during
interrupt acknowledge machine cycle
Cascade Buffer/Comparator:
• This logic allows for cascading multiple 8259 controllers
in a Master/ Slave configuration.
• This function block stores and compares the IDs of all
8259A’s in the system.
• The associated 3-I/O lines (CAS2-CAS0) are outputs
when 8259A is used as a master and are inputs when
8259A is used as a slave.
• As a master, the 8259A sends the ID of the interrupting
slave device onto the CAS2-0 lines.
• The slave 8259As compare this ID with their own
programmed ID.
• Thus selected 8259A will send its pre-programmed
subroutine address on to the data bus during the next
one or two successive INTA pulses.
How does the Master-Slave concept work?
• The slave 8259 creates an interrupt trigger on master as soon as it
receives an interrupt trigger at one of its eight input lines.
• The master in turn interrupts the processor.
• The processor read Interrupts Service Routine address.
• The master 8259 informs the corresponding slave 8259 to release the
ISR address onto the Data Bus.
• The processor reads this information and executes the appropriate
Interrupt service Routine.
INTERCONNECTING OF MASTER /SLAVE PICs
AND CPU
• Each PIC scheme provides to receive only up to 8 IR signals. If
required more than 8 IR signals then used multiple PIC schemes from
which one is master and others are slave. At this case PIC schemes are
used in cascading mode.
• In cascading mode INT outs of Slave are connected into nonuse IR line
of Master.
• INTR input of CPU can be receives common interrupt request signal
only from INT output of single Master.
• Number of selected interrupt vector can be transferred from only
Master PIC
PIN Diagram of 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).
10. CAS2-CAS0, the cascade lines are used as outputs from the master to the slaves for
cascading multiple 8259As in a system.
8259A Interrupt Operation
• To implement interrupt, the interrupt enable flip-flop in the microprocessor
should be enabled by writing the EI instruction and the 8259A should be
initialized by writing control words in the control register. The 8259A requires two
types of control words:
a. Initialization Command Words (ICWS)
b. Operational Command Words (OCWs)
• ICWs are used to set up the proper conditions and specify RST vector address.
The OCWs are used to perform functions such as masking interrupts, setting up
status-read operations etc.
• Step-1: The IRR of 8259A stores the request.
• Step-2: The priority resolver checks 3 registers-
• The IRR for interrupt requests.
• IMR for masking bits and
• The ISR for interrupt request being served
• It resolves the priority and sets the INT high when appropriate.
8259A Interrupt Operation
• Step-3: The MPU acknowledges the interrupt by sending signals in 𝐼𝑁𝑇A
• Step-4: After the 𝐼𝑁𝑇𝐴 is received, the appropriate bit in the ISR is set to indicate which interrupt
level is being served and the corresponding bit in the IRR is reset to indicate that the request for
the CALL instruction is placed on the data bus.
• Step-5: When MPU decodes the CALL instruction, it places two more 𝐼𝑁𝑇𝐴 signals on the data
bus.
• Step-6: When the 8259A receives the second 𝐼𝑁𝑇𝐴, it places the low-order byte of the CALL
address on the data bus. At the 3rd 𝐼𝑁𝑇𝐴, it places the high order byte on the data bus. The CALL
address is the vector memory location for the interrupt, this address is placed in the control
register during the initialization.
• Step-7: During the 3rd 𝐼𝑁𝑇𝐴 pulse, the ISR bit is reset either automatically (Automatic-End-of
Interrupt-AEOI) or by a command word that must be issued at the end of the service routine (End
of Interrupt-EOI).This option is determined by the initialization command word (ICW).
• Step-8: The program sequence is transferred to the memory location specified by the CALL
instruction