KEMBAR78
LAB 14 8051 Interrupt Programming | PDF | Electrical Engineering | Computer Hardware
0% found this document useful (0 votes)
23 views20 pages

LAB 14 8051 Interrupt Programming

Uploaded by

tanveer1111110
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
23 views20 pages

LAB 14 8051 Interrupt Programming

Uploaded by

tanveer1111110
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 20

LAB 14

8051 INTERRUPT
PROGRAMMING
INTRODUCTION

 An interrupt is the occurrence of a condition—an


event—that causes a temporary suspension of a
program while the condition is serviced by
another program.
 The program that deals with an interrupt is
called an ‘interrupt service routine’ (ISR) or
‘Interrupt handler’.
 A single microcontroller can serve several devices
efficiently using interrupt.
8051 INTERRUPTS

1. Reset
2. External Hardware Interrupt 0 (INT0)
3. Timer 0 Interrupt (TF0)
4. External Hardware Interrupt 1 (INT1)
5. Timer 1 Interrupt (TF1)
6. Serial COM Interrupt (RI and TI)
8051 INTERRUPTS – INTERRUPT VECTOR
TABLE
Interrupt service routines ISR are stored at specific
locations called interrupt vector table IVT

Interrupt Flag Interrupt Handler


Address
External 0 IE0 0003h

Timer 0 TF0 000Bh

External 1 IE1 0013h

Timer 1 TF1 001Bh

Serial RI/TI 0023h


8051 INTERRUPTS – INTERRUPT ENABLE
REGISTER IE
Interrupt enable register IE is a special function
register used to enable/ disable any interrupt
Bit Name Description
7 EA (Global bit) EA = 0 means all interrupts are disabled
EA = 1 means now we can enable any interrupt
6 - Not define
5 - Not define
4 ES (Serial Int ES = 0 mean serial interrupt is disabled
ES = 1 mean serial interrupt is enabled
3 ET1 (Timer 1 Int) ET1 = 1 mean Timer1 interrupt is enable
2 EX1 (Ext H/w 1 Int) EX1 = 1 mean External H/w 1 interrupt is
enable
1 ET0 (Timer 0 Int) ET0 = 1 mean Timer0 interrupt is enable
0 EX0 (Ext H/w 0 Int) EX0 = 1 mean External H/w 0 interrupt is
enable
ENABLE AND DISABLE INTERRUPT
The following command will enable the serial
interrupt, timer 0 interrupt, and external
hardware 1 interrupt:

MOV IE, #10010110B ;

We can also disable an interrupt as follows:

CLR IE.1 ; disable timer 0 interrupt only


CLR IE.7 ; disable all interrupts
TIMER INTERRUPT-EXAMPLES
A program that continuously gets 8-bit data from P0 and
sends it to P1 while simultaneously creating a square
wave of 200 us period on pin P2.1. Crystal frequency is
11.0592MHz

ORG 0000H
JMP MAIN ; by-pass interrupt vector table

;_-ISR for Timer 0 to generate square wave


ORG 000BH ; Timer 0 interrupt vector table
CPL P2.1 ; toggle P2.1 pin
RETI ; return from ISR
TIMER INTERRUPT-EXAMPLES

;_-The main program for initialization


ORG 0030H ; after vector table space
MAIN: MOV TMOD, #02H ; Timer 0, mode 2(auto reload)
MOV P0, #0FFH ; make P0 an input port
MOV TH0, #-92 ; TH0=A4H for -92
MOV IE, #82H ; IE=10000010 (bin) enable
; Timer 0
SETB TR0 ; Start Timer 0
BACK: MOV A, P0 ; get data from P0
MOV P1, A ; issue it to P1
SJMP BACK ; keep doing it unless interrupted
; by TF0
END
TIMER INTERRUPT-EXAMPLES
A program to generate a square wave of 50Hz on P1.2

ORG 00H
JMP MAIN
ORG 000BH ; ISR for Timer 0
CPL P1.2
MOV TL0, #00
MOV TH0, #0DCH
RETI
ORG 30H
;------main program for initialization
MAIN:
MOV TMOD, #00000001B ; Timer 0, Mode 1
MOV TL0, #00
MOV TH0, #0DCH
MOV IE, #82H ; enable Timer 0 interrupt
SETB TR0
SJMP $
END
TIMER INTERRUPT-EXERCISE
Write a program that continuously gets 8-bit data
from P0, multiply it by 6 and sends the result to
P1 while simultaneously creating a square wave
of 800 Hz on pin P2.7. Crystal frequency is
11.0592MHz
Note: use Timer 1 for delay and show your results
on Proteus
EXTERNAL INTERRUPTS
 Two External / Hardware interrupt (INT0 and INT1).
 IVT locations 0003H and 0013H.
 Pin 12 (P3.2) and Pin 13 (P3.3) are used as external hardware
interrupts (INT0, INT1).
 Two activation levels.
 Level triggered.
 Negative edge triggered (Edge Trigger).
 If we set IT0 or IT1 in TCON (TCON.0 and TCON.2). The
interrupt would be edge triggered otherwise level triggered
(next slide).
 The default mode (on activation) is level trigger.
Timer Control - TCON (88h) SFR

Bit
Bit Name Explanation of Function Int
Address

3 IE1 8Bh External Interrupt 1 edge flag. 1

External Interrupt 1 type flag. Set/ Cleared


2 IT1 8Ah by software for falling-edge / low-level 1
activation external interrupt.

1 IE0 89h External Interrupt 0 edge flag 0

0 IT0 88h External Interrupt 0 type flag 0


LEVEL TRIGGERED -EXAMPLE
In the following program an LED connected to P1.3 is turned on and off
using INT1 interrupt.
ORG 0000H
JMP MAIN ; by-pass interrupt vector table

;_-ISR for hardware interrupt INT1 to turn on the LED


ORG 0013H ; INT1 ISR
SETB P1.3 ; turn on LED
MOV R3, #255
BACK:
DJNZ R3, BACK ; keep LED on for a while
CLR P1.3 ; turn off the LED
RETI ; return from ISR

;__ MAIN program for initialization


ORG 30H
MAIN:
MOV IE, #10000100B ; enable external INT 1
SJMP $ ; stay here until get interrupted
END
EDGED TRIGGERED -EXAMPLE
In the following program an LED connected to P1.3 is turned on and off
using INT1 interrupt.
ORG 0000H
JMP MAIN ; by-pass interrupt vector table

;_-ISR for hardware interrupt INT1 to turn on the LED


ORG 0013H ; INT1 ISR
SETB P1.3 ; turn on LED
MOV R3, #255
BACK:
DJNZ R3, BACK ; keep LED on for a while
CLR P1.3 ; turn off the LED
RETI ; return from ISR

;__ MAIN program for initialization


ORG 30H
MAIN: SETB TCON.2 ; Making external INT1 edged triggered
MOV IE, #10000100B ; enable external INT 1
SJMP $ ; stay here until get interrupted
END
EXTERNAL HARDWARE INTERRUPT-EXERCISE
Write a program which counts number of
interrupts arriving on external interrupt pin
INT1 and show this count on P1. Stop when
counter overflows and disable the interrupt. Give
the indication on pin P0.0
SERIAL INTERRUPT

All Interrupt flags except serial are cleared by hardware.


Serial flag (RI or TI ) has to be cleared by software.
SERIAL INTERRUPT-EXAMPLE
A program in which the 8051 reads data from P1 and writes
it to P2 continuously while giving a copy of it to the serial
COM port to be transferred serially.
ORG 00H
LJMP MAIN
ORG 23H
LJMP SERIAL ; jump to serial interrupt ISR
ORG 30H
MAIN:
MOV P1, #0FFH ; make P1 an input port
MOV TMOD, #20H ; timer 1, mode 2 (auto reload)
MOV TH1, #0FDH ; 9600 baud rate
MOV SCON, #50H ; 8-bit, 1 stop, ren enabled
MOV IE, #10010000B ; enable serial interrupt
SETB TR1 ; start timer 1
SERIAL INTERRUPT-EXAMPLE CONT…
MOV SBUF, A
AGAIN:
MOV A, P1
MOV P2, A
SJMP AGAIN

SERIAL:
JB TI, NEXT
MOV A, SBUF
MOV P0, A
CLR RI
RETI
NEXT:
MOV SBUF, A
CLR TI
RETI

END
INTERRUPT-EXERCISES
Write a program which detects an external
interrupt on P3.2 and P3.3 and turn on LED’s for
approximately 65 ms connected on P0.0 & P0.1
respectively when interrupt arrive
INTERRUPT-EXERCISES
Write a program which sends an ultrasonic wave
for some time through P1.0 and receive its echo
through P3.2. as an interrupt. Calculate the
distance of object. Assume velocity v = 10m/s

You might also like