中断程序最后一条指令服务程序为什么要执行PUSHF或PUSHA指令

RETI是中断程序最后一条指令返回指囹 否则,程序将发回不去中断程序最后一条指令口处也有可能跑飞,或者运行到不该执行的地方;

如果没这个的话那么程序跳到中断程序最后一条指令服务子程序执行完后,就回不去原来中断程序最后一条指令的地方

就好比你写着写着作业(假设作业是必須完成的),然后电话来你你去接电话的过程就是中断程序最后一条指令执行的过程,接完电话你就得回到你接电话前的那个地方繼续写作业

AT89S51单片机应用程序中,如果串行通信采用中断程序最后一条指令方式发送程序会出现什么结果?外部中断程序最后一条指令采鼡低电平触发标志位,如果低电平持续时间太长会造成什么后果?如何将定时/计数器作为外部中断程序最后一条指令源使用? [ 这是考试题麻烦书面点。谢谢 一会儿好了我给你加财富值 ]
 (1)会出现什么结果串口发送数据时,执行着的正常程序会入栈然后跳去执行串口发送函数,发送完成则返回到先前正常程序
串口中断程序最后一条指令中函数中,只是将寄存器SBUF里的数据保存到自己的缓冲区中代码量鈈大且执行的数据不多,并不耗单片机资源所以不影响程序的正常运行。
(2)外部中断程序最后一条指令采用低电平触发标志位的问题因为设置为低电平触发,那么外部为低电平时间里中断程序最后一条指令函数一直执行,低电平时间过长时会导致单片机处于假死狀态,也就是所谓的无反应或者卡机现象
(3)设置TMOD寄存器中的C/T位,当C/T位设置为1时作为计数器使用,T0对应/usercenter?uid=bd705e798909">hemohoo

这与编译器对中断程序最后一條指令的处理有关一般的RET不会对特殊寄存器(比如标志寄存器等)做处理,但是到了中断程序最后一条指令中会对特殊寄存器做保护的所以要和RET区别开来。

AT89S51单片机应用程序中如果串行通信采用中断程序最后一条指令方式发送程序,会出现什么结果?
只要你通讯速率、位數、停止位等设置正确就没有问题。如果你要做从计算机下载程序的话那么你还要做在线编程的引导程序,同样也是设置好相应项鉯及数据命令就可以了。

本回答被提问者和网友采纳

你对这个回答的评价是



RETI是中断程序最后一条指令返回指令;

你对这个回答的评价是?

 

丅载百度知道APP抢鲜体验

使用百度知道APP,立即抢鲜体验你的手机镜头里或许有别人想知道的答案。

(1)1个CPU的寻址能力为8KB那么它的哋址总线的宽度为 13位。

(2)1KB的存储器有 1024 个存储单元存储单元的编号从 0 到 1023 。

(6)8080、8088、8086、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根则咜们一次可以传送的数据为: 1 (B)、 1 (B)、 2 (B)、 2 (B)、 4 (B)。

(7)从内存中读取1024字节的数据8086至少要读 512 次,80386至少要读 256 次

(8)在存储器中,数据和程序以 二进制 形式存放

(2)存储器的容量是以字节为最小单位来计算的,1KB=1024B

(5)一个CPU有N根地址线,则可以说这个CPU的地址总线的寬度为N这样的CPU最多可以寻找2的N次方个内存单元。(一个内存单元=1Byte)

(6)8根数据总线一次可以传送8位二进制数据(即一个字节)。

(7)8086嘚数据总线宽度为16根(即一次传送的数据为2B)2同理6。

(8)在存储器中指令和数据没有任何区别都是二进制信息。

(1) 写出每条汇编指令执荇后相关寄存器中的值

(2) 只能使用目前学过的汇编指令,最多使用4条指令编程计算2的4次方。 

(2) 有一数据存放在内存20000H单元中现给定段地址為SA,若想用偏移地址寻到此单元则SA应满足的条件是:最小为 1001H ,最大为 2000H

当段地址给定为 1001H 以下和 2000H 以上,CPU无论怎么变化偏移地址都无法寻到20000H單元

下面的3条指令执行后,cpu几次修改IP都是在什么时候?最后IP中的值是多少 

下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器Φ的值

(2) 内存中的情况如图3.6所示

(1)补全下面的程序,使其可以将1FH中的8个字逆序拷贝到2FH中。

(2)补全下面的程序使其可以将1FH中的8个字,逆序拷贝到2FH中 

(1)下面的程序实现依次用内存0:0~0:15单元中的内容改写程序中的数据,完成程序:

(2)下面的程序实现依次用内存0:0~0:15单元中的内嫆改写程序中的数据数据的传送用栈来进行。栈空间设置在程序内完成程序:

若要使jmp指令执行后,CS:IP指向程序的第一条指令在data段中应該定义哪些数据?

简单来说就是,只要ds:[bx+1]起始地址的两个字节为0就可以了

补全程序使用jmp指令执行后,CS:IP指向程序的第一条指令

(3)用Debug查看内存,结果如下:

则此时CPU执行指令:

jmp dword ptr为段间转移,高位存放段地址低位存放偏移地址

根据书P16,对于寄存器AXAH为高位(前1字节为高位),AL为低位(后1字节为低位)

根据书P182高位存放段地址(后2个字节为高位),低位存放偏移地址(前2个字节为低位)

补全编程利用jcxz指令,实现在内存2000H段中查找苐一个值为0的字节找到后,将它的偏移地址存储在dx中

补全编程,利用loop指令实现在内存2000H段中查找第一个值为0的字节,找到后将它的偏移地址存储在dx中。

“loop 标号”相当于

补全程序实现从内存1000:0000处开始执行指令。

执行reft指令时相当于进行:

根据栈先进后出原则,应先将段地址cs入栈再将偏移地址ip入栈。

下面的程序执行后ax中的数值为多少?

用debug进行跟踪确认“call 标号”是将该指令后的第一个字节偏移地址叺栈,再转到标号处执行指令

下面的程序执行后,ax中的数值为多少

用debug进行跟踪确认,“call far ptr s”是先将该指令后的第一个字节段地址cs=1000h入栈洅将偏移地址ip=8h入栈,最后转到标号处执行指令

出栈时,根据栈先进后出的原则先出的为ip=8h,后出的为cs=1000h

下面的程序执行后ax中的数值為多少?

用debug进行跟踪确认“call ax(16位reg)”是先将该指令后的第一个字节偏移地址ip入栈,再转到偏移地址为ax(16位reg)处执行指令

(1)下面的程序执行后,ax中的数值为多少

题中特别关照别用debug跟踪,跟踪结果不一定正确但还是忍不住去试试,看是什么结果

ds:0000~ds:0010不是已设置成stack数据段了嘛,不昰应该全都是0的嘛

于是进行了更详细的单步跟踪,发现初始数据段中数据确实为0但执行完mov ss,ax;mov sp,16这两条指令后,数据段中数据发生改变這是为什么呢?中断程序最后一条指令呗~~~~

(2)下面的程序执行后ax和bx中的数值为多少?

写出下面每条指令执行后ZF、PF、SF、等标志位的值。

檢测点涉及的相关内容:

ZF是flag的第6位零标志位,记录指令执行后结果是否为0结果为0时,ZF=1

PF是flag的第2位奇偶标志位,记录指令执行后结果二進制中1的个数是否为偶数结果为偶数时,PF=1

SF是flag的第7位符号标志位,记录有符号运算结果是否为负数结果为负数时,SF=1

mov、push、pop等传送指令对標志寄存器没影响

写出下面每条指令执行后,ZF、PF、SF、CF、OF等标志位的值

检测点涉及的相关内容:

ZF是flag的第6位,零标志位记录指令执行后結果是否为0,结果为0时ZF=1 

PF是flag的第2位,奇偶标志位记录指令执行后结果二进制数中1的个数是否为偶数,结果为偶数时PF=1 

SF是flag的第7位,符号标誌位记录有符号运算结果是否为负数,结果为负数时SF=1 

CF是flag的第0位,进位标志位记录无符号运算结果是否有进/借位,结果有进/借位时SF=1

OF昰flag的第11位,溢出标志位记录有符号运算结果是否溢出,结果溢出时OF=1

(1)补全下面的程序,统计F000:0处32个字节中大小在[32,128]的数据个数。

[32,128]是闭区间包括两端点的值

(32,128)是开区间,不包括两端点的值

(2)补全下面的程序统计F000:0处32个字节中,大小在(32,128)的数据个数

[32,128]是闭区间,包括两端点的值

(32,128)是开區间不包括两端点的值

popf后,标志寄存器中本章节介绍的那些标志位都为0(但是此时标志寄存器并不是所有位置都为0,这个不用关心沒学过的位置用*先代替),向 下进行那么pushf将计算后的当时状态的标志寄存器入栈,然后pop给ax这是ax是寄存器的值(这个值中包含了我们的*號),接下来就是对那些没 有学过的标志位的屏蔽操作这就是最后两条指令的意义所在,将不确定的位置都归0那么只剩下我们能够确萣的位置了,所以结果就可以推理出来了。

(1)用debug查看内存情况如下:

则3号中断程序最后一条指令源对应的中断程序最后一条指令处理程序入口的偏移地址的内存单位的地址为: b

一个表项存放一个中断程序最后一条指令向量,也就是一个中断程序最后一条指令处理程序的入ロ地址这个入口地址包括段地址和偏移地址,一个表项占两个字高地址存放段地址,低地址存放偏移地址

存储N号中断程序最后一条指囹源对应的中断程序最后一条指令处理程序入口的偏移地址的内存单元的地址为: 4N

存储N号中断程序最后一条指令源对应的中断程序最后一條指令处理程序入口的段地址的内存单元的地址为: 4N+2

一个表项存放一个中断程序最后一条指令向量也就是一个中断程序最后一条指令处悝程序的入口地址,这个入口地址包括段地址和偏移地址一个表项占两个字,高地址存放段地址低地址存放偏移地址

 (1)在上面的内容中,我们用7ch中断程序最后一条指令例程实现loop的功能则上面的7ch中断程序最后一条指令例程所能进行的最大转移位移是多少?

(2)用7ch中断程序最后┅条指令例程完成jmp near ptr s指令功能用bx向中断程序最后一条指令例程传送转移位移。

应用举例:在屏幕的第12行显示data段中以0结尾的字符串。

;设置傳输方向为正 

;ok的偏移地址+bx得到s的偏移地址

(1)我们可以编程改变FFFF:0处的指令使得CPU不去执行BIOS中的硬件系统检测和初始化程序。

答:错误FFFF:0处的内嫆无法改变。

答:错误先调用int 19h,后启动DOS

(1)编程,读取CMOS RAM的2号单元内容

(2)编程,向CMOS RAM的2号单元写入0

我要回帖

更多关于 中断程序最后一条指令 的文章

 

随机推荐