Lecture 7
Lecture 7
&
PIC 8259
Interrupt :
INTERRUPTS
An interrupt is an event which informs the CPU that its service
(action) is needed.
The process starts from the I/O device
The process is asynchronous.
Classification of Interrupts
Interrupts can be classified into two types:
Maskable Interrupts (Can be delayed or Rejected)
Non-Maskable Interrupts (Can not be delayed or
Rejected)
Interrupts can also be classified into:
Vectored (the address of the service routine is hard-wired)
Non-vectored (the address of the service routine needs to
be supplied externally by the device)
Basic Procedure for Processing
Interrupts
When an interrupt is executed, the p:
finishes executing its current instruction (if any).
Saves (PUSH) the flag register, IP and CS register
in the stack.
Goes to a fixed memory location.
Reads the address of the associated ISR.
Jumps to that address and executes the ISR.
Gets (PULL) the flag register, CS:IP register from
the stack.
Continues executing the previous job (if any).
8086 INTERRUPT CATAGORIES
i. Hardware interrupt
v. Reset
In the 8086 there are a total of 256 interrupts (or interrupt types):
-INT 00H
-INT 01H
-……….
-INT FFH
For every interrupt there must be a program associated with it .
This program is called Interrupt Service Routine (ISR) .
It is also called an interrupt handler.
But where the interrupt handler.
-- In the Interrupt Vector Table (IVT).
The Operation of Real Mode Interrupt:
1. The contents of the flag register are pushed onto the stack.
2. Both the interrupt (IF) and trap (TF) flags are cleared.This
disables the INTR pin and the trap or single step feature.
3. The contents of the code segment register (CS) are pushed onto
the stack.
4. The contents of the instruction pointer (IP) are pushed onto the
stack.
5. The interrupt vector contents are fetched, and then placed into
both IP and CS so that the next instruction executes at the
interrupt service procedure addressed by the vector.
Type 0 interrupts: This interrupt is also known as the divide
by zero interrupt. For cases where the quotient becomes
particularly large to be placed / adjusted an error might occur.
Priority Resolver
The associated three I/O pins (CAS0- 2) are outputs when the
8259 is used as a master and are inputs when the 8259 is used as a
slave. As a master, the 8259 sends the ID of the interrupting slave
device onto the CAS0 - 2 lines. The slave, thus selected will send its
preprogrammed subroutine address onto the Data Bus during the
next one or two consecutive INTA pulses.
PIN DIAGRAM
8259 PINS