若需要将35h位运算 取最高位的1与最低位取反,其他位不变,要进行什么运算

单片机复习题含答案_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
单片机复习题含答案
上传于||暂无简介
阅读已结束,如果下载本文需要使用
想免费下载本文?
下载文档到电脑,查找使用更方便
还剩4页未读,继续阅读
你可能喜欢c语言中的位运算符中“按位取反”是怎么运算的?什么是负数的反码?
c语言中的位运算符中“按位取反”是怎么运算的?什么是负数的反码?
09-01-20 &
0001 取反 1110 符号位为1,取反+1为 1010 转化成10进制为 -2正数的原码,补码,反码都相同,都等于它本身 负数的补码是:符号位为1,其余各位求反,末位加1 反码是:符号位为1,其余各位求反,但末位不加1 也就是说,反码末位加上1就是补码
反 除符号位,按位取反
补 除符号位,按位取反再加1 正数的原反补是一样的 在计算机中,数据是以补码的形式存储的: 在n位的机器数中,最高位为符号位,该位为零表示为正,为1表示为负; 其余n-1位为数值位,各位的值可为0或1。 当真值为正时:原码、反码、补码数值位完全相同; 当真值为负时: 原码的数值位保持原样, 反码的数值位是原码数值位的各位取反, 补码则是反码的最低位加一。 注意符号位不变。 如:若机器数是16位: 十进制数 17 的原码、反码与补码均为: 0001 十进制数-17 的原码、反码与补码分别为:、1111
请登录后再发表评论!公考,家教,作文,写作,答案,中考,高考,语文,英语,培训,教师,律师,秘书,文秘,作业,辅导
&>&&>&单片机原理及接口技术课后答案_(第三版)
单片机原理及接口技术课后答案_(第三版)_28000字
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个
(7)定时器/计数器: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区从00H~FFH(256B)
其中20H~2FH(字节地址)是位寻址区
对应的位地址是00H~7FH
6. 如何简捷地判断89C51正在工作?
答:用示波器观察8051的XTAL2端是否有脉冲信号输出(判断震荡电路工作是否正常?)
ALE(地址锁存允许)(Address Latch Enable)输出是fosc的6分频
用示波器观察ALE是否有脉冲输出(判断 8051芯片的好坏?)
观察PSEN(判断8051能够到EPROM 或ROM中读取指令码?)
因为/PSEN接外部EPROM(ROM)的/OE端子
OE=Output Enable(输出允许)
7. 89C51如何确定和改变当前工作寄存器组?
答:PSW(程序状态字)(Program Status Word)中的RS1和RS0
可以给出4中组合
用来从4组工作寄存器组中进行选择
PSW属于SFR(Special Function Register)(特殊功能寄存器)
8. 89C51 P0口用作通用I/O口输入时,若通过TTL“OC”门输入数据,应注意什么?为什么?
9. 读端口锁存器和“读引脚”有何不同?各使用哪种指令?
答:读锁存器(ANL P0,A)就是相当于从存储器中拿数据,而读引脚是从外部拿数据(如MOV A,P1 这条指令就是读引脚的,意思就是把端口p1输入数据送给A)
传送类MOV,判位转移JB、JNB、这些都属于读引脚,平时实验时经常用这些指令于外部通信,判断外部键盘等;字节交换XCH、XCHD算术及逻辑运算 ORL、CPL、ANL、ADD、ADDC、SUBB、INC、DEC控制转移CJNE、DJNZ都属于读锁存器。
10. 89C51 P0~P3口结构有何不同?用作通用I/O口输入数据时,应注意什么?
答:P0口内部没有上拉电阻,可以用做16位地址的低8位;
P3有第二功能;
P2口可以用做16位地址的高8位;
需要上拉电阻。OC门电路无法输出高低电平,只有靠上拉电阻才能实现
11. 89C51单片机的EA信号有何功能?在使用8031时,EA信号引脚应如何处理?
答:(1)80C51单片机的EA信号的功能
EA为片外程序存储器访问允许信号,低电平有效;在编程时,其上施加21V的编程电压
EA引脚接高电平时,程序从片内程序存储器开始执行,即访问片内存储器;EA引脚接低电平时,迫使系统全部执行片外程序存储器程序。
(2)在使用80C31时,EA信号引脚的处理方法
因为80C31没有片内的程序存储器,所以在使用它时必定要有外部的程序存储器,EA 信号引脚应接低电平。
12. 89C51单片机有哪些信号需要芯片引脚以第2功能的方式提供?
答: 第一功能
RXD(串行输入口)
TXD(串行输出口)
INT0外部中断0
INT1外部中断1
定时器/计数器(T0、T1):
T0(定时器/计数器0的外部输入)
T1(定时器/计数器1的外部输入)
数据存储器选通:
WR(外部存储器写选通,低电平有效,输出)
RD(外部存储器读选通,低电平有效,输出)
定时器/计数器(T2):
T2(定时器T2的计数端)
T2EX(定时器T2的外部输入端)
13. 内部RAM低128字节单元划分为哪3个主要部分?各部分主要功能是什么?
答:片内RAM低128单元的划分及主要功能:
(l)工作寄存器组(00H~lFH)
这是一个用寄存器直接寻址的区域,内部数据RAM区的0~31(00H~lFH),共32个单
元。它是4个通用工作寄存器组,每个组包含8个8位寄存器,编号为R0~R7。
(2)位寻址区(20H~2FH)
从内部数据RAM区的32~47(20H~2FH)的16个字节单元,共包含128位,是可位寻
址的RAM区。这16个字节单元,既可进行字节寻址,又可实现位寻址。
(3)字节寻址区(30H~7FH)
从内部数据RAM区的48~127(30H~7FH),共80个字节单元,可以采用间接字节寻址
的方法访问。
14. 使单片机复位有几种方法?复位后机器的初始状态如何?
答:(1)单片机复位方法
单片机复位方法有:上电自动复位、按键电平复位和外部脉冲三种方式,如题图2-1所示。
(2)复位后的初始状态
复位后机器的初始状态,即各寄存器的状态:PC之外,复位操作还对其他一些特殊功能寄存器有影响,它们的复位状态如题表2-1所例
15. 开机复位后,CPU使用的是哪组工作寄存器?它们的地址是什么?CPU如何确定和改变当前工作寄存器组? 答:一般开机复位后都是选择第一组通用工作寄存器作为工作寄存器的,一共有4组,分别为0.1.2.3连续位于00h到1FH地址,
然后在机器中有个程序状态字PSW,它的第四和第三位RS1,RS0是用来选择工作寄存器组的,可能不同机器地址稍有不同。他们俩的值和寄存器组的关系:
使用的工作寄存器
00-07 08-0F 10-17 18-1F
写程序的时候就是通过定义程序状态字来选择使用不同的寄存器组。也可以直接对RS1和RS0赋值。
(最后一问同题7)
16. 程序状态寄存器PSW的作用是什么?常用标志有哪些位?作用是什么?
答:PSW是一个SFR(特殊功能寄存器)
位于片内RAM的高128B
具体地址D0H(00H~FFH)(片内RAM的编址)(8bits编址方法)
PSW=Program Status Word(程序状态字)
PSW的常用标志位有哪些?
CY=Carry(进位标志位)
AC=Auxiliary Carry(辅助进位标志位)(半进位标志位)
F0用户标志位
RS1,RS0,用来选择当前工作寄存器组(R0~R7)(4选1)
OV=Overflow(溢出标志位)
P=Parity(奇偶校验位)
17. 位地址7CH与字节地址7CH如何区别?位地址7CH具体在片内RAM中的什么位置?
答:用不同的寻址方式来加以区分,即访问128个位地址用位寻址方式,访问低128字节单元用字节寻址和间接寻址。
具体地址为2F的第五位,即为7C。
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字节,字节224字节可用,但这样便没有其它空间可用于数据存储现在的单片机的程序一般都能用C51来,不用关心堆栈大小与SP寄存器
21. 89C51有几种低功耗方式?如何实现?
答:空闲方式和掉电方式
空闲方式和掉电方式是通过对SFR中的PCON(地址87H)相应位置1而启动的。
当CPU执行完置IDL=1(PCON.1)的指令后,系统进入空闲工作方式。这时,内部时钟不向CPU提供,而只供给中断、串行口、定时器部分。CPU的内部状态维持,即包括堆栈指针SP、程序计数器PC、程序状态字PSW、累加器ACC所有的内容保持不变,端口状态也保持不变。ALE和PSEN保持逻辑高电平。
当CPU执行一条置PCON.1位(PD)为1的指令后,系统进入掉电工作方式。在这种工作方式下,内部振荡器停止工作。由于没有振荡时钟,因此,所有的功能部件都停止工作。但内部RAM区和特殊功能寄存器的内容被保留,而端口的输出状态值都保存在对应的SFR中,ALE和PSEN都为低电平。
22. PC与DPTR各有哪些特点?有何异同?
答:(1)程序计数器PC作为不可寻址寄存器的特点
程序计数器PC是中央控制器申最基本的寄存器,是一个独立的计数器,存放着下一条将程序存储器中取出的指令的地址。
程序计数器PC变化的轨迹决定程序的流程。程序计数器的宽度决定了程序存储器可以
寻址的范围。
程序计数器PC的基本工作方式有:
①程序计数器PC自动加1。这是最基本的工作方式,也是这个专用寄存器被称为计数
器的原因。
②执行条件或无条件转移指令时,程序计数器将被置入新的数值,程序的流向发生变化。
变化的方式有下列几种:带符号的相对跳转SJMP、短跳转AJMP、长跳转LJMP及JMP
@A+DPTR等。
③在执行调用指令或响应中断时:
●PC的现行值,即下一条将要执行的指令的地址送入堆栈,加以保护;
●将子程序的入口地址或者中断矢量地址送入PC,程序流向发生变化,执行子程序或中断服务程序;
●子程序或中断服务程序执行完毕,遇到返回指令RET或RETI时,将栈顶的内容送到PC寄存器中,程序流程又返回到原来的地方,继续执行。
(2)地址指针DPTR的特点
地址指针DPTR的特点是,它作为片外数据存储器寻址用的地址寄存器(间接寻址)。
(3)地址指针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是可以访问的,如MOV
DPTR,#XXXXH,INC DPTP。
23. 89C51端口锁存器的“读—修改—写”操作与“读引脚”操作有何区别?
答:指令系统中有些指令读锁存器的值, 有些指令则读引脚上的值。读锁存器指令是从锁存器中读取一个值并进行处理, 把处理后的值(原值或已修改后的值)重新写入锁存器中。这类指令称为读-修改-写指令。
对于读-修改-写指令。直接读锁存器而不是读端口引脚, 是因为从引脚上读出的数据不一定能真正反映锁存器的状态。
指令:CPU根据人的意图来执行某种操作的命令
指令系统:一台计算机所能执行的全部指令集合
机器语言:用二进制编码表示,计算机能直接识别和执行的语言
汇编语言:用助记符、符号和数字来表示指令的程序语言
高级语言:独立于机器的,在编程时不需要对机器结构及其指令系统有深入了解的通用性语言
3、简述8951的汇编指令格式。答: 操作码
[目的操作数]
[,源操作数]
5、访问特殊功能寄存器和外数据存储器,应采用那些寻址方式?
SFR:直接寻址,位寻址,寄存器寻址;片外RAM:寄存器间接寻址
6、8951中已知(30H)=38H,请分析以下各是什么指令,说明源操作数的寻址方式以及执行结果。
;直接寻址(40H)→A
R0,A;寄存器寻址(A)→R0
;立即数寻址0F0→P1
@R0,30H;直接寻址(30H) →(R0)
DPTR,#3848H;立即数寻址
3848H→DPTR
40H,38H;直接寻址 (38H) →40H
R0,30H;直接寻址 (30H) →R0
P0,R0;寄存器寻址( R0 )→P0
;立即数寻址30H→18H
;寄存器间接寻址 ((R0)) →A
;直接寻址 (P1)→P2
最后结果:(R0)=38H,(A)=40H,(P0)=38H,(P1)=(P2)=0F0H,(DPTR)=3848H,(18H)=30H,(30H)=38H,(38H)=40H,(40H)=40H,(48H)=38H
注意:→左边是内容,右边是单元
7、8951片内高128字节的地址寻址要注意什么/?
用直接寻址,位寻址,寄存器寻址
8、指出些列指令的本质?
A,DATA ;直接寻址
A,#DATA 2字节1周期 ;立即数寻址 2字节1周期 ;直接寻址 3字节2周期 MOV
DATA1,DATA2 MOV
74H,#78H ;立即数寻址 3字节2周期
如果想查某一指令的机器码,字节数或周期数可查阅书本后面的附录A
9、设R0的内容分为32H,A的内容为48H,。。。。请指出在执行下列程序段后上述各单元内容的变化?
MOV MOV MOV MOV A,@R0 ;((R0))=80H→A @R0,40H ;(40H)=08H→(R0) 40H,A ;(A)=80→40H R0,#35H ;35H→R0
最后结果:(R0)=35H
(A)=80H,(32H)=08H,(40H)=80H
10、如何访问SFR,可采用那些寻址方式?
答:用直接寻址,位寻址,寄存器寻址
11、如何访问片外RAM,可使用那些寻址方式?
答:只能采用寄存器间接寻址(用MOVX指令)
12、如何访问片内RAM,可使用那些寻址方式?
答:低128字节:直接寻址,位寻址,寄存器间接寻址,寄存器寻址(R0~R7)
高128字节:直接寻址,位寻址,寄存器寻址
13、如何访问片内外程序存储器,可使用那些寻址方式?
答:采用变址寻址(用MOVC指令)
14、说明十进制调整的原因和方法?
答:压缩BCD码在进行加法运算时应逢十进一,而计算机只将其当作十六进制数处理,此时得到的结果不正确。用DA
A指令调整(加06H,60H,66H)
15、说明8951布尔机处理机功能?
答:用来进行位操作
;83H∧17H=03H→A
;34H∨03H=37H→17H
;03H⊕37H=34H
;34H求反等于CBH
所以(A)=CBH
17、(1)SETB
ACC.0或SETB
E0HE0H是累加器的地址
(2)CLR ACC.7
20、编程,进行两个16位数的减法:6F5DH-13B4H,结果存入内部RAM的30和31H单元,30H存低八位。 CLR
;被减数的低8位→A
;减数低8位→R2
;被减数减去减数,差→A
;低8位结果→30H
;被减数的高8位→A
;减数高8位→R2
;被减数减去减数,差→A
;高8位结果→30H
注意:如果在你的程序中用到了进位位,在程序开始的时候要记得清0进位位
21、编程,若累加器A满足下列条件,则程序转至LABEL存储单元,设A中为无符号数。
(1)A≥10
A,#0AH,L1
;(A)与10比较,不等转L1
;相等转LABEL
;(A)大于10,转LABEL
(2)A>10
A,#0AH,L1
;(A)与10比较,不等转L1
;相等结束
;(A)大于10,转LABEL
;(A)小于10,结束
(3)A≤10
A,#0AH,L1
;(A)与10比较,不等转L1
;相等转LABEL
;(A)小于10,转L2
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单元清零。
;数据块长度→R2
;数据块首地址→R0
;待查找的数据→A
;清进位位
SUBB A,#0AAH
;待查找的数据是0AAH吗
;是,转L1
;不是,地址增1,指向下一个待查数据
;数据块长度减1,不等于0,继续查找
;等于0,未找到,00H→51H
;找到,01H→51H
26、编程查找内部RAM的20H-50H单元中出现00H的次数并将结果存入51H中。
;数据块长度→R2
;数据块首地址→R0
;待查找的数据→A
;不为0,转L1
;为0,00H个数增1
;地址增1,指向下一个待查数据
;数据块长度减1,不等于0,继续查找
27、外部数据RAM中有一个数据块,首地址为SOURCE,要求将该数据传送到内部RAM以DIST开头的区域在,直到遇到数字字符¥时结束。
DPTR,#SOURCE
;源首地址→DPTR
;目的首地址→R0
LOOP:MOVX
;传送一个字符
;指向下一个字符
A,#24H,LOOP
;传送的是“$”字符吗?不是,传送下一个字符
已知R3和R4中存有一个十六位的二进制数,高位在3中,低位在4中,编程求其补,并存回原处。
;取该数高8位→A
;取出该数符号判断
;是正数,转L1
;是负数,将该数低8位→A
;低8位取反
;低8位取反加1后→R4
;将该数高8位→A
;高8位取反
;加上低8位加1时可能产生的进位
;高8位取反加1后→R3
29、 已知30H和31H中存有一个十六位的二进制数,高位在前,低位在后,编程将它们乘2,并存回原处。
;清进位位C
;取该数低8位→A
;带进位位左移1位
;结果存回31H
;取该数高8位→A
;带进位位左移1位
;结果存回30H
30、 内存中有两个4字节以压缩的BCD码形式存放的十进制数,一个放在30H-33H的单元中,一个放在40H-43H的单元中,编程求他们的和,结果放在30H-33H的单元中。
;字节长度→R2
;一个加数首地址→R0
;另一个加数首地址→R1
;清进位位
;取一个加数
;两个加数带进位位相加
;十进制调整
;存放结果
;指向下一个字节
;数据块长度减1,不等于0,继续查找
31、编程,把片外RAM从2000H开始存放的8个数传送到片内30H开始的单元中。
;数据块长度→R2
;数据块目的地址→R0
DPTR,#2000H
;数据块源地址→DPTR
LOOP:MOVX
;传送一个数据
;指向下一个数据
;数据块长度减1,没传送完,继续传送
35、解:(1000H)=53H
(1001H)=54H
(1002H)=41H
(1003H)=52H
(1004H)=54H
(1005H)=12H
(1006H)=34H
(1007H)=30H
(1008H)=00H
(1009H)=70H
36、阅读下列程序说明其功能
;98H+(41H)=47H→A
;结果存入42H单元
;进位位存入A
;进位位存入43H
功能:将40H,41H单元中的内容相加结果放在42H单元,进位放在43H单元,(R0)=43H,(A)=1,(40H)=98H,(41H)=AFH,(42H)=47H,(43H)=01H
37、同上题
;F2H×O2H=E4H→A
ADD A,62H
;积的低8位加上CCH→A
;结果送62H
;积的高8位加进位位→A
;结果送64H
功能:将61H单元的内容乘2,低8位再加上62H单元的内容放入63H,将结果的高8位放在64H单元。(A)=02H,
(B)=01H,(61H)=F2H,(62H)=CCH,(63H)=B0H,(64H)=02H
MOV XXH,A
40、(2)MOV
1、什么是中断和中断系统?其主要功能是什么?
答:当CPU正在处理某件事情的时候,外部发生的某一件事件请求CPU迅速去处理,于是,CPU暂时中止当前的工作,转去处理所发生的事件,中断服务处理完该事件以后,再回到原来被终止的地方,继续原来的工作。这种过程称为中断,实现这种功能的部件称为中断系统。功能:
使计算机具有实时处理能力,能对外界异步发生的事件作出及时的处理
完全消除了CPU在查询方式中的等待现象,大大提高了CPU的工作效率
实现实时控制
2、试编写一段对中断系统初始化的程序,使之允许INT0,INT1,TO,串行口中断,且使T0中断为高优先级中断。 解:MOV
3、在单片机中,中断能实现哪些功能?
答:有三种功能:分时操作,实时处理,故障处理
4、89C51共有哪些中断源?对其中端请求如何进行控制?
答:(1)89C51有如下中断源
① :外部中断0请求,低电平有效
② :外部中断1请求,低电平有效
③T0:定时器、计数器0溢出中断请求
④T1:定时器、计数器1溢出中断请求
⑤TX/RX:串行接口中断请求
(2)通过对特殊功能寄存器TCON、SCON、IE、IP的各位进行置位或复位等操作,可实现各种中断控制功能
5、什么是中断优先级?中断优先处理的原则是什么?
答:中断优先级是CPU相应中断的先后顺序。原则:
先响应优先级高的中断请求,再响应优先级低的
如果一个中断请求已经被响应,同级的其它中断请求将被禁止
如果同级的多个请求同时出现,则CPU通过内部硬件查询电路,按查询顺序确定应该响应哪个中断请求 查询顺序:外部中断0→定时器0中断→外部中断1→定时器1中断→串行接口中断
6、说明外部中断请求的查询和响应过程。
答:当CPU执行主程序第K条指令,外设向CPU发出中断请求,CPU接到中断请求信号并在本条指令执行完后,中断主程序的执行并保存断点地址,然后转去响应中断。CPU在每个S5P2期间顺序采样每个中断源,CPU在下一个机器周期S6期间按优先级顺序查询中断标志,如果查询到某个中断标志为1,将在接下来的机器周期S1期间按优先级进行中断处理,中断系统通过硬件自动将相应的中断矢量地址装入PC,以便进入相应的中断服务程序。中断服务完毕后,CPU返回到主程序第K+1条指令继续执行。
7、89C51在什么条件下可响应中断?
有中断源发出中断请求
中断中允许位EA=1.即CPU开中断
申请中断的中断源的中断允许位为1,即中断没有被屏蔽
无同级或更高级中断正在服务
当前指令周期已经结束
若现行指令为RETI或访问IE或IP指令时,该指令以及紧接着的另一条指令已执行完毕
8、简述89C51单片机的中断响应过程。
答:CPU在每个机器周期S5P2期间顺序采样每个中断源,CPU在下一个机器周期S6期间按优先级顺序查询中断标志,如查询到某个中断标志为1,将在接下来的机器周期S1期间按优先级进行中断处理,中断系统通过硬件自动将相应的中断矢量地址装入PC,以便进入相应的中断服务程序。一旦响应中断,89C51首先置位相应的中断“优先
级生效”触发器,然后由硬件执行一条长调用指令,把当前的PC值压入堆栈,以保护断点,再将相应的中断服务的入口地址送入PC,于是CPU接着从中断服务程序的入口处开始执行。对于有些中断源,CPU在响应中断后会自动清除中断标志。
9、在89C51内存中,应如何安排程序区?
答:主程序一般从0030H开始,主程序后一般是子程序及中断服务程序。在这个大家还要清除各个中断的中断矢量地址。
10、试述中断的作用及中断的全过程。
答:作用:对外部异步发生的事件作出及时的处理
过程:中断请求,中断响应,中断处理,中断返回
11、当正在执行某一个中断源的中断服务程序时,如果有新的中断请求出现,试问在什么情况下可响应新的中断请求?在什么情况下不能响应新的中断请求?
答:(1)符合以下6个条件可响应新的中断请求:
a)有中断源发出中断请求
b)中断允许位EA=1,即CPU开中断
c)申请中断的中断源的中断允许位为1,即中断没有被屏蔽
d)无同级或更高级中断正在被服务
e)当前的指令周期已结束
f)若现行指令为RETI或访问IE或IP指令时,该指令以及紧接着的另一条指令已被执行完
12、89C51单片机外部中断源有几种触发中断请求的方法?如何实现中断请求?
答:有两种方式:电平触发和边沿触发
电平触发方式:CPU在每个机器周期的S5P2期间采样外部中断引脚的输入电平。若为低电平,使IE1(IE0)置“1,”申请中断;若为高电平,则IE1(IE0)清零。
边沿触发方式:CPU在每个机器周期S5P2期间采样外部中断请求引脚的输入电平。如果在相继的两个机器周期采样过程中,一个机器周期采样到外部中断请求为高电平,接着下一个机器周期采样到外部中断请求为低电平,则使IE1(IE0)置“1”申请中断;否则,IE1(IE0)置0。
13、89C51单片机有五个中断源,但只能设置两个中断优先级,因此,在中断优先级安排上受到一定的限制。试问以下几种中断优先顺序的安排(级别由高到低)是否可能:若可能,则应如何设置中断源的中断级别:否则,请简述不可能的理由。
定时器0,定时器1,外中断0,外中断1,串行口中断。
串行口中断,外中断0,定时器0,外中断1,定时器1。
外中断0,定时器1,外中断1,定时器0,串行口中断。
不可以,只能设置一级高级优先级,如果将INT0,T1设置为高级,而T0级别 高于INT1.
外中断0,外中断1,串行口中断, 定时器0,定时器1 。
串行口中断,定时器0,外中断0,外中断1,定时器1。
外中断0,外中断1,定时器0,串行口中断,定时器1 。 不可以
外中断0,定时器1,定时器0,外中断1,串行口中断。
14、89C51各中断源的中断标志是如何产生的?又是如何清0的?CPU响应中断时,中断入口地址各是多少?
答:各中断标志的产生和清“0”如下:
外部中断类
外部中断是由外部原因引起的,可以通过两个固定引脚,即外部中断0和外部中断1输入信号。
外部中断0请求信号,由P3.2脚输入。通过IT0来决定中断请求信号是低电平有效还是下跳变有效。一旦输入信号有效,则向CPU申请中断,并且使IE0=1。硬件复位。
外部中断1请求信号,功能与用法类似外部中断0
定时中断类
定时中断是为满足定时或计数溢出处理需要而设置的。当定时器/计数器中的计数结构发生计数溢出的,即表明定时时间到或计数值已满,这时就以计数溢出信号作为中断请求,去置位一个溢出标志位。这种中断请求是在单片机芯片内部发生的,无需在芯片上设置引入端,但在计数方式时,中断源可以由外部引入。
TF0:定时器T0溢出中断请求。当定时器T0产生溢出时,定时器T0请求标志TF0=1,请求中断处理。使用中断时由硬件复位,在查询方式下可由软件复位。
TF1:定时器T1溢出中断请求。功能与用法类似定时器T0
串行口中断类
串行口中断是为串行数据的传送需要而设置的。串行中断请求也是在单片机芯片内部发生的,但当串行口作为接收端时,必须有一完整的串行帧数据从RI端引入芯片,才可能引发中断。
RI或TI:串行口中断请求。当接收或发送一串帧数据时,使内部串行口中断请求标志RI或TI=1,并请求中断。响应后必须软件复位。
CPU响应中断时,中断入口地址如下:
定时器T0中断 000BH
定时器T1中断 001BH
串行口中断
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) 中断源标志清零(TI、RI除外)
c) 中断断点地址装入堆栈保护(不保护PSW)
d) 中断入口地址装入PC,以便使程序转到中断入口地址处
在计算机内部,中断表现为CPU的微查询操作。89C51单片机中,CPU在每个机器周期的S6状态,查询中断源,并按优先级管理规则处理同时请求的中断源,且在下一个机器周期的S1状态中,响应最高级中断请求。
但是以下情况除外:
a) CPU正在处理相同或更高优先级中断
b)多机器周期指令中,还未执行到最后一个机器周期
c) 正在执行中断系统的SFR操作,如RETI指令及访问IE、IP等操作时,要延后一条指令
18、在中断请求有效并开中断状况下,能否保证立即响应中断?有什么条件?
答:在中断请求有效并开中断状况下,并不能保证立即响应中断。这是因为,在计算机内部,中断表现为CPU的微查询操作。89C51单片机中,CPU在每个机器周期的S6状态下,查询中断源,并按优先级管理规则处理同时请求的中断源,且在下一个机器周期的S1状态中,响应最高级中断请求。
在以下情况下,还需要有另外的等待:
CPU正在处理相同或更高优先级中断
b) 多机器周期指令中,还未执行到最后一个机器周期
c)正在执行中断系统的SFR操作,如RETI指令及访问IE、IP等操作时,要延后一条指令
第6章习题答案
1、定时器模式2有什么特点?适用于什么场合?
答:(1)模式2把TL0(或TL1)配置成一个可以自动重装载的8位定时器/计数器。TL0计数溢出时不仅使溢出中断标志位TF0置1,而且还自动把TH0中的内容重新装载到TL0中。TL0用作8位计数器,TH0用以保存初值。
(2)用于定时工作方式时间(TF0溢出周期)为 ,用于计数工作方式时,最大计数长度(TH0初值=0)为28=256个外部脉冲。
这种工作方式可省去用户软件重装初值的语句,并可产生相当精确定时时间,特别适于作串行波特率发生器。
2、单片机内部定时方式产生频率为100KHZ等宽矩形波,假定单片机的晶振频率为12MHZ,请编程实现。
T0低5位:1BH
T0高8位:FFH
TMOD,#00H设置定时器T0工作于模式0
;设置5ms定时初值
TF0,L1;查询到定时时间到?时间到转L1
;时间未到转LOOP,继续查询
TL0,#1BH;重新置入定时初值
P1.0输出取反,形成等宽矩形波
;重复循环
3、89C51定时器有哪几种工作模式?有何区别?
答:有四种工作模式:模式0,模式1,模式2,模式3
模式0:选择定时器的高8位和低5位组成一个13位定时器/计数器。TL低5位溢出时向TH进位,TH溢出时向中断标志位TF进位,并申请中断。
定时时间t=(213-初值)×振荡周期×12;计数长度位213=8192个外部脉冲
模式1:与模式0的唯一差别是寄存器TH和TL以全部16位参与操作。定时时间t=(216-初值)×振荡周期×12;计数长度位216=65536个外部脉冲
模式2:把TL0和TL1配置成一个自动重装载的8位定时器/计数器。TL用作8位计数器,TH用以保存初值。TL计数溢出时不仅使TF0置1,而且还自动将TH中的内容重新装载到TL中。
定时时间t=(28-初值)×振荡周期×12;计数长度位28=256个外部脉冲
模式3:对T0和T1不大相同
若设T0位模式3,TL0和TH0被分为两个相互独立的8位计数器。TL0为8位计数器,功能与模式0和模式1相同,可定时可计数。
TH0仅用作简单的内部定时功能,它占用了定时器T1的控制位TR1和中断标志位TF1,启动和关闭仅受TR1控制。 定时器T1无工作模式3,但T0在工作模式3时T1仍可设置为0~2。
4、89C51内部设有几个定时器/计数器?它们是由哪些特殊功能寄存器组成?
答:89C51单片机内有两个16位定时器/计数器,即T0和T1。
T0由两个8位特殊功能寄存器TH0和TL0组成;T1由TH1和TL1组成。
5、定时器用作定时器时,其定时时间与哪些因素有关?作计数器时,对外界计数频率有何限制?
答:定时时间与定时器的工作模式,初值及振荡周期有关。
作计数器时对外界计数频率要求最高为机器振荡频率的1/24。
6、简述定时器4种工作模式的特点,如何选择设定?
模式0:选择定时器的高8位和低5位组成一个13位定时器/计数器。TL低5位溢出时向TH进位,TH
溢出时向中断标志位TF进位,并申请中断。
定时时间t=(213-初值)×振荡周期×12;计数长度位213=8192个外部脉冲
置TMOD中的M1M0为00
模式1:与模式0的唯一差别是寄存器TH和TL以全部16位参与操作。定时时间t=(216-初值)×振荡周期×12;计数长度位216=65536个外部脉冲
置TMOD中的M1M0为01
模式2:把TL0和TL1配置成一个自动重装载的8位定时器/计数器。TL用作8位计数器,TH用以保存初值。TL计数溢出时不仅使TF0置1,而且还自动将TH中的内容重新装载到TL中。
定时时间t=(28-初值)×振荡周期×12;计数长度位28=256个外部脉冲
置TMOD中的M1M0为10
模式3:对T0和T1不大相同
若设T0位模式3,TL0和TH0被分为两个相互独立的8位计数器。TL0为8位计数器,功能与模式0和模式1相同,可定时可计数。
TH0仅用作简单的内部定时功能,它占用了定时器T1的控制位TR1和中断标志位TF1,启动和关闭仅受TR1控制。 定时器T1无工作模式3,但T0在工作模式3时T1仍可设置为0~2。
置TMOD中的M1M0为11
7、当T0用作模式3时,由于TR1已被T0占用,如何控制T1的开启和关闭?
答:用T1控制位C/T切换定时器或计数器工作方式就可以使T1运行。定时器T1无工作模式3,将T1设置为工作模式3,就会使T1立即停止计数,关闭。
8、以定时器/计数器1进行外部时间计数,每计数1000个脉冲后,定时器/计数器1转为定时工作方式,定时10ms后又转为计数方式,如此循环不止。假定 为6WHZ,用模式1编程。
解:T1为定时器时初值:
T1为计数器时初值:
TMOD,#50H设置T1为计数方式且工作模式为1
TH1,#0FCH置入计数初值
TR1启动T1计数器
TF1,L2查询计数溢出?有溢出(计数满1000个)转L2
LOOP1无溢出转LOOP1,继续查询
TMOD,#10H设置T1为定时方式且工作与模式1
TH1,#0ECH置入定时10ms初值
TR1启动T1定时
TF1,L1查询10ms时间到?时间到,转L1
LOOP2时间未到,转LOOP2,继续查询
9、一个定时器定时时间有限,如何实现两个定时器的串行定时以满足较长定时时间的要求?
答:当一个定时器溢出时,设置另一个定时器的初值为0开始定时。
10、使用一个定时器,如何通过软硬件结合方法实现较长时间的定时?
答:设定好定时器的定时时间,采用中断方式用软件设置计数次数,进行溢出次数累计,从而得到较长的时间。 11、89C51定时器作定时和计数时其计数脉冲分别由谁提供?
答:作定时器时计数脉冲由89C51片内振荡器输出经12分频后的脉冲提供,作计数时计数脉冲由外部信号通过引脚P3.4和P3.5提供。
12、89C51定时器的门控信号GATE设置为1时定时器如何启动?
答:只有 (或 )引脚为高电平且由软件使TR0(或TR1)置1时,才能启动定时器工作。
13、已知89C51单片机的fosc=6MHz, 请利用T0和P1.0输出矩形波。矩形波高电平宽50μs,低电平宽300μs。 解:T0采用模式2作为50μs定时时的初值:
所以 作300μs定时时的初值:
TMOD,#02H设置定时器T0工作于模式2
P1.0P1.0输出低电平
TH0,#6AH置入定时300μs初值
LOOP1:JBC TF0,L1;查询300μs时间到?时间到,转L1
LOOP1时间未到,转LOOP1,继续查询
P1.0P1.0输出高电平
TH0,#0E7H置入定时300μs初值
TL0,# 0E7H
TR0 启动T0
LOOP2:JBC TF0,L2 ;查询50μs时间到?时间到,转L2
LOOP2时间未到,转LOOP2,继续查询
14、已知89C51单片机的fosc=12MHz, 用T1定时。试编程由P1.0和P1.1引脚分别输出周期为 2ms和500μs的方波。
解:采用模式0作 定时初值:
R2,#04HR2为“250μs”计数器,置入初值4
P1.0P1.0输出低电平
P1.1P1.1输出低电平
TH1,#0F8H置入定时250μs初值
TF1,L1查询250μs时间到?时间到,转L1
LOOP时间未到,转LOOP,继续查询
P1.1;P1.1输出取反,形成周期为500μs
TR1 ;关闭T1
R2,L2;“250μs”计数器减1,到1ms吗?未到转L2
P1.0P1.0输出取反,形成周期为2ms方波
R2,#04H重置“250μs”计数器初值4
L2重复循环
15、单片机8031的时钟频率为6MHz,若要求定时值分别为0.1ms,1ms,10ms,定时器0工作在模式0、模式1和模式2时,其定时器初值各应是多少?
T0低5位01110B=0EH
T0高8位:B=FEH
T0低5位01100B=0CH
T0高8位:B=F0H
在此情况下最长定时为512μs,无法一次实现定时1ms,可用0.1ms循环10次
T0低5位11000B=18H
T0高8位:H
模式2:在此情况下最长定时为512μs,无法一次实现定时10ms,可用0.1ms循环100次
16、89C51单片机的定时器在何种设置下可提供三个8位计数器定时器?这时,定时器1可作为串行口波特率发生器。若波特率按9600b/s,4800b/s,2400b/s,1200b/s,600b/s,100b/s来考虑,则此时可选用的波特率是多少(允许存在一定误差)?设fosc=12MHz。
解:当T0为模式3,T1为模式2时,可提供3个8位定时器。
可选100b/s
17、试编制一段程序,功能为:当P1.2引脚的电平上跳时,对P1.1的输入脉冲进行计数;当P1.2引脚的电平下跳时,停止计数,并将计数值写入R6,R7。
TMOD,#05HT0为计数方式且工作于模式1
P1.2,$等待P1.2引脚电平上跳
TH0,#00H P1.2电平上跳,置入计数初值
P1.2,$等待P1.2引脚电平下跳
TR0电平下跳,关闭T0
R7,TH0计数初值写入R7,R6
18、 设fosc=12MHz。试编制一段程序,功能为:对定时器T0初始化,使之工作在模式2,产生200μs定时,并用查询T0溢出标志的方法,控制 P1.0输出周期为2ms的方波。
解:T0作定时器时初值:
P1.0P1.0输出低电平
R2,#05HR2为“200μs”计数器,置入初值5,计1ms
TMOD,#02H设定时器T0工作于模式2
TH0,#38H置入定时初值
TF0,L1查询200μs时间到?时间到,转L1
LOOP时间未到,转LOOP,继续查询
R2,L2“200μs”计数器减1,到1ms吗?未到,转L2
;到1ms,P1.0取反,形成周期为2ms的方波
R2,#05H重置“200μs”计数器初值
L2重复循环
TMOD,#02H设定时器T0工作于模式2
P1.0P1.0输出低电平
R2,#05HR2为“200μs”计数器,置入初值5,计1ms
TH0,#38H置入定时初值
TF0,$查询200μs时间到?时间到,继续查询
R2,LOOP“200μs”计数器减1,到1ms吗?未到,转LOOP
;到1ms,P1.0取反,形成周期为2ms的方波
LOOP1重复循环
19、以中断方法设计单片机秒、分脉冲发生器。假定P1.0每秒产生1个机器周期的正脉冲,P1.1每分产生1个周期的正脉冲。
1、什么是串行异步通信,它有哪些作用?
答:在异步串行通信中,数据是一帧一帧(包括一个字符代码或一字节数据)传送的,每一帧的数据格式参考书。通信采用帧格式,无需同步字符。存在空闲位也是异步通信的特征之一。
2、89C51单片机的串行口由哪些功能部件组成?各有什么作用?
答:89C51单片机的串行接口由发送缓冲期SBUF,接收缓冲期SBUF、输入移位寄存器、串行接口控制器SCON、定时器T1构成的波特率发生器等部件组成。
由发送缓冲期SBUF发送数据,接收缓冲期SBUF接收数据。串行接口通信的工作方式选择、接收和发送控制及状态等均由串行接口控制寄存器SCON控制和指示。定时器T1产生串行通信所需的波特率。
3、简述串行口接收和发送数据的过程。
答:串行接口的接收和发送是对同一地址(99H)两个物理空间的特殊功能寄存器SBUF进行读和写的。当向SBUF发“写”命令时(执行“MOV
SBUF,A”),即向缓冲期SBUF装载并开始TXD引脚向外发送一帧数据,发送完便使发送中断标志位TI=1。
在满足串行接口接收中断标志位RI(SCON.0)=0的条件下,置允许接收位REN(SCON.4)=1,就会接收一帧数据进入移位寄存器,并装载到接收SBUF中,同时使RI=1。当发读SBUF命令时(执行“MOV
A, SBUF”),便由接收缓冲期SBUF取出信息通过89C51内部总线送CPU。
4、89C51串行口有几种工作方式?有几种帧格式?各工作方式的波特率如何确定?
答:89C51串行口有4种工作方式:
方式0(8位同步移位寄存器),方式1(10位异步收发),方式2(11位异步收发),方式3(11位异步收发)。 有2种帧格式:10位,11位
方式0:方式0的波特率≌fosc/12(波特率固定为振荡频率1/12)
方式2:方式2波特率≌2SMOD/64×fosc
方式1和方式3:方式1和方式3波特率≌2SMOD/32×(T1溢出速率)
如果T1采用模式2则:
5、若异步通信接口按方式3传送,已知其每分钟传送3600个字符,其波特率是多少?
答:已知每分钟传送3600个字符,方式3每个字符11位,则:
波特率=(11b/字符)×(3600字符/60s)=660b/s
6、89C51中SCON的SM2,TB8,RB8有何作用?
答:89c51SCON的SM2是多机通信控制位,主要用于方式2和方式3.若置SM2=1,则允许多机通信。
TB8是发送数据的第9位,在方式2或方式3中,根据发送数据的需要由软件置位或复位。它在许多通信协议中可用作奇偶校验位;在多机通信中作为发送地址帧或数据帧的标志位。
RB8是接收数据的第9位,在方式2或方式3中接收到的第9位数据放在RB8位。它或是约定的奇偶校验位,或是约定的地址/数据标示位。
7、设fosc=11.059MHz,试编写一段程序,其功能为对串行口初始化,使之工作与方式1,波特率为1200b/s;并用查询串行口状态的方法,读出接收缓冲器的数据并回送到发送缓冲器。
SCON,#40H串行接口工作于方式1
TMOD,#20H定时器T1工作于模式2
TH1,#0E8H赋定时器计数初值
TR1启动定时器T1
A,SBUF读出接收缓冲器数据
SBUF,A启动发送过程
TI,$等待发送完
TI清TI标志
8、若晶振为11.0592MHz,串行口工作与方式1,波特率为4800b/s。写出用T1作为波特率发生器的方式字和计数初值。
TMOD,#20H定时器T1工作于模式2
TH1,#0FAH赋定时器计数初值
9、为什么定时器T1用作串行口波特率发生器时,常选用工作模式2?若已知系统时钟频率和通信用的波特率,如何计算其初值?
答:因为工作模式2是自动重装初值定时器,编程时无需重装时间参数(计数初值),比较使用。若选用工作模式0或工作模式1,当定时器T1溢出时,需在中断服务程序中重装初值。
已知系统时钟频率fosc和通信用的波特率fbaud,可得出定时器T1模式2的初值
10、若定时器T1设置成模式2作波特率发生器,已知fosc=6MHz。求可能产生的最高和最低的波特率。 解:最高波特率为T1定时最小值时,此时初值为255,并且SMOD=1,有:
最高波特率为T1定时最大值时,此时初值为0,并且SMOD=0,有:
11、串行通信的总线标准是什么?有哪些内容?
答:美国电子工业协会(EIA)正式公布的串行总线接口标准有RS-232C,RS-422,RS-423和RS-485等。
在异步串行通信中应用最广的标准总线是RD-232C。它包括了按位串行传输的电气和机械方面的规定,如适用范围、信号特性、接口信号及引脚说明等,适用于短距离(<15m)或带调制解调的通信场合。采用RS-422, RS-485标准时,通信距离可达1000m。
12、简述单片几多机通信的原理。
答:当一片89C51(主机)与多片89C51(从机)通信时,所有从机的SM2位都置1.主机首先发送的一帧数据为地址,即某从机机号,其中第9位为1,所有的从机接收到数据后,将其中第9位装入RB8中。各从机根据收到的
第9位数据(RB8中)的值来决定从机可否再接收主机的信息。若(RB8)=0,说明是数据帧,则使接收中断标志位RI=0,信息丢失;若(RB8)=1说明是地址帧,数据装入SBUF并置RI=1,中断所有从机,只有被寻址的目标从机清除SM2(SM2=0),以接收主机发来的一帧数据(点对点通信)。其他从机仍然保持SM2=1.
13、当89C51串行口按工作方式1进行串行数据通信时。假定波特率为1200b/s,以中断方式传送数据。请编写全双工通信程序。
解:设系统时钟频率fosc=6.0MHZ。查教材表9-2可知,可取SMOD=0,T1的计数初值为F3H。程序如下:
MAIN上电,转向主程序
0023H串行口的中断入口地址
SERVE转向中断服务程序
0040H主程序
SP,#60H设置堆栈指针
SCON ,#50H
PCON ,#00H
R0 ,#20H置发送数据区首地址
;置接收数据区首地址
;置发送字节长度
;置接收字节长度
ES允许串行口中断
EACPU允许中断
;取第一个数据发送
SBUF ,A发送第一个数据
;等待中断
SERVE: JNB
RI ,SENDTI=1,为发送中断
A ,SBUF读出接收缓冲区内容
@R1 ,A读入接收缓冲区
R6 ,L1判断数据块发送完否
L2数据块接收完,转L2
R1修改数据区指针
L2:RETI中断返回
TI清除发送中断标志
R7 ,L3判断数据块发送完否
L4数据块接收完,转L4
A ,@R0取数据发送
SBUF ,A发送数据
R0修改数据地址
RETI中断返回
14、以89C51串行口按工作方式3进行串行数据通信。假定波特率为1200b/s,第9数据位作奇偶校验位,以中断方式传送数据。请编写通信程序。
MAIN上电,转向主程序
0023H串行口的中断入口地址
STOP转向中断服务程序
0040H主程序
SCON ,#0D0H
PCON ,#00H
R0 ,#20H置发送数据区首地址
;置接收数据区首地址
ES允许串行口中断
EACPU允许中断
C, PSW.0P→C
SBUF ,A发送第一个数据
RI SOUTTI=1,为发送中断
A ,SBUF读出接收缓冲区内容
C ,PSW.0P→C
C形成奇校验
LOOP1判断接收端的奇偶值,C=1转LOOP1
RB8 ,LOOP2C=0,RB8=0,转LOOP2
ERRORC=0,RB8=1,转出错处理
RB8 ,LOOP2C=1,RB8=1,转LOOP2
ERRORC=0,RB8=1,转出错处理
@R1 ,A将接收数据送入接收数据区
R1修改数据区指针
TI是发送中断,清除发送中断标志
R0修改数据区指针
PSW.0, CP→C
SBUF ,A发送第一个数据
ERROR:……
15、某异步通信接口,其帧格式由1个起始位(0),7个数据位,1个奇偶校验位和1个停止位(1)组成。当该接口每分钟传送1800个字符时,试计算出传送波特率。
解:该异步通信接口的帧格式为10b/字符,当该接口每分钟传送1800个字符时:
波特率=(10b/字符)×(1800字符/60s)=300b/s
16、串行口工作在方式1和方式3时,其波特率与fosc、定时器T1工作模式2的初值及SMOD位的关系如何?设fosc=6MHz,现利用定时器T1模式2产生的波特率为110b/s。试计算定时器初值。
解:关系如下:
当波特率为110b/s,fosc=6MHz,令SMOD=0,有:
17、设计一个单片机的双机通信系统,并编写通信程序。将甲机内部RAM 40H--4FH存储区中去。
参考教材例题7-12
1.微处理器,RAM,ROM,以及I/O口,定时器,构成的微型计算机称为单片机。
2.指令寄存器(IR)保存当前正在执行的一条指令;指令译码器(ID)对操作码进行译码。
3.程序计数器(PC)指示出将要执行的下一条指令地址,由两个8位计数器PCH及PCL组成。
4.80C31片内没有程序存储器,80C51内部设有4KB的掩膜ROM程序存储器,87C51是将80C51片内的ROM换成EPROM,89C51则换成4KB的闪存FLASHROM,51增强型的程序存储器容量是普通型的2倍。
5.89C51的组成:一个8位的80C51的微处理器,片内256字节数据存储器RAM/SFR用来存放可以读/写的数据,片内4KB程序存储器FLASHROM用存放程序、数据、表格,4个8位并行I/O端口P0-P3,两个16位的定时器/计数器,5个中断源、两个中断个优先级的中断控制系统, 一个全双工UART的串行口I/O口,片内振荡器和
时钟产生电路,休闲方式和掉电方式。
6.89C51片内程序存储器容量为4KB,地址从0000-0FFFH开始,存放程序和表格常数,片外最多可扩展64KBROM地址1000-FFFFH,片内外统一编址。单片机的内部存储空间分为数据存储器和程序存储器。
7.内部数据存储器:共256字节单元,包括低128个单元和高128个单元。低128字节又分成3个区域:工作寄存器区(00H~1FH),位寻址区(20H~2FH)和用户RAM区(30H~7FH)存放中间结果,数据暂存及数据缓冲。高128字节是供给特殊功能寄存器(SFR)使用的,因此称之为特殊功能寄存器区(80H~FFH),访问它只能用直接寻址。
内部程序存储器:在8031片内无程序存储器,8051片内具有4KB掩模ROM,8751片内具有4KBEPROM。
8. 引脚是片内外程序存储器的选择信号。当 端保持高电平时,访问内部程序存储器,但在PC(程序计数器)值超过0FFFH(对于C51)或1FFFH(对于8052)时,将自动转向访问外部程序存储器。当 端保持低电平时,不管是否有内部程序存储器,则只访问外部程序存储器。由于8031片内没有程序存储器,所以在使用8031时, 引脚必须接低电平。
9.RST复位信号输入端,高电平有效。保持两个机器周期(24个时钟振荡周期)的高电平有效,完成复位,复位后,CPU和系统都处于一个确定的初始状态,在这种状态下,所有的专用寄存器都被赋予默认值,除SP=07H,P0~P3口为FFH外,其余寄存器均为0。
ALE/ :ALE输出正脉冲,频率为振荡周期的1/6,CPU访问片外存储器时,ALE输出信号作为锁存低8位地址的控制信号,看芯片好坏可以用示波器看ALE端是否有脉冲信号输出。PSEN程序存储允许输出信号端,也可以检查芯片好坏,有效即能读出片外ROM的指令,引脚信号RD/WR有效时可读/写片外RAM或片外I/O接口。
10.P0作为输出口时,必须外接上拉电阻才能有高电平输出,作为输入口时,必须先向锁存器写“1”;作为普通I/O口使用或低8位地址/数据总线使用。
P1口有上拉电阻,对FLASHROM编程和校验是P1接收低八位地址;只用作普通I/O口使用。
P2口比P1口多了一个转换控制开关;作为普通I/O口使用或高8位地址线使用时访问外部程序存储器和16位地址的外部数据存储器。
P3口比P1口增加了与非门和缓冲器;具有准双向I/O功能和第二功能。P0,P1,P2,P3准双向口。上述4个端口在作为输入口使用时,应注意必须先向端口写“1。”
11.普林斯顿结构:一个地址对应唯一的存储单元,用同类访问指令。哈佛结构:程序存储器和数据存储器分开的结构。CPU访问片内外ROM用MOVC,访问片外RAM用MOVX,访问片内RAM用MOV.
SP总是初始化到内部RAM地址07H,堆栈的操作;PUSH、POP。DPTR是数据指针寄存器,是一个16位寄存器,用来存放16位存储器的地址,以便对64KB片外RAM作间接寻址。DPTR由高位字节DPH和低位字节DPL组成。
13.指令周期:执行一条指令所需要的时间。
机器周期:CPU完成一个基本操作所需要的时间,6个状态周期和12个振荡周期。当晶振频率为12MHz时,一个机器周期为1μs;当晶振频率为6MHz时,一个机器周期为2μs,复位时间超过4μs。
14.复位操作有:电自动,按键手动,看门狗。
15.空闲方式是CPU停止工作而RAM,定时器/计数器,串行口及中断系统都工作。掉电一切功能都暂停,保存RAM中内容。退出空闲方式;硬件将PCON.0清0,硬件复位。当CPU执行PCON.1为1,系统进入掉电方式。推出掉电只有硬件复位。
17.单片机的寻址方式:寄存器寻址,直接寻址,立即数寻址,寄存器间接寻址,变址寻址,相对寻址,位寻址。
18.AJMP和SJMP的区别有:
(1) 跳转范围不同。 AJMP addr1 ;短跳转范围:2KB 。SJMP rel ;相对跳转范围:-128~+127 (2) 指令长度不同。(3) 指令构成不同。AJMP、LJMP后跟的是绝对地址,而SJMP后跟的是相对地址。 不能用AJMP指令代替程序中的SJMP指令,因为如果改变的话,程序跳转到的新PC值指向的地址会不同,导致程序出现错误。
19.在89c51片内RAM中30H)=38H,38H=40H,40H=48H,48H=90H。情分析下面各是什么指令,说明源操作数的寻址方式以及按顺序执行每条指令后的结果?
;直接寻址
(40H)→A
;寄存器寻址
;立即数寻址
;直接寻址 (30H) →(R0)
DPTR,#3848H
;立即数寻址
3848H→DPTR
;直接寻址 (38H) →40H
;直接寻址 (30H) →R0
;寄存器寻址
( R0 )→P0
;立即数寻址
;寄存器间接寻址 ((R0)) →A
;直接寻址 (P1)→P2
最后结果:(R0)=38H,(A)=40H,(P0)=38H,(P1)=(P2)=0F0H,(DPTR)=3848H,(18H)=30H,(30H)=38H,(38H)=40H,(40H)=40H,(48H)=38H注意:→左边是内容,右边是单元
20.已知R3和R4中存放有一个16位的二进制数,高位在R3中,地位在R4中,请编程将其求补,并存回原处。
;取该数高8位→A
;取出该数符号判断
;是正数,转L1
;是负数,将该数低8位→A
;低8位取反
;低8位取反加1后→R4
;将该数高8位→A
;高8位取反
;加上低8位加1时可能产生的进位
;高8位取反加1后→R3
21.已知30H和31H中村有一个16位的二进制数,高位在前,低位在后,请编程将他们乘以2,在存回原单元中。
;清进位位C
;取该数低8位→A
;带进位位左移1位
;结果存回31H
;取该数高8位→A
;带进位位左移1位
;结果存回30H
22.假设允许片内定时器/计数器中断,禁止其他中断。设置IE值。用字节操作指令: MOV IE #8AH 或MOV A8H,#A8H 用位操作指令:SETB ET0
23.设89 C51的片外中断为高优先级,片内为低优先级,设置IP值。 用字节操作指令:MOV
IP,#05H或MOV
0B8H,#05H 用位操作指令:SETB
24.89C51单片机内有两个16位定时器/计数器,即T0,T1.
海南鹏欣白金湾景观施工图深化设计合同 工 程 名 称: 工 程 地 点: 合 同 编 号:设计证书编号:A(甲级)发 包 人:琼海鹏博置业有限公司 设 计 人:棕榈园林股份有限公司 签 订 日 期: 发包人(甲方):琼海鹏博置业有限公司 设计人(乙方): 棕榈园林股份有限公司根据
近代西方资本主 义政体的建立 课标要求: 课标要求:了解《权利法案》 了解《权利法案》的制定和责任制内阁形成的史 实,理解英国资产阶级君主立宪制的特点。 理解英国资产阶级君主立宪制的特点。 知道《德意志帝国宪法》的主要内容, 知道《德意志帝国宪法》的主要内容,比较德意 志帝国君主立宪制与法国共和制的
来源:重庆智豪律师事务所 编辑:张智勇律师(重庆律师协会刑事委员会副主任) 刑事知名律师张智勇释义放火罪量刑标准放火罪量刑标准放火罪是指故意用放火焚烧公私财物的方法,足以危害公共安全的行为。十年以上徒刑的起刑点,为有人重伤、死亡和公私财产重大损失。放火罪量刑标准中国现行《刑法》规定,放火罪是危害公
历年中考题汇总--- 时态专练(含答案) 1. (2010 .河北省卷,38. 1) This termtwo weeks.A. is B. was over. The summer vacation is coming in C. has been D. will bea mistake. Pl
第 3 章 1.MCS-51指令系统按功能分为几类?具有几种寻址方式?他们的寻址范围如何? 答:① 按功能分为5类,分别是: 数据传送类、算术操作类、逻辑操作类、控制转移类和位操作类;② 具有7种寻址方式;③ 立即寻址,寻址范围是程序存储器;?直接寻址,寻址范围是内部RAM低128字节和高128字节
第一章1.单片机具有哪些特点(1)片内存储容量越来越大。(2抗干扰性好,可靠性高。(3)芯片引线齐全,容易扩展。(4)运行速度高,控制功能强。(5)单片机内部的数据信息保存时间很长,有的芯片可以达到100年以上。2. 89C51单片机内包含哪些主要逻辑功能部件?答:80C51系列单片机在片内集成了以
单片机原理及接口技术 人民邮电出版社课后习题答案第1章 单片机概述 1.除了单片机这一名称之外,单片机还可称为和。 答:微控制器,嵌入式控制器。2.单片机与普通微型计算机的不同之处在于其将、 部分集成于一块芯片上。 答:CPU、存储器、I/O口。3.的区别是 A.内部数据存储单元数
单片机原理及接口技术课后习题答案 李朝青 课后习题答案
15:11 阅读673 评论0字号: 大 中 小 5、 SFR:直接寻址,位寻址,寄存器寻址;片外RAM:寄存器间接寻址 6、 MOV A,40H ;直接寻址 (40H)→AMOV R0,A ;寄存器寻址 (A)→R0MO
第二章 1.89C51、87C51、80C51 和 80C31 单片机的主要区别在那里? 答:相同之处是:制造工艺都为 CHMOS,都有 128 字节片内 RAM、两个定 时/计数器、4 个 8 位 I/O 并行口,一个串行口和 5 个中断源。主要区别: ① 89C51 片内 4K 字节 FLASH
第1章 单片机概述 1.除了单片机这一名称之外,单片机还可称为和。答:微控制器,嵌入式控制器。2.单片机与普通微型计算机的不同之处在于其将、 部分集成于一块芯片上。答:CPU、存储器、I/O口。3.的区别是A.内部数据存储单元数目不同 B.内部数据存储器的类型不同C.内部程序存储
单片机原理与接口技术课后答案 第一章 略 第二章 略(前两章过于简单) 第三章 1. 指令:CPU根据人的意图来执行某种操作的命令指令系统:一台计算机所能执行的全部指令集合 机器语言:用二进制编码表示,计算机能直接识别和执行的语言汇编语言:用助记符、符号和数字来表示指令的程序语言高级语言:独立于机
本文由()首发,转载请保留网址和出处!
免费下载文档:}

我要回帖

更多关于 java取反运算 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信