关于51单片机一个简单的外部中断程序,求教~

关于51单片机一个简单的外部中断程序,求教~,第1张

试试看:

ORG 0000H

JMP MAIN

ORG 0013H

AJMP INT

JMP MAIN

TAB:

DB 0X01, 0X02, 0X04, 0X08

DB 0X10, 0X20, 0X40, 0X80

MAIN:

SETB EA

SETB EX1

MOV DPTR, #TAB

LOOP:

MOV R1, #8

MOV B, #0

AGAIN:

MOV A, B

MOVC A, @A+DPTR

MOV P1, A

INC B 下一个状态

CALL DELAY

DJNZ R1, AGAIN

JMP LOOP

DELAY:

MOV R6, #2

LOOP3: MOV R5, #255 延迟0。5秒

LOOP2: MOV R4, #255

LOOP1: NOP

NOP

DJNZ R4, LOOP1

DJNZ R5, LOOP2

DJNZ R6, LOOP3

RET

INT:

MOV P2, #0XAA

CALL DELAY

CALL DELAY

CALL DELAY

CALL DELAY

CALL DELAY

MOV P2, #0XFF

MOV A, B显示下一个状态.

MOVC A, @A+DPTR

MOV P1, A

INC B

RETI

END

一般中断处理的主要步骤分别是中断请求、中断判优、中断响应、中断处理和中断返回。

在微机系统中,对于外部中断,中断请求信号是由外部设备产生,并施加到CPU的NMI或INTR引脚上,CPU通过不断地检测NMI和INTR引脚信号来识 别是否有中断请求发生。对于内部中断,中断请求方式不需要外部施加信号激发,而是通过内部中断控制逻辑去调用。无论是外部中断还是内部中断,中断处理过程 都要经历以下步骤: 请求中断→响应中断→关闭中断→保留断点→中断源识别→保护现场→中断服务子程序→恢复现场→中断返回。

请求中断

当某一中断源需要CPU为其进行中断服务时,就输出中断请求信号,使中断控制系统的中断请求触发器置位,向CPU请求中断。系统要求中断请求信号一直保持到CPU对其进行中断响应为止。

中断响应

CPU对系统内部中断源提出的中断请求必须响应,而且自动取得中断服务子程序的入口地址,执行中断 服务子程序。对于外部中断,CPU在执行当前指令的最后一个时钟周期去查询INTR引脚,若查询到中断请求信号有效,同时在系统开中断(即IF=1)的情 况下,CPU向发出中断请求的外设回送一个低电平有效的中断应答信号,作为对中断请求INTR的应答,系统自动进入中断响应周期。

关闭中断

CPU响应中断后,输出中断响应信号,自动将状态标志寄存器FR或EFR的内容压入堆栈保护起来,然后将FR或EFR中的中断标志位IF与陷阱标志位TF清零,从而自动关闭外部硬件中断。因为CPU刚进入中断时要保护现场,主要涉及堆栈 *** 作,此时不能再响应中断,否则将造成系统混乱。

保护断点

保护断点就是将CS和IP/EIP的当前内容压入堆栈保存,以便中断处理完毕后能返回被中断的原程序继续执行,这一过程也是由CPU自动完成。

中断源识别

当系统中有多个中断源时,一旦有中断请求,CPU必须确定是哪一个中断源提出的中断请求,并由中断控制器给出中断服务子程序的入口地址,装入CS与IP/EIP两个寄存器。CPU转入相应的中断服务子程序开始执行。

保护现场

主程序和中断服务子程序都要使用CPU内部寄存器等资源,为使中断处理程序不破坏主程序中寄存器的内容,应先将断点处各寄存器的内容压入堆栈保护起来,再进入的中断处理。现场保护是由用户使用PUSH指令来实现的。

中断服务

中断服务是执行中断的主体部分,不同的中断请求,有各自不同的中断服务内容,需要根据中断源所要完成的功能,事先编写相应的中断服务子程序存入内存,等待中断请求响应后调用执行。

恢复现场

当中断处理完毕后,用户通过POP指令将保存在堆栈中的各个寄存器的内容d出,即恢复主程序断点处寄存器的原值。

中断返回

在中断服务子程序的最后要安排一条中断返回指令IRET,执行该指令,系统自动将堆栈内保存的 IP/EIP和CS值d出,从而恢复主程序断点处的地址值,同时还自动恢复标志寄存器FR或EFR的内容,使CPU转到被中断的程序中继续执行。

#include<stdio.h>

#include<AT89X52.h>

unsigned char flag

unsigned char commond

void main()

{

TMOD=0x21//计数器1工作方式2,计数器0工作方式1

TH1=TL1=0xfb//波特率9600

TR1=1 //开始计时

SCON=0x50 //串口工作方式1 ,允许接收数据

EA=1

ES=1 //打开串口中断

ET0=0 //禁止计时器TO中断

while(1)

{

if(flag)

{

flag=0

}

}

}

void comm() interrupt 4 using 2

{ //unsigned char i

if(RI)

{

RI=0

flag=1

commond = SBUF

P2= commond

RI=0

if(commond=='e')

{

ET0=1 //打开计数器0中断

TH0=(65536-50000)/256

TL0=(65536-50000)%256 //延时0.5秒

TR0=1 //开始计时

}

}

}

void time0()interrupt 1 using 3

{

unsigned char j,k

EA=0

while(j>10)

{

j=0

P3_4 = ~P3_4

k++

if(k>13)

{

TR0 =0

k = 0

}

}

TH0=(65536-50000)/256

TL0=(65536-50000)%256

j++

EA =1

}

你的程序好像是定时器中断那里有问题,这个改过的可以实现你的要求了


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/11166539.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存