版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
单片机原理及接口技术课后答案.(第三版)
第一章
1.单片机具有哪些特点
(1)片内存储容量越来越大。
(2抗干扰性好,可靠性高。
(3)芯片引线齐全,容易扩展。
(4)运行速度高,控制功能强。
(5)单片机内部的数据信息保存时间很长,有的芯片可以达到100年以上。
2.89C51单片机内包含哪些主要逻辑功能部件?
答:80c51系列单片机在片内集成了以下主要逻辑功能部件:
(l)CPU(中央处理器):8位
(2)片内RAM:128B
(3)特殊功能寄存器:21个
(4)程序存储器:4KB
(5)并行I/O口:8位,4个
(6)串行接口:全双工,1个
(7)定时器/计数器:16位,2个
(8)片内时钟电路:1个
3.什么是微处理器(CPU)、微机和单片机?
答:微处理器本身不是计算机,但它是小型计算机或微机的控制和处理部分。
微机则是具有完整运算及控制功能的计算机,除了微处理器外还包括存储器、接
口适配器以及输入输出设备等。
单片机是将微处理器、一定容量的RAM、ROM以及I/O口、定时器等电路集成
在一块芯片上,构成的单片微型计算机。
4.微型计算机怎样执行一个程序?
答:通过CPU指令,提到内存当中,再逐一执行。
5.什么是嵌入式系统?他有哪些类型?为什么说单片机是典型的嵌入式系统?
答;嵌入式系统是将先进的计算机技术、半导体技术和电子技术和各个行业的具
体应用相结合后的产物,这一点就决定了它必然是一个技术密集、资金密集、高
度分散、不断创新的知识集成系统。
它有嵌入式微处理器、嵌入式微控制器、嵌入式DSP处理器、嵌入式片上系
统等。
/入式系统的出现最初是基于单片机的。它从体系结构到指令系统都是按照
嵌入式应用特点专门设计的,能最好的满足面对控制对象,应运系统的嵌入、现
场的可靠运行以及非凡的控制品质要求。因此,她是典型的嵌入式系统。
第二章
1.89C51单片机内包含哪些主要逻辑功能部件?
答:80c51系列单片机在片内集成了以下主要逻辑功能部件:
(l)CPU(中央处理器):8位
(2)片内RAM:128B
(3)特殊功能寄存器:21个
(4)程序存储器:4KB
(5)并行I/O口:8位,4个
(6)串行接口:全双工,1个
⑺定时器/计数器:16位,2个
(8)片内时钟电路:1个
2.89C51的EA端有何用途?
答:/EA端接高电平时,CPU只访问片内并执行内部程序,存储
器。/EA端接低电平时,CPU只访问外部ROM,并执行片外程序存储器中的指
令。/EA端保持高电平时,CPU执行内部存储器中的指令。
3.89C51的存储器分哪几个空间?如何区别不同空间的寻址?
答:ROM(片内ROM和片外ROM统一编址)(使用MOVC)(数据传送指
令)(16bits地址)(64KB)
片夕卜RAM(MOVX)(16bits地址)(64KB)
片内RAM(MOV)(8bits地址)(256B)
4.简述89C51片内RAM的空间分配。
答:片内RAM有256B
低128B是真正的RAM区
高128B是SFR(特殊功能寄存器)区
5.简述布尔处理存储器的空间分配,片内RAM中包含哪些可位寻址单元。
答:片内RAM区从OOH~FFH(256B)
其中20H-2FH(字节地址)是位寻址区
对应的位地址是00H~7FH
6.如何简捷地判断89c51正在工作?
答:用示波器观察8051的XTAL2端是否有脉冲信号输出(判断震荡电路工作
是否正常?)
ALE(地址锁存允许)(AddressLatchEnable)输出是fosc的6分频
用示波器观察ALE是否有脉冲输出(判断8051芯片的好坏?)
观察PSEN(判断8051能够到EPROM或ROM中读取指令码?)
因为/PSEN接外部EPROM(ROM)的/OE端子
OE=OutputEnable(输出允许)
7.89c51如何确定和改变当前工作寄存器组?
答:PSW(程序状态字)(ProgramStatusWord)中的RS1和RSO
可以给出4中组合
用来从4组工作寄存器组中进行选择
PSW属于SFR(SpecialFunctionRegister)(特殊功能寄蠲)
8.89C51P0口用作通用工/O口输入时,若通过TTL"OC"门输入数据,应注
意什么?为什么?
答:
3读端口锁存器和"读引脚"有何不同?各使用哪种指令?
答:读锁存器(ANLP0,A)就是相当于从存储器中拿数据,而读引脚是从外部
拿数据(如MOVA,Pl这条指令就是读引脚的,意思就是把端口pl输入数据
送给A)
传送类MOV,判位转移JB、JNB、这些都属于读引脚,平时实验时经常
用这些指令于外部通信,判断外部键盘等;字节交换XCH、XCHD算术及逻辑
运算ORL、CPL、ANL、ADD、ADDC、SUBB、INC、DEC控制转移
CINE、DJNZ都属于读锁存器。
10.89C51P0-P3口结构有何不同?用作通用工/O口输入数据时,应注意什
么?
答:P0口内部没有上拉电阻,可以用做16位地址的低8位;
P3有第二功能;
P2口可以用做16位地址的高8位;
需要上拉电阻。OC门电路无法输出高低电平,只有靠上拉电阻才能实现
11.89C51单片机的EA信号有何功能?在使用8031时,EA信号引脚应如何
处理?
答:(D80C51单片机的EA信号的功能
EA为片外程序存储器访问允许信号,低电平有效;在编程时,其上施加21V
的编程电压
EA引脚接高电平时,程序从片内程序存储器开始执行,即访问片内存储
器;EA引脚接低电平时,迫使系统全部执行片外程序存储器程序。
(2)在使用80C31时,EA信号引脚的处理方法
因为80C31没有片内的程序存储器,所以在使用它时必定要有外部的程序
存储器,EA信号引脚应接低电平。
12.89C51单片机有哪些信号需要芯片引脚以第2功能的方式提供?
答:第一功能第二功能
串行口:
P3.0RXD(串行输入口)
P3.1TXD(串行输出口)
中断:
P3.2INTO外部中断0
P3.3INT1外部中断1
定时器/计数器(TO、T1):
P3.4TO(定时器/计数器0的外部输
入)
P3.5T1(定时器/计数器1的外部输
入)
数据存储器选通:
P3.6WR(外部存储器写选通,低电平
有效,输出)
P3.7RD(外部存储器读选通,低电平
有效,输出)
定时器/计数器(T2):
P1.0T2(定时器T2的计数端)
P1.1T2EX(定时器T2的外部输入端)
13.内部RAM低128字节单元划分为哪3个主要部分?各部分主要功能是什么?
答:片内RAM低128单元的划分及主要功能:
⑴工作寄存器组(OOH~IFH)
这是一个用寄存器直接寻址的区域,内部数据RAM区的O~31(OOH~IFH),
共32个单
蓝。它是4个通用工作寄存器组,每个组包含8个8位寄存器,编号为R0~R7。
(2)位寻址区(2OH~2FH)
从内部数据RAM区的32〜47(20H~2FH)的16个字节单元,共包含128
位,是可位寻
址的RAM区。这16个字节单元,既可进行字节寻址,又可实现位寻址。
⑶字节寻址区(30H~7FH)
从内部数据RAM区的48〜127(30H~7FH),共80个字节单元,可以采用
间接字节寻址
的方法访问。
14.使单片机复位有几种方法?复位后机器的初始状态如何?
答:(1)单片机复位方法
单片机复位方法有:上电自动复位、按键电平复位和外部脉冲三种方式,如
题图2-1所示。
题图2-1
(2)复位后的初始状态
复位后机器的初始状态,即各寄存器的状态:PC之外,复位操作还对其他一些
特殊功能寄存器有影响,它们的复位状态如题表2-1所例
15.开机复位后,CPU使用的是哪组工作寄存器沱们的地址是什么?CPU如何
确定和改变当前工作寄存器组?
答:一般开机复位后都是选择第一组通用工作寄存器作为工作寄存器的,一共有
4组,分别为0.123连续位于00h到1FH地址,
然后在机器中有个程序状态字PSW,它的第四和第三位RSI,RSO是用来选择
工作寄存器组的,可能不同机器地址稍有不同。他们俩的值和寄存器组的关系:
RS1/RS00/00/11/01/1
使用的工作寄存器0123
地址00-0708-0F10-1718-1F
写程序的时候就是通过定义程序状态字来选择使用不同的寄存器组。也可以直接
对RS1和RSO赋值。
(最后一问同题7)
16.程序状态寄存器PSW的作用是什么?常用标志有哪些位?作用是什么?
答:PSW是一个SFR(特殊功能寄存器)
位于片内RAM的高128B
具体地址DOH(OOH~FFH)(片内RAM的编址)(8bits编址方法)
PSW=ProgramStatusWord(程序状态字)
PSW的常用标志位有哪些?
CY=Carry(进位标志位)
AC=AuxiliaryCarry(辅助进位标志位)(半进位标志位)
F0用户标志位
RSI,RSO,用来选择当前工作寄存器组(R0〜R7)(4选1)
OV=Overflow(溢出标志位)
P二Parity(奇偶校验位)
17.位地址7cH与字节地址7cH如何区别?位地址7cH具体在片内RAM中的
什么位置?
答:用不同的寻址方式来加以区分,即访问128个位地址用位寻址方式,访问低
128字节单元用字节寻址和间接寻址。
具体地址为2F的第五位,即为7Ce
18.89C51单片机的时钟周期与振荡周期之间有什么关系?什么叫机器周期和指
令周期?
答:时钟信号的周期称为机器状态周期,是振荡周期的两倍。一个机器周期是指
CPU访问存储器一次所需的时间。指令周期是执行一条指令所需的时间。
19.一个机器周期的时序如何划分?
答:一个机器周期=12个震荡周期=6个时钟周期(状态周期)
S1P1,S1P2,S2P1,S2P2,S3P1,S3P2,S4P1,S4P2,S5P1,
S5P2,S6P1,S6P2其中s=state(状态),p=phase(相位)
20.什么叫堆栈?堆栈指针SP的作用是什么?89c51单片机堆栈的容量不能超过
多少字节?
答:堆栈都是一种数据项按序排列的数据结构,只能在一端(称为栈顶(top))对
数据项进行插入和删除。要点:堆:顺序随意栈:后进先出
(Last-In/First-Out)
在调用子程序时需要保存调用函数的CPU寄存器PC指针,PC指针是被
CALL指令自动压入SP所指向的片内存储器,CPU寄存器要由用户用PUSH指令
自行保存,因此SP的作用就是一个指针,当进行中断调用,子函数调用时将现场数
据压入SP所指向的存储器,SP自动增加1或2,当中断结束RETI,调用返回
RET,POP时将SP数据弹出,SP自动减1或,2
8051最大为128字节的片内存储器,0X20以上理论都可以做堆栈用96字
节,8052为256字节224字节可用,但这样便没有其它空间可用于甥居存储现
在的单片机的程序一般都能用C51来,不用关心堆栈大小与SP寄存器
21.89C51有几种低功耗方式?如何实现?
答:空闲方式和掉电方式
空闲方式和掉电方式是通过对SFR中的PCON(地址87H)相应位置1而
启动的。
当CPU执行完置IDL=l(PCON.l)的指令后,系统进入空闲工作方式。这时,
内部时钟不向CPU提供,而只供给中断、串行口、定时器部分。CPU的内部状
态维持,即包括堆栈指针SP、程序计数器PC、程序状态字PSW、累加器ACC
所有的内容保持不变,端口状态也保持不变。ALE和PSEN保持逻辑高电平。
当CPU执行一条置PC0N.1位(PD)为1的指令后,系统进入掉电工作方式。
在这种工作方式下,内部振荡器停止工作。由于没有振荡时钟,因此,所有的功
能部件都停止工作。但内部RAM区和特殊功能寄存器的内容被保留,而端口的
输出状态值都保存在对应的SFR中,ALE和PSEN都为低电平。
22.PC与DPTR各有哪些特点?有何异同?
答:(1)程序计数器PC作为不可寻址寄存器的特点
程序计数器PC是中央控制器申最基本的寄存器,是一个独立的计数器,存
放着下一条将程序存储器中取出的指令的地址。
程序计数器PC变化的轨迹决定程序的流程。程序计数器的宽度决定了程序
存储器可以
寻址的范围。
程序计数器PC的基本工作方式有:
①程序计数器PC自动加1。这是最基本的工作方式,也是这个专用寄存器
被称为计数
器的原因。
②执行条件或无条件转移指令时,程序计数器将被置入新的数值,程序的流
向发生变化。
变化的方式有下列几种:带符号的相对跳转SJMP、短目阵专AJMP、长目聃LJMP
及JMP@A+DPTR等。
③田丸行调用指令或响应中断时:
•PC的现行值,即下f将要执行的指令的地址送入堆栈,加以保护;
•将子程序的入口地址或者中断矢量地址送入PC,程序流向发生变化,执行
子程序或中断服务程序;
•子程序或中断服务程序执行完毕,遇到返回指令RET或RETI时,将栈顶
的内容送到PC寄存器中,程序流程又返回到原来的地方,继续执行。
(2)地姐旨针DPTR的特点
地幽旨针DPTR的特点是,它作为片外数据存储器寻址用的地址寄存器(间
接寻址)。
⑶地明旨针DPTR与程序计数器PC的异同
①相同之处:
・两者都是与地址有关的、16位的寄存器。其中,PC与程序存储器的地址
有关,而
DPTR与数据存储器的地址有关。
•作为地址寄存器使用时,PC与DPTR都是通过P0和P2口(作为16位地
址总线)输
出的。但是,PC的输出与ALE及PSEN有关;DPTR的输出,则与ALE、
RD及WR相联系。
②不同之处:
•PC只能作为16位寄存器对待,由于有自动加1的功能,故又称为计数器;
DPTR可以作为16位寄存器对待,也可以作为两个8位寄存器对待。
•PC是不可以访问的,有自己独特的变化方式,它的变化轨迹决定了程序执
行的流程;
DPTR是可以访问的,如MOVDPTR,#XXXXH,INCDPTPe
23.89C51端口锁存器的"读T修改一写"操作与"读引脚"操作有何区别?
答:指令系统中有些指令读锁存器的值,有些指令则读引脚上的值。读锁存器指
令是从锁存器中读取一个值并进行处理,把处理后的值(原值或已修改后的值)重
新写入锁存器中。这类指令称为读-修改-写指令。
对于读-修改-写指令。直接读锁存器而不是读端口弓I脚,是因为从引脚上读
出的数据不一定能真正反映锁存器的状态。
第三章
1、指令:CPU根据人的意图来执行某种操作的命令
指令系统:一台计算机所能执行的全部指令集合
机器语言:用二进制编码表示,计算机能直接识别和执行的语言
汇编语言:用助记符、符号和数字来表示指令的程序语言
高级语言:独立于机器的,在编程时不需要对机器结构及其指令系统有深入了解
的通用性语言
2、见第1题
3:简述8951的汇编指令格式。答:操作码[目的操作数][,涮暴作数]
4、简述8951的寻址方式^所能涉及的寻址空间。
寻址方式寻址空间
立即数寻程序存储器ROM
址
直接寻址片内RAM低128B、特殊功能寄存器
存器寻工作寄存器R0_R7、人、B、C、DPTR
寄存器间
片内RAM低128B、片外RAM
接寻址
变址寻址程序存储器(@A+PC,@A+DPTR)
相对寻址程序存储器256B范围(PC+偏移量)
位寻址片内RAM的20H-2FH字节地址、部分SFR
5、访问特殊功能寄存器和外数据存储器,应采用那些寻址方式?
答:SFR:直接寻址,位寻址,寄存器寻址;片外RAM:寄存器间接寻址
6、8951中已知(30H)=38H,请分析以下各是什么指令,说明源操作数的寻
址方式以及执行结果。
MOVA,40H;直接寻址(40H)-A
MOVRO,A;寄存器寻址(A)-RO
MOVPl,#OFOH;立即数寻址OFO-P1
MOV@RO,3OH;直接寻址(30H)—(RO)
MOVDPTR,#3848H;立即数寻址3848H-DPTR
MOV40H,38H;直接寻址(38H)—40H
MOVRO,3OH;■妾寻址(30H)-RO
MOVPO,RO;寄存器寻址(RO)-PO
MOV18H,#30H;立即数寻址30H-18H
MOVA,@R0;寄存器间接寻址((RO))-A
MOVP2,Pl;直接寻址(Pl)-P2
最后结果:(RO)=38H,(A)=40H,(P0)=38H,(P1)=(P2)=OFOH,
(DPTR)=3848H,(18H)=30H,(30H)=38H,(38H)=40H,(40H)
=40H,(48H)=38H
注意:一左边是内容,右边是单元
7、8951片内高128字节的地址寻址要注意什么/?
答:用直接寻址,位寻址,寄存器寻址
8、指出些列指令的本质?
MOVA,DATA;直接寻址2字节1周期
MOVA,#DATA;立即数寻址2字节1周期
MOVDATA1,DATA2;直接寻址3字节2周期
MOV74H,#78H;立即数寻址3字节2周期
如果想查某一指令的机器码,字节数或周期数可查阅书本后面的附录A
9、设R0的内容分为32H,A的内容为48H,0000请指出在执行下列程序段后
上述各单元内容的变化?
MOVA,@RO;((R0))=80H-A
MOV@R0,40H;(40H)=08H-(R0)
MOV40H,A;(A)=80-40H
MOVRO,#35H;35H-R0
最后结果:(RO)=35H(A)=80H,(32H)=08H,(40H)=80H
10、如何访问SFR,可采用那些寻址方式?
答:用直接寻址,位寻址,寄存器寻址
11、如何访问片外RAM,可使用那些寻址方式?
答:只能采用寄存器间接寻址(用MOVX指令)
12、如何访问片内RAM,可使用那些寻址方式?
答:低128字节:直接寻址,位寻址,寄存器间接寻址,寄存器寻址(R0~R7)
高128字节:直接寻址,位寻址,寄存器寻址
13、如何访问片内外程序存储器,可使用那些寻址方式?
答:采用变址寻址(用MOVC指令)
14、说明十进制调整的原因和方法?
答:压缩BCD码在进行加法运算时应逢十进一,而计算机只将其当作十六进制数
处理,此时得到的结果不正确。用DAA指令调整(加06H,60H,66H)
15、说明8951布尔机处理机功能?
答:用来进行彳端作
16、ANLA,#17H;83HAi7H=03H-A
ORL17H,A;34Hv03H=37H^17H
XRLA,@R0;03H㊉37H=34H
CPLA;34H求反等于CBH
所以(A)=CBH
17s(1)SETBACC.0或SETBEOH;EOH是累力口器的地址
(2)CLRACC.7
CLRACC.6
CLRACC.5
CLRACC.4
(3)CLRACC.6
CLRACC.5
CLRACC.4
CLRACC.3
18、MOV27H,R7
MOV26H,R6
MOV25H,R5
MOV24H,R4
MOV23H,R3
MOV22H,R2
MOV21H,RI
MOV20H,RO
19、MOV2FH,20
MOV2EH,21
MOV2DH,22
20、编程,进行两个16频的减法:6F5DH-13B4H,结果存入内部RAM的
30和31H单元,30H存低八位。
CLRC
MOVA,#5DH;被减数的低8位一A
MOVR2,#B4H;减数低8位一R2
SUBBA,R2;被减数减去减数,差一A
MOV30H,A;低8位结转-30H
MOVA,#6FH;被减数的高8位-A
MOVR2,#13H;减数高8位一R2
SUBBA,R2;被减数减去减数,差一A
MOV31H,A;高8位结果-30H
注意:如果在你的程序中用到了进位位,在程序开始的时候要记得清0进位位
21、编程,若累加器A满足下列条件,则程序转至LABEL存储单元,设A中为
无符号数。
(1)A>10
CJNEA,#0AH,LI;(A)与10比较,不等转LI
LJMPLABEL;相等转LABEL
LI:JNCLABEL;(A)大于10,转LABEL
或者:
CLRC
SUBBA,#0AH
JNCLABEL
(2)A>10
CJNEA,#0AH,LI;(A)与10匕俄,不等转LI
RET;相等结束
L1:JNCLABEL;(A)大于10,转LABEL
RET;(A)小于10,结束
或者:
CLRC
SUBBA,#0AH
JNCLI
RET
LI:JNZLABEL
RET
(3)A<10
CJNEA,#0AH,LI;(A)与10匕俄,不等转L1
L2:LJMPLABEL;相等转LABEL
LI:JCL2;(A)小于10,转L2
RET
或者:
CLRC
SUBBA,#0AH
JCLABEL
JZLABEL
RET
22、(SP)=23H,(PC)=3412H
参看书上80页
23、(SP)=27H,(26H)=48H,(27H)=23H,(PC)=3456H
参看书上79页
24、不能。ACALL是短转指令,可调用的地址范围是2KB。
在看这个题的时候同时看一下AJMP指令。同时考虑调用指令ACALL和LCALL
指令和RET指令的关系。
25、编程,查找内部RAM中20H-50H单元中是否有0AAH这一数据,若有
则将51h单元置为01H,如无,则将51H单元清零。
MOVR2,#31H;数据块长度TR2
MOVRO,#20H;数据块首地址-R0
LOOP:MOVA,@R0;待查找的数据一A
CLRC;清进位位
SUBBA,#0AAH;待查找的数据是0AAH吗
JZLI;是,转LI
INCRO;不是,地址增1,指向下一个待查数据
DJNZR2,LOOP;数据块长度减1,不等于0,继续查找
MOV51H,#00H;等于0,未找至IL00H-51H
RET
L1:MOV51H,#01H;找到,01H-51H
RET
26、编程查找内部RAM的20H-50H单元中出现00H的次数并将结果存入51H
中。
MOVR2,#31H;数据块长度-R2
MOVRO,#20H;数据块首地址-R0
LOOP:MOVA,@R0;待查找的数据一A
JNZLI;不为。,转L1
INC51H;为0,00H个数增1
LI:INCRO;地址增1,指向下一个待查数据
DJNZR2,LOOP;数据块长度减1,不等于0,继续查找
RET
27、外部数据RAM中有一个数据块,首地址为SOURCE,要求将该数据传送到
内部RAM以DIST开头的区域在,直到遇到数字字符¥时结束。
MOVDPTR,#SOURCE;源首地址一DPTR
MOVRO,#DIST;目的首地址iRO
LOOP:MOVXA,@DPTR;侬一个钠
MOV@R0,A
INCDPTR;指向下一个那
INCRO
CJNEA,#24H,LOOP;传送的是字符吗?不是,传送
下一个字符
RET
28、已知R3和R4中存有一个十六位的二进制数,高位在3中,低位在4中,
编程求其补,并存回原处。
MOVA,R3;取该数高8位-A
ANLA,#80H;取出该数符号判断
JZLI•星TF新蛀11
‘;是负数’,将该数低8位一A
MOVA,R4
CPLA;低8位取反
ADDA,#01H;加1
MOVR4,A;低8位取反加1后-R4
MOVA,R3;将该数高8位一A
CPLA;高8位则
ADDCA,#00H;加上低8位加1时可能产生的进位
MOVR3,A;高8位取反加1后-R3
LI:RET
29、已知30H和31H中存有一个十六位的二进制数,高位在前,低位在后,
编程将它们乘2,并存回原处。
CLRC;清进位位C
MOVA,31H;取该数低8位一A
RLCA;带进位位左移1位
MOV31H,A;结果存回31H
MOVA,30H;取该数高8位一A
RLCA;带进位位左移1位
MOV30H,A;结果存回30H
30、内存中有两个4字节以压缩的BCD码形式存放的十进制数,一个放在
30H-33H的单元中,一个放在40H-43H的单元中,编程求他们的和,结果放
在30H-33H的单元中。
MOVR2,#04H;字节长度一R2
MOVRO,#30H;一个加数首地址一RO
MOVRI,#40H;另一个加数首地址一RI
CLRC;清进位位
LOOP:MOVA,@R0;取一个加数
ADDCA,@R1;两个加数带进位位相加
DAA;十进制调整
MOV@R0,A;存放结果
INCRO;指向下一个字节
INCRI
DJNZR2,LOOP;娄好居块长度减1,不等于0,继续查找
RET
31、编程,把片外RAM从2000H开始存放的8个数传送到片内30H开始的
单元中。
MOVR2,#08H;数据块长度-R2
MOVRO,#30H;数据块目的地址-RO
MOVDPTR,#2000H;数据块源地址一DPTR
LOOP:MOVXA,@DPTR"堡一个数据
MOV@R0,A
INCDPTR;指向下一个数据
INCRO;
DJNZR2,LOOP;娄好居块长度减1,没传送完,继续传送
RET
35、解:(1000H)=53H(1001H)=54H(1002H)=41H
(1003H)=52H(1004H)=54H(1005H)=12H
(1006H)=34H(1007H)=30H(1008H)=00H
(1009H)=70H
36、阅读下列程序说明其功能
MOVRO,#40H;40H-R0
MOVA,@R0;98H-A
INCRO;41H-R0
ADDA,@R0;98H+(41H)=47H-A
INCRO
MOV@R0,A;结果存入42H单兀
CLRA;清人
ADDCA,#0;进位位存入A
INCRO
MOV@R0,A;进位位存入43H
功能:将40H,41H单元中的内容相加结果放在42H单元,进位放在43H单
元(RO)=43H,(A)=1,(40H)=98H,(41H)=AFH,(42H)=47H,
(43H)=01H
37、同上题
MOVA,61H;F2H-A
MOVB,#02H;02H-B
MULAB;F2HxO2H=E4H—A
ADDA,62H;积的低8位加上CCH-A
MOV63H,A;结果送62H
CLRA;清A
ADDCA,B;积的高8位加进位位一A
MOV64H,A;结果送64H
功能:将61H单元的内容乘2,低8位再加上62H单元的内容放入63H,
果的高8位放在64H单元(A)=02H,(B)=01H,(61H)=F2H,(62H)
=CCH,(63H)=BOH,(64H)=02H
39、MOVA,XXH
ORLA,#80H
MOVXXH,A
40、(2)MOVA,XXH
MOVRO,A
XRLA,RO
第五章
1、什么是中断和中断系统?其主要功能是什么?
答:当CPU正在处理某件事情的时候,外部发生的某T牛事件请求CPU迅速去
处理,于是,CPU暂时中止当前的工作,转去处理所发生的事件,中断服务处理
完该事件以后,再回到原来被终止的地方,继续原来的工作。这种过程称为中断,
实现这种功能的部件称为中断系统。功能:
(1)使计算机具有实时处理能力,能对外界异步发生的事件作出及时的处理
(2)完全消除了CPU在查询方式中的等待现象,大大提高了CPU的工作效
率
(3)实现实时控制
2、试编写一段对中断系统初始化的程序,使之允许INTO,INTI,TO,串行口
中断,且使T0中断为高优先级中断。
解:MOVIE,#097H
MOVIP,#02H
3、在单片机中,中断能实现哪些功能?
答:有三种功能:分时操作,实时处理,故障处理
4、89C51共有哪些中断源?对其中端请求如何进行控制?
答(1)89C51有如下中断源
①:外部中断0请求,低电平有效
②:外部中断1请求,低电平有效
③T0:定时器、计数器0溢出中断请求
④T1:定时器、计数器1溢出中断请求
⑤TX/RX:串行接口中断请求
(2)通过对特殊功能寄存器TCON、SCON、正、IP的各位进行置位或复位等
操作,可实现各种中断控制功能
5、什么是中断优先级?中断优先处理的原则是什么?
答:中断优先级是CPU相应中断的先后顺序。原则:
(1)先响应优先级高的中断请求,再响应优先级低的
(2)如果一个中断请求已经被响应,同级的其它中断请求将被禁止
(3)如果同级的多个请求同时出现,则CPU通过内部硬件查询电路,按查
询顺序确定应该响应哪个中断请求
查询顺序:外部中断0-定时器0中断一外部中断11定时器1中断一串行接口
中断
6、说明外部中断请求的查询和响应过程。
答:当CPU执行主程序第K条指令,外设向CPU发出中断请求,CPU接到中
断请求信号并在本条指令执行完后,中断主程序的执行并保存断点地址,然后转
去响应中断。CPU在每个S5P2期间顺序采样每个中断源,CPU在下一个机器
周期S6期间按优先级111页序查询中断标志,如果查询到某个中断标志为1,将在接
下来的机器周期S1期间按优先级进行中断处理,中断系统通过硬件自动将相应
的中断矢量地址装入PC,以便进入相应的中断服务程序。中断服务完毕后,CPU
返回到主程序第K+1条指令继续执行。
7、89c51在什么条件下可响应中断?
答:
71)有中断源发出中断请求
(2)中断中允许位EA=1.即CPU开中断
(3)申请中断的中断源的中断允许位为1,即中断没有被屏蔽
(4)无同级或更高级中断正在服务
(5)当前指令周期已经结束
(6)若现行指令为RET;或访问IE或IP指令时,该指令以及紧接着的另一
条指令已执行完毕
8、简述89c51单片机的中断响应过程。
答:CPU在每个机器周期S5P2期间顺序采样每个中断源,CPU在下一个机器
周期S6期间按优先级顺序查询中断标志,如查询到某个中断标志为1,将在接下
来的机器周期S1期间按优先级进行中断处理,中断系统通过硬件自动将相应的
中断矢量地址装入PC,以便进入相应的中断服务程序。一旦响应中断,89C51
首先置位相应的中断"优先级生效"触发器,然后由硬件执行一条长调用指令,
把当前的PC值压入堆栈,以保护断点,再应的中断服务的入口地址送入PC,
于是CPU接着从中断服务程序的入口处开始执行。对于有些中断源,CPU在响
应中断后会自动清除中断标志。
9、在89C51内存中,应如何安排程序区?
答:主程序一般从0030H开始,主程序后T殳是子程序及中断服务程序。在这
个大家还要清除各个中断的中断矢量地址。
10、试述中断的作用及中断的全过程。
答:作用:对外部异步发生的事件作出及时的处理
过程:中断请求,中断响应,中断处理,中断返回
11、当正在执行某一个中断源的中断服务程序时,如果有新的中断请求出现,试
问在什么情况下可响应新的中断请求?在什么情况下不能响应新的中断请求?
答:(1)符合以下6个条件可响应新的中断请求:
a)有中断源发出中断请求
b)中断允许位EA=1,即CPU开中断
c)申请中断的中断源的中断允许位为1,即中断没有被屏蔽d)无同级或更高级
中断正在被服务
①当前的指令周期已结束
f)若现行指令为RETI%访问IE或IP指令时,该指令以及紧接着的另一条指令已
被执行完
12、89C51单片机外部中断源有几种触发中断请求的方法?如何实现中断请求?
答:有两种方式:电平触发和边沿触发
电平触发方式:CPU在每个机器周期的S5P2期间采样外部中断引脚的输入电平。
若为低电平,使IE1QE0)置"1",申请中断;若为高电平,则lEl(IEO)清零。
边沿触发方式:CPU在每个机器周期S5P2期间采样外部中断请求引脚的输入电
平。如果在相继的两个机器周期采样过程中,一个机器周期采样到外部中断请求
为高电平,接着下一个机器周期采样到外部中断请求为低电平,则使IE1QEO)置
"1"申请中断;否则,IE1(IEO)置0。
13、89C51单片机有五个中断源,但只能设置两个中断优先级,因此,在中断优
先级安排上受到一定的限制。试问以下几种中断优先W页序的安排(级别由高到低)
是否可能:若可能,则应如何设置中断源的中断级别:否则,请简述不可能的理
由。
(1)定时器0,定时器I,外中断0,外中断I,串行口中断。
可以,MOVIP,#0AH
⑵串行口中断,外中断0,定时器0,外中断1,定时器L可以,MOV
IB#10H
(3)外中断0,定时器1,外中断1,定时器0,串行口中断。
不可以,只能设置一级高级优先级,如果将INT0J1设置为高级,而T0级
别高于INT1.
(4)外中断0,外栅1,串行口中断,定时器0,定时器1。可以,MOV
IP#15H
⑸串行口中断,定时器0,外中断0,外中断1,定时器1。不可以
(6)外中断0,外中断1,定时器0,串行口中断,定时器1。不可以
⑺外中断0,定时器1,定时器0,外中断1,串行口中断。可以,MOV
IP,#09H
14、89C51各中断源的中断标志是如何产生的?又是如何清0的?CPU响应中
断时,中断入口地址各是多少?
答:各中断标志的产生和清"0"如下:
(1)外部中断类
外部中断是由外部原因引起的,可以通过两个固定引脚,即外部中断。和外部中
断1输入信号。
外部中断0请求信号,由P3.2脚输入。通过IT0来决定中断请求信号是低电平
有效还是下跳变有效。一旦输入信号葭,则向CPU申请中断,并且使IE0=l。
硬件复位。
外部中断1请求信号,功能与用法类似外部中断0
(2)定时中断类
定时中断是为满足定时或计数溢出处理需要而设置的。当定时器/计数器中的计数
结构发生计数溢出的,即表明定时时间到或计数值已满,这时就以计数溢出信号
作为中断请求,去置位一个溢出标志位。这种中断请求是在单片机芯片内部发生
的,无需在芯片上设置引入端,但在计数方式时,中断源可以由外部引入。
TF0:定时器T0溢出中断请求。当定时器T0产生溢出时,定时器T0请求标志
TFO=1,请求中断处理。使用中断时由硬件复位,在查询方式下可由软件复位。
TF1:定时器T1溢出中断请求。功能与用法类似定时器T0
(3)串行口中断类
串行口中断是为串行数据的传送需要而设置的。串行中断请求也是在单片机芯片
内部发生的,但当串行口作为接收端时,必须有一完整的串行帧数据从RI端引入
芯片,才可能引发中断。
RI或TI:串行口中断请求。当接收或发送一串帧数据时,使内部串行口中断请求
标志RI或TI=1,并请求中断。响应后必须软件复位。
CPU响应中断时,中断入口地址如下:
中断源入口地址
外部中断00003H
定时器T0中断OOOBH
外部中断10013H
定时器T1中断001BH
串行口中断0023H
15、中断响应时间是否为确定不变的?为什么?
答:中断响应时间不是确定不变的。由于CPU不是在任何情况下对中断请求都予
以响应的;止矽卜,不同的情况对中断响应的时间也是不同的。下面以外部中断为
例,说明中断响应的时间。
在每个机器周期的S5P2期间,端的电平被所存到TCON的IE0位,CPU在下
一个机器周期才会查询这些值。这时满足中断响应条件,下一条要执行的指令将
是一条硬件长调用指令"LCALL",使程序转入中断矢量入口。调用本身要用2
个机器周期,这样,从外部中断请求有效到开始执行中断服务程序的第一条指令,
至少需要3个机器周期,这是最短的响应时间。
如果遇到中断受阻的情况,这中断响应时间会更长一些。例如,当一个同级或更
高级的中断服务程序正在进行,则附加的等待时间取决于正在进行的中断服务程
序:如果正在执行的一条指令还没有进行到最后一个机器周期,附加的等待时间
为1~3个机器周期;如果正在执行的是RETI指令或者访问IE或IP的指令,则
附加的等待时间在5个机器周期内。
若系统中只有一个中断源,则响应时间为3~8个机器周期。
16、中断响应过程中,为什么通常要保护现场?如何保护?
答:因为一般主程序和中断服务程序都可能会用到累加器,PSW寄存器及其他一
些寄存器。CPU在进入中断服务程序后,用到上述寄存器时,就会破坏它原来存
在寄存器中的内容;一旦中断返回,将会造成主程序的混乱。因而在进入中断服
务程序后,一般要先保护现场,然后再执行中断处理程序,在返回主程序以前再
恢复现场。
保护方法」般是把累加器、PSW寄存器及其他一些与主程序有关的寄存器压入堆
栈。在保护现场和恢复现场时,为了不使现场受到破坏或者造成混乱,一般规定
此时CPU不响应新的中断请求。这就要求在编写中断服务程序时,注意在保护现
场之前要关中断,在恢复现场之后开中断。如果在中断处理时允许有更高级的中
断打断它,则在保护现场之后再开中断,恢复现场之前关中断。
17、;言又述中断响应的CPU操作过程,为什么说中断操作是一个CPU的微查询
过程?
答:在中断响应中,CPU要完成以下自主操作过程:
a)置位相应的优先级状态触发器,以标明所响应中断的优先级别b)中断源标
志清零(TLRI除外)
c)中断断点地址装入堆栈保护(不保护PSW)
d)中断入口地址装入PC,以便使程序转到中断入口地址处
在计算机内部,中断表现为CPU的微查询操作。89C51单片机中,CPU在每个
机器周期的S6状态,查询中断源,并按优先级管理规则处理同时请求的中断源,
且在下一个机器周期的S1状态中,响应最高级中断请求。
但是以下情况除外:
a)CPU正在处理相同或更高优先级中断
b)多机器周期指令中,还未执行到最后一个机器周期
c)正在执行中断系统的SFR操作,如RETI指令及访问IE、IP等操作时,要延
后一条指令
18、在中断请求有效并开中断状况下,能否保证立即响应中断?有什么条件?
答:在中断请求有效并开中断状况下,并不能保证立即响应中断。这是因为,在
计算机内部,中断表现为CPU的微查询操作。89C51单片机中,CPU在每个机
器周期的S6状态下,查询中断源,并按优先级管理规则处理同时请求的中断源,
且在下一个机器周期的S1状态中,响应最高级中断请求。
在以下情况下,还需要有另外的等待:
a)CPU正在处理相同或更高优先级中断
b)多机器周期指令中,还未执行到最后一个机器周期
c)正在执行中断系统的SFR操作,如RETI指令及访问IE、IP等操作时,要延后
一条指令
第6章习题答案
1、定时器模式2有什么特点?适用于什么场合?
答:(1)模式2把TLO(或TL1)配置成一个可以自动重装载的8位定时器/计数
器。TLO计数溢出时不仅使溢出中断标志位TFO置1,而且还自动把THO中的
内容重新装载到TLO中。TLO用作8位计数器,THO用以保存初值。
(2)用于定时工作方式时间(TFO溢出周期)为,用于计数工作方式时,最大
计数长度(THO初值=0)为28=256个夕卜部脉冲。
这种工作方式可省去用户软件重装初值的语句,并可产生相当精确定时时间,特
别适于作串行波特率发生器。
2、单片机内部定时方式产生频率为100KHZ等宽矩形波,假定单片机的晶振频
率为12MHZ,请编程实现。
答:
TO低5位:1BH
TO高8位:FFH
MOVTMOD,#OOH;设置定时器TO工作于模式0
MOVTLO,#1BH;设置5ms定时初值
MOVTHO,#OFFH
SETBTRO;启动TO
LOOPJBCTFO,LI;查询到定时时间到?时间到转L1
SJMPLOOP;时间未到转LOOP,继续查询
L1:MOVTLO,#1BH;重新置入定时初值
MOVTHO,#OFFH
CPLP1.0;输出取反,形成等宽矩形波
SJMPLOOP;重复循环
3、89C51定时器有哪几种工作模式?有何区别?
答:有四种工作模式:模式0,模式1,模式2,模式3
(1)模式0:选择定时器的高8位和低5位组成一个13位定时器/计数器。
TL低5位溢出时向TH进位,TH溢出时向中断标志位TF进位,并申请中断。
定时时间t=(213-初值)x振荡周期xl2;计数长度位213=8192个外部脉冲
(2)模式1:与模式0的唯一差别是寄存器TH和TL以全部16位参与操作。
定时时间t=(216-初值)x振荡周期xl2;计数长度位216=65536个外部脉冲
(3)模式2:把TLO和TL1配置成一个自动重装载的8位定时器/计数器。
TL用作8位计数器,TH用以保存初值。TL计数溢出时不仅使TFO置1,而且
还自动将TH中的内容重新装载到TL中。
定时时间t=(28-初值)x振荡周期xl2;计数长度位28二256个外部脉冲
(4)模式3:对TO和T1不大相同
若设TO位模式3,TLO和THO被分为两个相互独立的8位计数器。TLO为8位
计数器,功能与模式0和模式1相同,可定时可计数。
THO仅用作简单的内部定时功能,它占用了定时器T1的控制位TR1和中断标志
位TF1,启动和关闭仅受TR1控制。
定时器T1无工作模式3,但TO在工作模式3时T1仍可设置为0~2。
4、89C51内部设有几个定时器/计数器?它们是由哪些特殊功能寄存器组成?
答:89C51单片机内有两个16位定时器/计数器,即TO和T1。
TO由两个8位特殊功能寄存器THO和TLO组成;T1由TH1和TL1组成。
5、定时器用作定时器时,其定时时间与哪些因素有关?作计数器时,对外界计数
频率有何限制?
答:定时时间与定时器的工作模式,初值及振荡周期有关。
作计数器时对外界计数频率要求最高为机器振荡频率的1/24。
6、简述定时器4种工作模式的特点,如何选择设定?
答:
71)模式0:选择定时器的高8位和低5位组成一个13位定时器/计数器。
TL低5位溢出时向TH进位,TH溢出时向中断标志位TF进位,并申请中断。
定时时间t=(213-初值)x振荡周期xl2;计数长度位213=8192个外部脉冲
置TMOD中的M1M0为00
(2)模式1:与模式0的唯一差别是寄存器TH和TL以全部16位参与操作。
定时时间t=(216-初值)x振荡周期xl2;计数长度位216=65536个外部脉冲
置TMOD中的M1M0为01
(3)模式2:把
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中国银行财富管理部经理的客户管理策略
- 2026年高考地理二轮复习:人口与城乡发展 主题(一)人口分布与人口迁移
- 陆秀夫演讲稿比赛
- 财政监督干部演讲稿
- 送考研学长祝福演讲稿
- 2025-2026学年统编版八年级历史上册知识点复习
- 税务人员抗疫演讲稿
- 2025-2026学年人教版七年级上英语期末复习专练:阅读理解之应用文
- 2025-2026学年人教版九年级英语全册作文期末复习
- 2026年一级建造师《机电工程管理与实务》教材对比明细
- 高中物理知识点总结大全
- 爱国教育:什么是爱国教学课件
- 家居陈列设计课件
- 2025年全球水资源治理的国际合作机制
- 危险化学品事故应急处置
- 餐厅安全用电气水培训课件
- 1.手术室患者人文关怀管理规范中国生命关怀协会团体标准TCALC003-2023
- 2025年中国热敏纸成色剂ODB-2行业市场分析及投资价值评估前景预测报告
- 爱弯腰的痘痘课件
- 快速康复肺癌围手术期护理
- 师德师风培训课件
评论
0/150
提交评论