单片机原理与接口技术修订本部分习题与参考答案_第1页
单片机原理与接口技术修订本部分习题与参考答案_第2页
单片机原理与接口技术修订本部分习题与参考答案_第3页
单片机原理与接口技术修订本部分习题与参考答案_第4页
单片机原理与接口技术修订本部分习题与参考答案_第5页
免费预览已结束,剩余17页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、单片机原理及接口技术(修订本)部分习题与参考答案第1章绪论1-2什么叫单片机?一个完整的单片机芯片至少有哪些部件?答:将微处理器(CPU)、存储器、定时/计数器及输入输出接口电路等部件集成在一块集成电路上,称为单片微型计算机,简称单片机。一个完整的单片机芯片至少有中央处理器(CPU)、随机存储器(RAM)、只读存储器(ROM)、定时/计数器及I/O接口等部件。1-5Intel公司的主要单片机产品分为哪几大系列?各系列的区别何在?答:Intel公司的MCS-48系列、MCS-51系列、MCS-96系列产品;48系列的单片机在片集成4位CPU,片含有多种I/O接口,有的根据不同用途还配有许多专用接

2、口,价格便宜,控制功能强。51系列的单片机在片集成8位CPU、片RAM为128字节,ROM为4K字节,4个并行I/O口、2个16位定时/计数器、串行接口、5个中断源。96系列单片机CPU为16位,片RAM为232字节,ROM为8K字节,片带有高速输入输出部件,多通道10位A/D转换部件,中断处理为8级。1-6叙述51子系列与52子系列的区别?答:51子系列包含8031/8051/8751三种型号,它们的基本组成、基本性能都相同,者B具有一个8位CPU、片数据存储器RAM128B、2个16位定时/计数器、有5个中断源,一个全双工串行接口,它们之间的区另在于片程序存储器配置:8031片没有ROM,

3、使用时需在片外接EPROM。8051片含有4KB的掩模ROM,其中的程序是生产厂家制作芯片时烧制的。8751片含有4KB的EPROM,用户可以先用紫外线擦除器擦除,然后再利用开发机或编程器写入新的程序。52子系列包含8032/8052/8752三种型号,52子系列与51子系列的区别在于:片ROM和RAM的容量比8051子系列各增加一倍,另外,增加了一个定时/计数器和一个中断源。第2章MCS-51系列单片机的结构及原理2-2MCS-51单片机的引脚有何功能?在使用8031时如何接法?使用8751时如何接法?答:引脚是片外程序存储器的选择信号。当端保持高电平时,访问部程序存储器,但在PC(程序计数

4、器)值超过0FFFH(对于8051/8751/80C51)或1FFFH(对于8052)时,将自动转向访问外部程序存储器。当端保持低电平时,不管是否有部程序存储器,则只访问外部程序存储器。由于8031片没有程序存储器,所以在使用8031时,引脚必须接低电平。2-4MCS-51单片机的部存储空间是怎样分配的?答:MCS-51单片机的部存储空间分为数据存储器和程序存储器。部数据存储器:共256字节单元,包括低128个单元和高128个单元。低128字节又分成3个区域:工作寄存器区(00H1FH),位寻址区(20H2FH)和用户RAM区(30H7FH)。高128字节是供给特殊功能寄存器使用的,因此称之为

5、特殊功能寄存器区。部程序存储器:在8031片无程序存储器,8051片具有4KB掩卞HROM,8751片具有4KBEPROM。2-5如何从MCS-51单片机的4个工作寄存器组中选择当前工作寄存器组?答:MCS-51单片机提供了4组工作寄存器,对于当前工作寄存器组的选择,是通过PSW中的RS1和RS0来进行选择。具体关系如下表:RS1RS0当前寄存器组00第0组工作寄存器01第1组工作寄存器10第2组工作寄存器11第3组工作寄存器2-6部RAM低128个单元是如何划分的?答:部RAM低128个单元按用途分成3个区域:工作寄存器区(00H1FH),位寻址区(20H2FH)和用户RAM区(30H7FH

6、)。2-7DPTR是什么寄存器?它的作用是什么?它由哪几个寄存器组成?答:DPTR是数据指针寄存器,是一个16位寄存器,用来存放16位存储器的地址,以便对外部数据存储器RAM中的数据进行操作。DPTR由高位字节DPH和低位字节DPL组成。2-8什么是堆栈?堆栈有何作用?为什么在程序初始化时要对SP重新赋值?答:所谓堆栈,顾名思义就是一种以“堆”的方式工作的“栈”。堆栈是在存中专门开辟出来的按照“先进后出,后进先出”的原则进行存取的RAM区域。堆栈的用途是保护现场和断点地址。在8051单片机复位后,堆栈指针SP总是初始化到部RAM地址07H。从08H开始就是8051的堆栈区,这个位置与工作寄存器

7、组1的位置相同。因此,在实际应用中,通常要根据需要在程序初始化时对SP重新赋值,以改变堆栈的位置。2-9试述程序状态字寄存器PSW各位的含义。答:程序状态字寄存器PSW是8位寄存器,用于存放程序运行的状态信息。CY(PSW.7):进位标志位。AC(PSW.6):辅助进位标志位。F0(PSW.5)、F1(PSW.1):用户标志位。RS1(PSW.4)、RS0(PSW.3):工作寄存器组选择位。OV(PSW.2):溢出标志位。P(PSW.0):奇偶标志位。2-10P0、P1、P2、P3口的结构有何不同?使用时要注意什么?各口都有什么用途?答:P0口由一个所存器、两个三态输入缓冲器、场效应管、控制与

8、门、反相器和转换开关组成;作为输出口时,必须外接上拉电阻才能有高电平输出,作为输入口时,必须先向锁存器写“1”;作为普通I/O使用或低8位地址/数据总线使用。P1没有转换开关,但有上拉电阻;只用作普通I/O使用。P2口比P1口多了一个转换控制开关;作为普通I/O使用或高8位地址线使用。P3比P1口增加了与非门和缓冲器;具有准双向I/O功能和第二功能。上述4个端口在作为输入口使用时,应注意必须先向端口写“1”。2-11请说出指令周期、机器周期、状态和拍的概念。当晶振频率为12MHz、8MHz时,一个机器周期为多少微秒?答:指令周期:执行一条指令所需要的时间。机器周期:CPU完成一个基本操作所需要

9、的时间。状态:振荡脉冲经过二分频后,得到的单片机的时钟信号。拍:振荡脉冲的周期。当晶振频率为12MHz时,一个机器周期为1W§当晶振频率为8MHz时,一个机器周期为3d82-12什么是单片机复位?复位后单片机的状态如何?答:在时钟电路工作后,只要在单片机的RESET引脚上出现24个时钟震荡脉冲(两个机器周期)以上的高电平,单片机就能实现复位。复位后,CPU和系统都处于一个确定的初始状态,在这种状态下,所有的专用寄存器都被赋予默认值,除SP=07H,P0P3口为FFH外,其余寄存器均为0。第3章MCS-51系列单片机的指令系统3-3MCS-51系列单片机有哪几种寻址方式?各种寻址方式所

10、对应的寄存器或存储器寻址空间如何?答:MCS-51系列单片机提供了7种寻址方式:(1)立即寻址:操作数在指令中直接给出,立即数前面有“#"。(2)直接寻址:在指令中直接给出操作数地址。对应片低128个字节单元和特殊功能寄存器。(3)寄存器寻址:以寄存器的容作为操作数。对应的寄存器有:R0R7、A、AB寄存器和数据指针DPTR。(4)寄存器间接寻址:以寄存器的容作为RAM地址,该地址中的容才是操作数。对应片RAM的低128个单元采用R0、R1作为间址寄存器,片外RAM低256个单元可用R0、R1作为间址寄存器,整个64KB空间可用DPTR作为间址寄存器。(5)变址寻址:以DPTR或PC

11、作为基址寄存器,以累加器A作为变址寄存器,并以两者容相加形成的16位地址作为操作数地址。对应片、片外的ROM空间。(6)相对寻址:只在相对转移指令中使用。对应片、片外的ROM空间。(7)位寻址:对可寻址的位单独进行操作。对应位寻址区20H2FH单元的128位和字节地址能被8整除的特殊功能寄存器的相应位。3-4若访问特殊功能寄存器,可使用那些寻址方式?答:直接寻址方式。3-5若访问外部RAM单元,可使用那些寻址方式?答:寄存器间接寻址方式。3-6若访问部RAM单元,可使用那些寻址方式?答:立即寻址方式,直接寻址方式,寄存器寻址方式,寄存器间接寻址方式,位寻址方式。3-7若访问外程序存储器,可使用

12、那些寻址方式?答:变址寻址方式3-9外部数据传送指令有几条?试比较下面每一组中两条指令的区别。(1) MOVXA,R1,MOVXA,DPTR(2) MOVXA,DPTR,MOVXDPTR,A(3) MOVR0,A,MOVXR0,A答:外部数据传送指令有6条:MOVXA,DPTRMOVXDPTR,AMOVXA,RiMOVXRi,AMOVCA,A+DPTR(1)MOVXA,R1MOVCAMOVXA,A+PC,DPTR(4)MOVCA,A+DPTRMOVXA,DPTR都是访问片外RAM,但二者寻址围不同。前1条指令是对片外RAM低256个单元的“读”操作。后1条指令是对片外RAM64KB空间的“读”

13、操作。(2) MOVXA,DPTRMOVXDPTR,A访问空间相同,但数据传送方向不同。前1条指令是对片外RAM64KB空间的“读”操作。后1条指令是对片外RAM64KB空间的“写”操作。(3) MOVR0,AMOVXR0,A二者访问的空间不同。前1条指令是对片RAM低128个单元的“写”操作。后1条指令是对片外RAM低256个单元的“写”操作。(4) MOVCA,A+DPTRMOVXA,DPTR二者访问的空间不同,寻址方式不同。前1条指令是变址寻址方式,对ROM操作。后1条指令是寄存器间接寻址方式,对片外RAM操作。3-10已知(30H)=40H,(40H)=10H,(10H)=32H,(P

14、1)=EFH,试写出执行以下程序段后有关单元的容。MOVR0,#30HMOVA,R0MOVR1,AMOVB,R1MOVR1,P1MOVP2,P1MOV10H,#20HMOV30H,10H答:R0-30H,(R0)=30HA(R0),(A)=40HR1(A),(R1)=40HB(R1),(B)=10H(R1)(P1),(R1)=(40H)=EFHP2(P1),(P2)=EFH10H20H,(10H)=20H30H(10H),(30H)=20H结果:(R0)=30H,(A)=40H,(R1)=40H,(B)=10H,(40H)=EFH,(P2)=EFH,(10H)=20H,(30H)=20H3-1

15、1试写出完成以下数据传送的的指令序列。(1)R1的容传送R0;(2)片外RAM60H单元的容送入R0;(3)片外RAM60H单元的容送入片RAM40H单元;(4)片外RAM1000H单元的容送入片外RAM40H单元;(5) ROM2000H单元的容送入R2;(6) ROM2000H单元的容送入片RAM40H单元;(7) ROM2000H单元的容送入片外RAM0200H单元。答:(1)由于在工作寄存器与工作寄存器之间不能直接传送数据,所以需要借助累加器AoMOVA,R1MOVR0,A(2)片外RAM向片RAM传送数据,不能直接进行,需要借助累加器A。由于片外RAM是60H单元,地址小于FFH,所

16、以间址寄存器使用Ri即可。MOVR1,#60HMOVXA,R1MOVR0,A(3) MOVR1,#60HMOVXA,R1MOV40H,A(1) 片外数据不能直接送入片外单元,需要先将片外数据读入累加器,然后再送到片外。MOVDPTR,#1000HMOVXA,DPTRMOVR1,#40HMOVXR1,A(5) ROM中的数据需要使用查表指令才能读出来,所以此题不能使用一般的传送指令从ROM中读数据。MOVDPTR,#2000HMOVA,#00HMOVCA,A+DPTRMOVR2,A(6) MOVDPTR,#2000H#00HMOVAMOVCA,A+DPTR,A,#2000H#00HA+DPTR,

17、#0200H,AMOV40HMOVDPTRMOVAMOVCAMOVDPTRMOVXDPTRRAM60H单元中的数据相互交换。3-12试编程,将外部RAM1000H单元中的数据与部答:片外RAM与片RAM之间的数据传送不能直接进行,需要借助累加器Ao数据交换需要使用数据交换指令XCH。MOVDPTR,#1000HMOVXA,DPTRXCHA,60HMOVXDPTR,A3-14已知(A)=5BH,(R1)=40H,(40H)=C3H,(PSW)=81H,试写出各条指令的执行结果,并说明程序状态字的状态。(1)XCHA,R1(3)XCHA,R1SWAPAADDA,40H(9)ADDCA,40H(11

18、)SUBBA,#40H答:(2)XCHA,40H(4)XCHDA,R1(6)ADDA,R1(8)ADDA,#40H(10)SUBBA,40H(1)结果:(A)一(R1),(A)=40H,(R1)=5BH,(PSW)=81H(2)结果:(A)-(40H),(A)=C3H,(40H)=5BH,(PSW)=80H(3)结果:(A)一T(R1),(A)=C3H,(R1)=(40H)=5BH,(PSW)=80H(4)结果:(A)o3<->(R1)o3,(A)=53H,(R1)=(40H)=CBH,(PSW)=80H(5)结果:(A)03<->(A)47,(A)=B5H,(PSW)

19、=81H(6)结果:A-(A)+(R1),(A)=9BH,(PSW)=05H(7)结果:A-(A)+(40H),(A)=1EH,(PSW)=80H(8)结果:A-(A)+40H,(A)=9BH,(PSW)=05H(9)结果:A-(A)+(40H)+CY,(A)=1FH,(PSW)=81H(10)结果:A-(A)-(40H)-CY,(A)=97H,(PSW)=85H(11)结果:A-(A)-40H-CY,(A)=1AH,(PSW)=01H3-26已知(A)=5BH,(R1)=40H,(40H)=C3H,(PSW)=81H,试写出各条指令的执行结果,并说明程序状态字的状态。1)XCHA,R1(2)

20、XCHA,40H3)XCHA,R1(4)XCHDA,R15)SWAPA(6)ADDA,R17)ADDA,40H(8)ADDA,#40H9)ADDCA,40H(10)SUBBA,40H11)SUBBA,#40H答:指令LJMPaddr16是长转移指令,指令中提供了16位目的地址,寻址围是64KB。指令AJMPadd1是绝对转移指令,指令中11位目的地址,其中a7a0在第二字节,a10a8则占据第一字节的高3位,寻址围是与PC当前值(本指令所在地址+本条指令所占用的字节数2)在同一个2K的区域。3-27试分析以下两段程序中各条指令的作用。程序执行完将转向何处?(1)MOVP1,#0CAHMOVA,

21、#56HJBP1.2,L1JNBACC.3,L2L1:L2:(2)MOVA,#43HJBACC.2,L1JBCACC.6,L2L1:L2:答:(1)MOVP1,#0CAH;P1-CAH,P1=CAH=11001010BMOVA,#56H;A56H,A=56H=01010110BJBP1.2,L1;若P1.2=1,则转移至L1JNBACC.3,L2;若ACC.3=0,则转移至L2L1:L2:执行完本段程序后将转移至L2,因为P1.2=0,ACC.3=0,所以转至L2。(2)MOVA,#43H;A43H,A=43H=01000011BJBACC.2,L1;若ACC.2=1,则转移至L1JBCACC

22、.6,L2;若ACC.6=1,则转移至L2,同时将ACC.6清零L1:L2:执行完本段程序后将转移至L2,因为ACC.2=0,ACC.6=1,所以转至L2,并且将ACC.6清零。第4章汇编语言程序设计4-3存放在部RAM的DATA单元中白变量X是一个无符号整数,试编程计算下面函数的函数值并存放到部RAM的FUNC单元中。答:口感心或殴ORG0300HMOVACJNEALOP1:JCLOP3CJNEALOP2:JCLOP4MOVBLJMPLOP5LOP3:MOVBLJMPLOP5LOP4:MOVBLOP5:MULABMOVFUNCRET,DATA,#20,LOP1,#50,LOP2,#1,#2,

23、#5,A4-5某单片机应用系统有4X4键盘,经键盘扫描程序得到被按键的键值(00H0FH)存放在R2中,16个键的键处理程序入口地址分别为KEY0、KEY1、KEY2、KEY15。试编程实现,根据被按键的键值,转对应的键处理程序。答:ORG0500HMOVDPTR,#JPTABMOVA,R2RLAJMPA+DPTRJPTAB:AJMPKEY0AJMPKEY1AJMPKEY2AJMPKEY15KEY0:KEY1:KEY2:KEY15:4-6试编程将片40H60H单元中容传送到外部RAM以2000H为首地址的存储区中。答:ORG0600HMOVR0,#40HMOVDPTR,#2000HMOVR7,

24、#21HLOOP:MOVA,R0MOVXDPTR,AINCR0INCDPTRDJNZR7LOOPRET4-7试编程将片40H60H单元中容传送到外部RAM以2000H为首地址的存储区中。答:ORG0700HMOVDPTR,#DATAMOVR7,#10LOOP:MOVXA,DPTRORLA,#80HMOVXDPTRAINCDPTRDJNZR7LOOPRET4-8编写程序将外部开始的区域。RAM3000H开始的13个单元中的数据隔一个传送到部RAM30H答:ORG0800HMOVDPTRMOVR0MOVR7LOOP:MOVXAMOVR0INCDPTRINCDPTR,#3000H,#30H,#7DP

25、TR,AINCR0DJNZR7,LOOPRET4-9编程将片外RAM地址为1000H1030H的数据块,全部搬迁到片RAM30H60H中,并将原数据区全部清0。答:ORG0900HMOVDPTR,#1000HMOVR1,#30HMOVR7,#31HLOOP:MOVXA,DPTRMOVR1CLRA,AMOVXDPTRINCDPTRINCR1,ADJNZR7,LOOPRET4-10试编程把长度为10H的字符串从部RAM首地址为DAT1的存储器中向外部RAMCR或整个字符串传送完毕结束。首地址为DAT2的存储器进行传送,一直进行到遇见字符答:ORG0A00HMOVR1MOVDPTRMOVR6LOOP

26、1:MOVACJNEALJMPLOOP3,#DAT1,#DAT2,#10HR1,#0DH,LOOP2LOOP2:MOVXDPTR,AINCR1INCDPTRDJNZR6,LOOP1LOOP3:RET4-18设在外部RAM2000H2004H单元中,存放有5个压缩BCD码,试编程将它们转换成ASCH码,存放到以2005H单元为首地址的存储区中。答:ORG1200HMOVDPTR,#2000HMOVR0,#30HMOVR7,#5LOP1:MOVXA,DPTRANLA,#0FHADDA,#30HMOVR0,AINCR0MOVXA,DPTRANLA,#0F0HSWAPAADDA,#30HMOVR0,A

27、INCR0INCDPTRDJNZR7,LOP1MOVDPTR,#2005HMOVR0,#30HMOVR7,#10LOP2:MOVA,R0MOVXDPTRINCR0INCDPTR,ADJNZR7,LOP2RET4-20已知部RAM30H和40H单元分别存放着一个数a、b,试编写程序计算a2-b2,并将结果送入30H单元。设a、b均是小于10的数。ORG1400HMOVA,40HMOVB,AMULABMOV31H,AMOVA,30HMOVB,AMULABCLRCSUBBA,31HMOV30H,ARET4-21根据题322的线路图(图3-10),设计灯亮移位程序,要求8个发光二极管每次亮一个,点亮时

28、间为40ms。顺次一个一个地循环右移点亮,循环不止。答:ORG1500HMOVA,#80HLOOP:MOVP1,ALCALLDELRRASJMPLOOPDEL:MOVR7,#100DEL1:MOVR6,#198DJNZR6$DJNZR7DEL1RETRET第5章定时/计数器5-151系列单片机的部设有几个定时/计数器?有哪几种工作方式?由哪位选择?不同方式下,脉冲来源是否一样?答:51系列单片机的部设有两个定时/计数器。分别有两种工作方式:定时器方式和计数器方式。由TMOD(定时器模式控制寄存器)中的控制位进行选择。定时器方式的脉冲来自于部时钟脉冲,每个机器周期是计数器的值增1;计数器方式的脉

29、冲来自于外部输入引脚T0(P3.4)或T1(P3.5)。5-251系列单片机的定时/计数器有哪几种工作模式?各有什么特点?答:51系列单片机的定时/计数器有四种工作模式。分别由TMOD中的M1和M0进行选择。特点如下:M1M0特点00模式0。TLX中低5位与THX中的8位构成13位计数器。计满溢出时,13位计数器回零。01模式1。TLX与THX构成16位计数器。计满溢出时,16位计数器回零。10模式2。8位自动重装载的定时/计数器,每当计数器TLX溢出口THX中的容重新装载到TLX中11模式3。对定时器0,分成2个8位计数器,对于定时器1,停止计数。5-351系列单片机的T0和T1在模式0中,

30、都使用了计数器的哪些位?答:51系列单片机的T0和T1在模式0中,使用了TLX中低5位与THX中的8位构成13位计数器,TLX中的高3位弃之未用。5-451系列单片机的T0和T1在模式3时有何不同?答:对于T1,设置为模式3,将使它停止计数并保持原有的计数值,其作用如同使TR1=0,因此,没有什么实质意义。对于T0,设置为模式3时,16位计数器被分成两个互相独立的8位计数器TL0和TH0,其中TL0利用了定时/计数器0本身的一些控制位:、GATE、TR0、和TF0。它既可以按照计数方式工作,也可以按照定时方式工作。而TH0被规定只可用作定时器方式,借用了T1的控制位TR1和TF1。5-5试问当

31、(TMOD)=27H时,是怎样定义T0和T1的?答:(TMOD)=27H=00100111B此时,T1工作于模式2,定时方式(即波特率发生器方式)。T1工作于模式3,TL0和TH0同为计数方式。5-6系统复位后执行下述指令,试问T0的定时时间为多长?MOVTH0,#06HMOVTL0,#00HSETBTR0答:单片机系统复位后(TMOD)=00H,即T0工作在模式0,使用的是TL0的低5位和TH0构成13位定时/计数器,由于(TH0)=06H,(TL0)=00H,所以定时的初值为:X=00B=192假设系统晶振频率为6MHz,机器周期T=2s,则定时时间为:定时值=(M-X)T=(213-19

32、2)X2Ws=16000科s=16ms5-7已知51系列单片机的系统晶振频率为6MHz,请利用定时器T1和P1.2输出矩形脉冲。答:ORG0000HLJMPSTARTORG0200HSTART:MOVTMOD,#20HMOVTL1,#231SETBTR1LOOP:SETBP1.2MOVTH1,#81LOP1:JBCTF1,LOP2SJMPLOP1LOP2:CLRP1.2MOVTH1,#231LOP3:JBCTF1,LOOPSJMPLOP3END第6章串行接口6.1并行通信和串行通信各有什么特点?它们分别适用于什么场合?答:计算机与外界信息交换的基本方式可分为并行通信与串行通信:并行通信是数据的

33、各位同时传送,并行通信的特点是传送速度快,但不适用长距离传输;串行通信是数据的各位依次逐位传送,串行通信的特点是传送速度较慢,但传输距离较长。并行通信适合近距离的CPU之间或设备之间快速进行数据交换;串行通信适合长距离的CPU之间或设备之间进行数据交换,或近距离的慢速数据交换。6.2什么是串行异步通信?它有哪些特点?串行异步通信的数据帧格式是怎样的?答:异步通信依靠起始位、停止位、保持通信同步。特点是数据在线路上的传送不连续,传送时,字符间隔不固定,各个字符可以是连续传送,也可以间断传送,这完全取决于通信协议或约定。串行异步通信的数据帧格式如图6-1:一位起始位“0”电平;其后是5位、6位、7

34、位或8位数据位,低位在前,高位在后;后面是1位奇偶校验位;最后是停止位“1”电平。起始位D0D1D2D3D4D5D6D7奇偶校验位停止位图6-1异步通信的数据帧格式6.3串行通行有哪几种数据传送形式,试举例说明。答:串行通信有3种数据传送形式单工方式:数据传送是单向的。半双工方式:数据传送是双向的,在同一时间只能做一个方向的传送。全双工方式:数据传送是双向的,即可同时发送,又可同时接收。图6-2串行通信数据传送3种形式6.4何谓波特率?某异步通信,串行每秒传送250个字符,每个字符由11位组成,其波特率应为多少?答:波特率表示每秒传输的二进制数据位数。Fb=11X250=2750其波特率应为2

35、750bps。6. 5MCS-51单片机串行口有几种工作模式?如何选择?简述其特点,并说明这几种工作模式各用于什么场合?答:MCS-51单片机串行有4种工作模式,由串行控制寄存器SCON中的SM0、SM1两位组合来确定。模式0是同步位移寄存器方式,用于模式1是8位异步通信方式,桢格式模式2是9位异步通信方式,桢格式模式3是9位异步通信方式,桢格式I/O口的串、并转换。10位,波特率可变,用于双机通信。11位,波特率固定,用于多机通信。11位,波特率可变,用于多机远距离通信。模式1、2、3的区别主要表现在桢格式和波特率两个方面。6. 6MCS-51单片机4种工作模式的波特率如何确定?答:模式0的

36、波特率固定:fosc/12模式2的波特率固定:fosc/n(n=64或32)模式1、3的波特率可变:T1溢出率/n(n=32或16)6. 10设计一个MCS-51单片机的双机通信系统,并编写程序将甲机片外RAM2200H-2250H的数据块通过串行口传送到乙机的片外RAM1400H1450H单元中。要求串行口工作在模式2,系统晶振为6MHz,传送时进行奇校验;若出错,置F0标志为1。答:串行口工作在模式2,确定SMOD=1o未规定波特率,定时器初值任取,但两机要保捋致。甲机发送子程序:TXDAMOVTMOD#20H;置T1定时器工作方式2MOVTL1,#0FDH;置初值MOVTH1,#0FDH

37、;置初值SETBTR1;启动T1MOVSCON#90H;直串口方式2,允许接收,且SM2=0MOVPCON#80H;置SMOD=1(SMOK能位操作)CLRES;禁止串行中断MOVDPTR#2200H;指发送数据区首地址MOVR2,#51H;指发送数据长度TRSAMOVXA,DPTR;读一个数据MOVC,PMOVTB8,C;置校验位MOVSBUF,A;发送JNBTI,$;等待一桢数据发送完毕CLRTI;清发送中断标志INCDPTR;指向下一字节单兀DJNZR2,TRSA;判数据发完否?未完继续RET;乙机接收子程序:RXDBMOVTMOD#20H;置T1定时器工作方式2MOVTL1,#0FDH

38、;置初值MOVTH1,#0FDH;置初值SETBTR1;启动T1MOVSCON#90H;置串行方式2,允许接收,且SM2=0MOVPCON#80H;置SMOD=1(SMOK能位操作)CLRES;禁止串行中断MOVDPTR#1400H;置接收数据区首地址MOVR2,#51H;置接收数据长度SETBREN;启动接收SETBF0;先置出错标志F0为1。RDSBJNBRI,$;等待一桢数据接收完毕CLRRI;清接收中断标志MOVA,SBUF;读接收数据MOVXDPTRA;存接收数据MOVC,RB8ANLC,PJCRDSB2都是1,则正确MOVC,RB8ORLC,PJNCRDSB2都是0,则正确LJMP

39、RXDBD;出错RDSB2INC下一数据存储单元DPTR;指向DJNZR2,RDSB;判数据接收完否?未完继续CLRF0;正确接收,则清除出错标志F0RXDBDRET第7章中断系统7. 1MCS-51系统有几个中断源,各中断标志是如何产生的,又如何清零的?CPU响应中断时,中断入口地址各是多少?答:MCS-51系统有、T0、T1和串行口共五个中断源;和的中断标志是IE0和IE1,在电平方式下,当外部中断输入信号是低电平时,由硬件置1;在边沿方式下,当外部中断输入信号是下降沿时,由硬件置1;定时计数器溢出中断T0和T1的中断标志位是TF0和TF1,当定时/计数器产生溢出时,该位由硬件置1;串行口

40、中断标志是TI或RI,当单片机接收到或发送完一帧数据后,由硬件置1。外部中断和的电平方式,无法清除,需采取硬件和软件相结合的方法来清除;边沿方式,在CPU响应中断后自动清除;定时/计数器0和1的溢出中断,在CPUP向应中断后自动清除;串行口中断(包括串行接收中断RI和串行发送中断TI),由软件清零。、T0、T1和串行口中断5个中断源分别对应的中断入口地址是:0003H、000BH、0013H、001BH、0023H。7. 2MCS-51的中断系统有几个中断优先级?中断优先级是如何控制的?答:MCS-51的中断系统有两个中断优先级:高优先级和低优先级。中断优先级的控制方式是:高优先级中断可以中断

41、正在响应的低优先级中断,反之则不能。优先级中断不能互相中断。即某个中断(不论是高优先级或低优先级)一旦得到响应,与其同级的中断就不能再中断它。同一中断优先级中优先权由高到低的次序是、T0、T1和串行口中断,若有多个中断源同时请求中断,CPU将先响应优先权高的中断,后响应优先权低的中断。通过中断优先级控制寄存器IP可以选择5个中断源的优先级别7. 3MCS-51有几个中断标志位?它们有什么相同之处,又有什么不同的地方?答:MCS-51有IE0、TF0、IE1、TF1、TI和RI共6个中断标志位。相同之处是这些中断标志位都是由硬件自动产生的,不同之处是外部中断和计数/定时器中断标志的清零是由硬件自

42、动完成的,而串行口中断标志(TI、RI)不会自动清除,必须由用户在串行中断服务程序中用指令对TI或RI清0。7. 4试编程实现,将设为高优先级中断,且为电平触发方式,T0溢出中断设为低优先级中断,串行口中断为高优先级中断,其余中断源设为禁止状态。答:MOVIE,#10010110B;T0、串行口允许中断MOVIP,#00010100B;和串行口中断为高优先级CLRIT1;电平触发方式7. 5如何将定时器中断扩展为外部中断源?答:(1)置定时/计数器为工作模式2,且为计数方式,即8位的自动装载方式;(2)定时/计数器的高8位和低8位初值都预置0FFH;(3)将定时/计数器的计数输入端(P3.3、

43、P3.4)作为扩展的外部中断请求输入;(4)在相应的中断服务程序入口开始存放外中断服务的中断服务程序。7. 8试用中断技术设计一个秒闪电路,其功能是发光二级管LED每秒闪亮400ms。主机频率为6MHz。答:主机频率6MHz,定时器最大定时130ms左右,取100ms为定时时间单位,高电平包含6个单位,低电平包含4个单位,共10个单位。选用定时器T0模式1,初值:P1.7驱动发光二极管,R7作时间单位计数器。电路如图7-1。电路中7404是反向器,P1.7输出高电平,灯不亮。编程:ORG0000H;复位地址LJMPSTAT;转初始化程序ORG000BH;T0中断服务程序LJMPPT0;转T0中

44、断服务程序ORG1000H;初始化程序首地址STAT:CLRP1.7;输出低电平MOVTMOD#01H;置T0定时器方式1MOVTH0,#3CH;置T0初值,定时100msMOVTL0,#0B0H;置T0初值,定时100msSETBTR0,;T0启动MOVR7,#10;计数器置初值MOVIE,#10000010B;T0开中LJMP$;等待中断PT0:CJNER7,#10,PT02SETBP1.7;计数器值105时,灯灭PT04LJMPPT02:CJNECLR时,灯亮PT04:DJNZMOVPT0D:RETIR7,#4,PT04P1.7R7,PT0DR7,#10;中断返回;计数器值41;计数器置

45、初值第8章MCS-51单片机的系统扩展8. 1在MCS-51扩展系统中,程序存储器和数据存储器共用16位地址线和8位数据线,为什么两个存储空间不会发生冲突?答:程序存储器和数据存储器虽然共用16位地址线和8位数据线,但数据存储器的读和写由和信号控制,程序存储器由读选通信号控制,两者虽然共处同一地址空间,但由于控制信号不同,故不会发生总线冲突。8.2MCS-51单片机的寻址围是多少?8031单片机可以配置的存储器最大容量是多少?而用户可以使用的最大容量又是多少答:MCS-51单片机的寻址围是64KB,既0000HFFFFH;8031单片机可以配置的存储器最大容量:程序存储器64KB;片外数据存储

46、器64KB;用户可以使用的最大容量是:64KBROM、64KBRAM、128B片RAM及SFR。8.3为什么单片机外扩存储器时,P0要外接锁存器,而P2口却不接?答:单片机外扩存储器时,P0要外接锁存器,是因为P0口是分时提供低8位地址和数据信息的,为避免低8位地址信息丢失,所以P0要外接锁存器;而P2不具备分时、复用功能,所以不用外接锁存器。8.4程序存储器和数据存储器的扩展有何相同点及不同点?试将8031芯片外接一片2732EPROM和一片6116RAM组成一个扩展系统,画出连接的逻辑图。答:程序存储器和数据存储器的扩展相同点是:由P2口提供高8位地址,P0口分时提供低8位地址和8位双向数

47、据线。CPU的和信号控制,地址空间任意选取;程序存储器读选信号由CPU的控制,程序空间从0000H开始。8031与2732、6116连接的电路图如图8-1。图8-18031与2732.«116连接的电路图程序存储器和数据存储器的扩展不相同点是:数据存储器的读和写由8.5设某一以8031单片机为主的系统,拟采用2片2732AEPROM芯片,扩展成8KB程序存储器,请设计它的硬件结构图。答:8031单片机与两片2732AEPROM芯片连接如图8-2IM3_slilFKkkL22加*EQMGPiSiTI碗窗R的"?直。福XI0口D口03DIrt£Jd.a.Jti7图S-

48、2S031单片机与两片2732连接的电路图8.6设某一以8031单片机为主的系统,拟扩展4KB数据存储器,请考虑选用合适的RAM芯片,并设计它的硬件结构图。答:静态RAM6116的容量是2KB,选用2片6116可满足扩展要求,8031单片机与2片6116芯片连接如图8-3。一空RsrP川田。pjlD皿他川E喟白图8-38031与两片6116的连接图8. 8用8255芯片扩展单片机的I/O口,8255的A口用作输入,A口的每一位接一个开关,用B口作为输出,输出的每一位接一个显示发光二极管,现要求某个开关接1时,相应位上的发光二极管就亮(输出为0),试编写相应的程序。答:分析可编程8255的工作状况可知:A口为普通输入,B口普通输出,C口未用,可定义成普通输入,控制字为10011001B,即99H,编程如下MOVDPTR,#8255命令口MOVA,#99HMOVXDPTR,ALOOP:MOVDPTR,#8255A口MOVXA,DPTRCPLAMOVDPTR,#8255B口MOVXDPTR,ALJMPLOOP第9章MCS巧1单片机的接口技术9. 2CPU对键

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论