




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
单片机课后习题答案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只接见片内flashRom并执行内部程序,储藏器。/EA端接低电平时,CPU只接见外面ROM,并执行片外程序储藏器中的指令。/EA端保持高电平时,CPU执行内部储藏器中的指令。3.89C51的储藏器分哪几个空间?如何差别不相同空间的寻址?答:ROM(片内ROM和片外ROM一致编址)(使用MOVC)(数据传达指令)(16bits地址)(64KB)片外RAM(MOVX)(16bits地址)(64KB)片内RAM(MOV)(8bits地址)(256B)简述89C51片内RAM的空间分配。答:片内RAM有256B,低128B是真切的RAM区,高128B是SFR(特别功能存放器)区。5.简述布尔办理储藏器的空间分配,片内RAM中包括哪些可位寻址单元。答:片内RAM区从00H~FFH(256B)其中20H~2FH(字节地址)是位寻址区对应的位地址是00H~7FH如何简捷地判断89C51正在工作?答:用示波器观察8051的XTAL2端可否有脉冲信号输出(判断震荡电路工作可否正常?)ALE(地址锁存赞同)(AddressLatchEnable)输出是fosc的6分频用示波器观察ALE可否有脉冲输出(判断8051芯片的利害?)观察PSEN(判断8051能够到EPROM或ROM中读取指令码?)由于/PSEN接外面EPROM(ROM)的/OE端子OE=OutputEnable(输出赞同)89C51如何确定和改变当前工作存放器组?答:PSW(程序状态字)(ProgramStatusWord)中的RS1和RS0能够给出4中组合,用来从4组工作存放器组中进行选择PSW属于SFR(SpecialFunctionRegister)(特别功能存放器)9.读端口锁存器和“读引脚”有何不相同?各使用哪一种指令?答:读锁存器(ANLP0,A)就是相当于从储藏器中拿数据,而读引脚是从外面拿数据(如MOVA,P1这条指令就是读引脚的,意思就是把端口p1输入数据送给A)传达类MOV,判位转移JB、JNB、这些都属于读引脚,平时实验时经常用这些指令于外面通信,判断外部键盘等;字节交换XCH、XCHD算术及逻辑运算ORL、CPL、ANL、ADD、ADDC、SUBB、INC、DEC控制转移CJNE、DJNZ都属于读锁存器。10.89C51P0~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功能的方式供给?答:第一功能第二功能串行口:P3.0RXD(串行输入口)P3.1TXD(串行输出口)中止:P3.2INT0外面中止0P3.3INT1外面中止1准时器/计数器(T0、T1):P3.4T0(准时器/计数器0的外面输入)P3.5T1(准时器/计数器1的外面输入)数据储藏器选通:P3.6WR(外面储藏器写选通,低电平有效,输出)P3.7RD(外面储藏器读选通,低电平有效,输出)准时器/计数器(T2):P1.0T2(准时器T2的计数端)P1.1T2EX(准时器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如何确定和改变当前工作存放器组?RS1/RS00/00/11/01/1使用的工作存放器0123地址00-0708-0F10-1718-1F写程序的时候就是经过定义程序状态字来选择使用不相同的存放器组。也能够直接对RS1和RS0赋值。16.程序状态存放器PSW的作用是什么?常用标志有哪些位?作用是什么?答:PSW是一个SFR(特别功能存放器)位于片内RAM的高128B详尽地址D0H(00H~FFH)(片内RAM的编址)(8bits编址方法)PSW=ProgramStatusWord(程序状态字)PSW的常用标志位有哪些?CY=Carry(进位标志位)AC=AuxiliaryCarry(辅助进位标志位)(半进位标志位)F0用户标志位RS1,RS0,用来选择当前工作存放器组(R0~R7)(4选1)OV=Overflow(溢出标志位)P=Parity(奇偶校验位)17.位地址7CH与字节地址7CH如何差别?位地址7CH详尽在片内RAM中的什么地址?答:用不相同的寻址方式来加以划分,即接见128个位地址用位寻址方式,接见低128字节单元用字节寻址和间接寻址。详尽地址为2F的第五位,即为7C。18.89C51单片机的时钟周期与振荡周期之间有什么关系?什么叫机器周期和指令周期?答:时钟信号的周期称为机器状态周期,是振荡周期的两倍。一个机器周期是指问储藏器一次所需的时间。指令周期是执行一条指令所需的时间。
CPU
访一个机器周期的时序如何划分?答:一个机器周期=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或,28051最大为128字节的片内储藏器,0X20以上理论都能够做货仓用96字节,8052为256字节224字节可用,但这样便没有其他空间可用于数据储藏现在的单片机的程序一般都能用C51来,不用关心货仓大小与SP存放器89C51有几种低功耗方式?如何实现?答:悠闲方式和掉电方式悠闲方式和掉电方式是经过对SFR中的PCON(地址87H)相应地址1而启动的。当CPU执行完置IDL=1(PCON.1)的指令后,系统进入悠闲工作方式。这时,内部时钟不向CPU供给,而只供给中止、串行口、准时器部分。CPU的内部状态保持,即包括货仓指针SP、程序计数器PC、程序状态字PSW、累加器ACC所有的内容保持不变,端口状态也保持不变。ALE和PSEN保持逻辑高电平。当CPU执行一条置PCON.1位(PD)为1的指令后,系统进入掉电工作方式。在这类工作方式下,内部振荡器停止工作。由于没有振荡时钟,所以,所有的功能部件都停止工作。但内部RAM区和特别功能存放器的内容被保留,而端口的输出状态值都保留在对应的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是能够接见的,如MOVDPTR,#XXXXH,INCDPTP。23.89C51端口锁存器的“读—更正—写”操作与“读引脚”操作有何差别?答:指令系统中有些指令读锁存器的值,有些指令则读引脚上的值。读锁存器指令是从锁存器中读取一个值并进行办理,把办理后的值(原值或已更正后的值)重新写入锁存器中。这类指令称为读-更正-写指令。对于读-更正-写指令。直接读锁存器而不是读端口引脚,是由于从引脚上读出的数据不用然能真切反响锁存器的状态。单片机原理及接口技术课后习题答案第三章1、指令:CPU依照人的妄图来执行某种操作的命令指令系统:一台计算机所能执行的所有指令会集机器语言:用二进制编码表示,计算机能直接鉴别和执行的语言汇编语言:用助记符、符号和数字来表示指令的程序语言高级语言:独立于机器的,在编程时不需要对机器结构及其指令系统有深入认识的通用性语言3、操作码[目的操作数][,源操作数]5、SFR:直接寻址,位寻址,存放器寻址;片外RAM:存放器间接寻址6、MOVA,40H;直接寻址(40H)→AMOVR0,A;存放器寻址(A)→R0MOVP1,#0F0H;马上数寻址0F0→P1MOV@R0,30H;直接寻址(30H)→(R0)MOVDPTR,#3848H;马上数寻址3848H→DPTRMOV40H,38H;直接寻址(38H)→40HMOVR0,30H;直接寻址(30H)→R0MOVP0,R0;存放器寻址(R0)→P0MOV18H,#30H;马上数寻址30H→18HMOVA,@R0;存放器间接寻址((R0))→AMOVP2,P1;直接寻址(P1)→P2最后结果:(R0)=38H,(A)=40H,(P0)=38H,(P1)=(P2)=0F0H,(DPTR)=3848H,18H)=30H,(30H)=38H,(38H)=40H,(40H=40H,(48H)=38H注意:→左边是内容,右边是单元7、用直接寻址,位寻址,存放器寻址8、MOVA,DATA;直接寻址2字节1周期MOVA,#DATA;马上数寻址2字节1周期MOVDATA1,DATA2;直接寻址3字节2周期MOV74H,#78H;马上数寻址3字节2周期若是想查某一指令的机器码,字节数或周期数可查阅书本后边的附录A9MOVA,@R0;((R0))=80H→AMOV@R0,40H;(40H)=08H→(R0)MOV40H,A;(A)=80→40HMOVR0,#35H;35H→R0最后结果:(R0)=35HA)=80H,(32H)=08H,(40H)=80H10、用直接寻址,位寻址,存放器寻址11、只能采用存放器间接寻址(用MOVX指令)12、低128字节:直接寻址,位寻址,存放器间接寻址,存放器寻址(R0~R7)高128字节:直接寻址,位寻址,存放器寻址13、采用变址寻址(用MOVC指令)14、压缩BCD码在进行加法运算时应逢十进一,而计算机只将其看作十六进制数办理,此时获取的结果不正确。用DAA指令调整(加06H,60H,66H)15、用来进行位操作16、ANLA,#17H;83H∧17H=03H→AORL17H,A;34H∨03H=37H→17HXRLA,@R0;03H⊕37H=34HCPLA;34H求反等于CBH所以(A)=CBH17、(1)SETBACC.0或SETBE0H;E0H是累加器的地址18、MOV27H,R7MOV26H,R6MOV25H,R5MOV24H,R4MOV23H,R3MOV22H,R2MOV21H,R1MOV20H,R019、MOV2FH,20MOV2EH,21MOV2DH,2220、CLRCMOVA,#5DH;被减数的低8位→AMOVR2,#B4H;减数低8位→R2SUBBA,R2;被减数减去减数,差→AMOV30H,A;低8位结果→30HMOVA,#6FH;被减数的高8位→AMOVR2,#13H;减数高8位→R2SUBBA,R2;被减数减去减数,差→AMOV31H,;高8位结果→30H注意:若是在你的程序中用到了进位位,在程序开始的时候要记得清0进位位21、(1)A≥10CJNEA,#0AH,L1;(A)与10比较,不等转L1LJMPLABEL;相等转LABELL1:JNCLABEL;(A)大于10,转LABEL也许:CLRCSUBBA,#0AHJNCLABEL2)A>10CJNEA,#0AH,L1;(A)与10比较,不等转L1RET;相等结束L1:JNCLABEL;(A)大于10,转LABELRET;(A)小于10,结束也许:CLRCSUBBA,#0AHJNCL1RETL1RET;数据块长度减1,不等于0,连续查找(3)A≤10RETCJNEA,#0AH,L127、MOVDPTR,#SOURCE;A)与10比较,不等转L1;源首地址→DPTRL2:LJMPLABEL;相等转LABELMOVR0,#DISTL1:JCL2;(A)小于10,转L2;目的首地址→R0RETLOOP:MOVXA,@DPTR也许:;传达一个字符CLRCMOV@R0,ASUBBA,#0AHINCDPTRJCLABELJZLABELRET22、(SP)=23H,(PC)=3412H23、(SP)=27H,(26H)=48H,(27H)=23H,(PC)=3456H参看书上79页24、不能够。ACALL是短转指令,可调用的地址范围是2KB。在看这个题的时候同时看一下AJMP指令。同时考虑调用指令ACALL和LCALL指令和RET指令的关系。25、MOVR2,#31H;数据块长度→R2MOVR0,#20H;数据块首地址→R0LOOP:MOVA,@R0;待查找的数据→ACLRC;清进位位SUBBA,#0AAH;待查找的数据是0AAH吗JZL1;是,转L1INCR0;不是,地址增1,指向下一个待查数据DJNZR2,LOOP;数据块长度减1,不等于0,连续查找MOV51H,#00H;等于0,未找到,00H→51HRETL1:MOV51H,#01H;找到,01H→51HRET26、MOVR2,#31H;数据块长度→R2MOVR0,#20H;数据块首地址→R0LOOP:MOVA,@R0;待查找的数据→AJNZL1;不为0,转L1INC51H;为0,00H个数增1L1:INCR0;地址增1,指向下一个待查数据DJNZR2,LOOP;指向下一个字符INCR0CJNEA,#24H,LOOP;传达的是“$字”符吗?不是,传达下一个字符RET28、MOVA,R3;取该数高8位→AANLA,#80H;取出该数符号判断JZL1;是正数,转L1MOVA,R4;是负数,将该数低8位→ACPLA;低8位取反ADDA,#01H;加1MOVR4,A;低8位取反加1后→R4MOVA,R3;将该数高8位→ACPLA;高8位取反ADDCA,#00H;加上低8位加1时可能产生的进位MOVR3,A;高8位取反加1后→R3L1:RET29、CLRC;清进位位CMOVA,31H;取该数低8位→ARLCA;带进位位左移1位MOV31H,A;结果存回31HMOVA,30H;取该数高8位→ARLCA;带进位位左移1位MOV30H,A;结果存回30H30、MOVR2,#04H;字节长度→R2MOVR0,#30H;一个加数首地址→R0MOVR1,#40H;另一个加数首地址→R1CLRC;清进位位LOOP:MOVA,@R0;取一个加数ADDCA,@R1;两个加数带进位位相加DAA;十进制调整MOV@R0,A;存放结果INCR0;指向下一个字节MOVA,@R0;98H→AINCR1;INCR0;41H→R0DJNZR2,LOOPADDA,@R0;98H+(41H)=47H→AINCR0;数据块长度减1,不等于0,连续查找RETMOV@R0,A;结果存入42H单元31、MOVR2,#08H;数据块长度→R2CLRA;清AMOVR0,#30HADDCA,#0;进位位存入AINCR0;数据块目的地址→R0MOVDPTR,#2000HMOV@R0,A;进位位存入43H;数据块源地址→DPTRLOOP:MOVXA,@DPTR;传达一个数据MOV@R0,AINCDPTR;指向下一个数据INCR0;DJNZR2,LOOP;数据块长度减1,没传达完,连续传达RET32、(1)MOVR0,0FH;2字节,2周期4字节4周期(差)MOVB,R0;2字节,2周期(2)MOVR0,#0FH;2字节,1周期4字节3周期(中)MOVB,@R0;2字节,2周期(3)MOVB,#0FH;3字节,2周期3字节2周期(好)33、1)功能是将片内RAM中50H~51H单元清0。2)7A0A(大家能够看一下书上,对于马上数寻址的话,后边一个字节存放的是马上数)7850(第一个字节的后三位是存放器,前一个条指令是010也就是指的R2,在这里是R0,所以应该是78,后一个字节存放的是马上数)DAFC(这里涉及到偏移量的计算,能够34、INC@R0;(7EH)=00HINCR0;(R0)=7FHINC@R0;(7FH)=39HINCDPTR;(DPTR)=10FFHINCDPTR;(DPTR)=1100HINCDPTR;(DPTR)=1101H35、解:(1000H)=53H(1001H)=54H(1002H)=41H1003H)=52H(1004H)=54H(1005H)=12H(1006H)=34H(1007H)=30H1008H)=00H1009H)=70H36、MOVR0,#40H;40H→R0功能:将40H,41H单元中的内容相加结果放在42H单元,进位放在43H单元,(R0)=43H,A)=1,(40H)=98H,(41H)=AFH,(42H)=47H,(43H)=01H37、MOVA,61H;F2H→AMOVB,#02H;02H→BMULAB;F2H×O2H=E4H→AADDA,62H;积的低8位加上CCH→AMOV63H,A;结果送62HCLRA;清AADDCA,B;积的高8位加进位位→AMOV64H,A;结果送64H功能:将61H单元的内容乘2,低8位再加上62H单元的内容放入63H,将结果的高8位放在64H单元。(A)=02H,(B)=01H,(61H)=F2H,(62H)=CCH,(63H)=B0H,(64H)=02H39、MOVA,XXHORLA,#80HMOVXXH,A40、(2)MOVA,XXHMOVR0,AXRLA,R0第五章1、什么是中止和中止系统?其主要功能是什么?答:当CPU正在处理某件事情的时候,外面发生的某一件事件央求CPU迅速去办理,于是,CPU暂时中止当前的工作,转去办理所发生的事件,中止服务办理完该事件今后,再回到原来被停止的地方,连续原来的工作。这类过程称为中止,实现这类功能的部件称为中止系统。功能:(1)使计算机拥有实时办理能力,能对外界异步发生的事件作出实时的办理(2)完满除掉了CPU在盘问方式中的等待现象,大大提高了CPU的工作效率7/18页(3)实现实时控制2、试编写一段对中止系统初始化的程序,使之赞同INT0,INT1,TO,串行口中止,且使T0中止为高优先级中止。解:MOVIE,#097HMOVIP,#02H3、在单片机中,中止能实现哪些功能?答:有三种功能:分时操作,实时办理,故障办理4、89C51共有哪些中止源?对其中端央求如何进行控制?答:(1)89C51有以下中止源①:外面中止0央求,低电平有效②:外面中止1央求,低电平有效③T0:准时器、计数器0溢出中止央求④T1:准时器、计数器1溢出中止央求⑤TX/RX:串行接口中止央求2)经过对特别功能存放器TCON、SCON、IE、IP的各位进行置位或复位等操作,可实现各种中止控制功能5、什么是中止优先级?中止优先办理的原则是什么?答:中止优先级是CPU相应中止的先后序次。原则:(1)先响应优先级高的中止央求,再响应优先级低的(2)若是一其中止央求已经被响应,同级的其他中止央求将被禁止(3)假好像级的多个央求同时出现,则CPU经过内部硬件盘问电路,按盘问序次确定应该响应哪其中止央求盘问序次:外面中止0→准时器0中止→外面中止1→准时器1中止→串行接口中止6、说明外面中止央求的盘问和响应过程。答:当CPU执行主程序第K条指令,外设向CPU发出中止央求,CPU接到中止央求信号并在本条指令执行完后,中止主程序的执行并保留断点地址,尔后转去响应中止。CPU在每个S5P2时期序次采样每其中止源,CPU在下一个机器周期S6时期按优先级序次查询中止标志,若是盘问到某其中止标志为1,将在接下来的机器周期S1时期按优先级进行中止办理,中止系统经过硬件自动将相应的中止矢量地址装入PC,以便进入相应的中止服务程序。中止服务达成后,CPU返回到主程序第K+1条指令连续执行。7、89C51在什么条件下可响应中止?答:(1)有中止源发出中止央求(2)中止中赞同位EA=1.即CPU开中止(3)申请中止的中止源的中止赞同位为1,即中止没有被障蔽(4)无同级或更高级中止正在服务(5)当前指令周期已经结束(6)若现行指令为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,串行口中止。能够,MOVIP,#0AH⑵串行口中止,外中止0,准时器0,外中止1,准时器1。能够,MOVIP,#10H⑶外中断0,准时器1,外中止1,准时器0,串行口中止。不能够够,只能设置一级高级优先级,若是将INT0,T1设置为高级,而T0级别高于INT1.⑷外中止0,外中止1,串行口中止,准时器0,准时器1。能够,MOVIP,#15H行口中止,准时器0,外中止0,外中止1,准时器1。不能够够⑹外中止0,外中止1,准时器0,串行口中止,准时器1。不能
⑸串⑺外中止0,准时器1,准时器0,外中止1,串行口中止。能够,MOVIP,#09H14、89C51各中止源的中止标志是如何产生的?又是如何清0的?CPU响应中止时,中止入口地址各是多少?答:各中止标志的产生和清“0”以下:(1)外面中止类0和外面中止1输入外面中止是由外面原因惹起的,能够经过两个固定引脚,即外面中止信号。外面中止0央求信号,由P3.2脚输入。经过IT0来决定中止央求信号是低电平有效还是下跳变有效。一旦输入信号有效,则向CPU申请中止,而且使IE0=1。硬件复位。外面中止1央求信号,功能与用法近似外面中止(2)准时中止类准时中止是为满足准时或计数溢出办理需要而设置的。当准时器/计数器中的计数结构发生计数溢出的,即表示准时时间到或计数值已满,这时就以计数溢出信号作为中止央求,去置位一个溢出标志位。这类中止央求是在单片机芯片内部发生的,无需在芯片上设置引入端,但在计数方式时,中止源能够由外面引入。TF0:准时器T0溢出中止央求。当准时器T0产生溢出时,准时器T0央求标志TF0=1,央求中止办理。使用中止时由硬件复位,在盘问方式下可由软件复位。TF1:准时器T1溢出中止央求。功能与用法近似准时器T0(3)串行口中止类串行口中止是为串行数据的传达需要而设置的。串行中止央求也是在单片机芯片内部发生的,但当串行口作为接收端时,必定有一完满的串行帧数据从RI端引入芯片,才可能惹起中止。RI或TI:串行口中止央求。当接收或发送一串帧数据时,使内部串行口中止央求标志RI或TI=1,并央求中止。响应后必定软件复位。CPU响应中止时,中止入口地址以下:中止源入口地址外面中止00003H准时器T0中止000BH外面中止10013H准时器T1中止001BH串行口中止0023H15、中止响应时间可否为确定不变的?为什么?答:中止响应时间不是确定不变的。由于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)置位相应的优先级状态触发器,以注明所响应中止的优先级别中止源标志清零(TI、RI除外)中止断点地址装入货仓保护(不保护PSW)d)中止入口地址装入PC,以便使程序转到中止入口地址处在计算机内部,中止表现为CPU的微盘问操作。89C51单片机中,CPU在每个机器周期的S6状态,盘问中止源,并按优先级管理规则办理同时央求的中止源,且在下一个机器周期的S1状态中,响应最高等中止央求。但是以下情况除外:CPU正在办理相同或更高优先级中止b)多机器周期指令中,还未执行到最后一个机器周期正在执行中止系统的SFR操作,如RETI指令及接见IE、IP等操作时,要延后一条指令18、在中止央求有效并开中止情况下,可否保证马上响应中止?有什么条件?答:在中止央求有效并开中止情况下,其实不能够保证马上响应中止。这是由于,在计算机内部,中止表现为CPU的微盘问操作。89C51单片机中,CPU在每个机器周期的S6状态下,盘问中止源,并按优先级管理规则办理同时央求的中止源,且在下一个机器周期的S1状态中,响应最高等中止央求。在以下情况下,还需要有其他的等待:a)CPU正在办理相同或更高优先级中止多机器周期指令中,还未执行到最后一个机器周期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位:1BHT0高8位:FFHMOVTMOD,#00H;设置准时器T0工作于模式0MOVTL0,#1BH;设置5ms准时初值MOVTH0,#0FFHSETBTR0;启动
T0LOOP:JBCTF0,L1;盘问到准时时间到?时间到转L1SJMPLOOP;时间未到转LOOP,连续盘问
L1:MOVTL0,#1BH;重新置入准时初值MOVTH0,#0FFHCPLP1.0;输出取反,形成等宽矩形波
SJMPLOOP
;重复循环3、89C51准时器有哪几种工作模式?有何差别?答:有四种工作模式:模式
0,模式
1,模式2,模式31)模式0:选择准时器的高8位和低5位组成一个13位准时器/计数器。TL低5位溢出时向TH进位,TH溢出时向中止标志位TF进位,并申请中止。准时时间t=(213-初值)×振荡周期×12;计数长度位213=8192个外面脉冲2)模式1:与模式0的唯一差别是存放器TH和TL以所有16位参加操作。准时时间t=(216-初值)×振荡周期×12;计数长度位216=65536个外面脉冲(3)模式2:把TL0和TL1配置成一个自动重装载的8位准时器/计数器。TL用作8位计数器,TH用以保留初值。TL计数溢出时不但使TF0置1,而且还自动将TH中的内容重新装载到TL中。准时时间t=(28-初值)×振荡周期×12;计数长度位28=256个外面脉冲(4)模式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种工作模式的特点,如何选择设定?答:(1)模式0:选择准时器的高8位和低5位组成一个13位准时器/计数器。TL低5位溢出时向TH进位,TH溢出时向中止标志位TF进位,并申请中止。准时时间t=(213-初值)×振荡周期×12;计数长度位213=8192个外面脉冲置TMOD中的M1M0为00(2)模式1:与模式0的唯一差别是存放器TH和TL以所有16位参加操作。准时时间t=(216-初值)×振荡周期×12;计数长度位216=65536个外面脉冲置TMOD中的M1M0为01(3)模式2:把TL0和TL1配置成一个自动重装载的8位准时器/计数器。TL用作8位计数器,TH用以保留初值。TL计数溢出时不但使TF0置1,而且还自动将TH中的内容重新装载到TL中。准时时间t=(28-初值)×振荡周期×12;计数长度位28=256个外面脉冲置TMOD中的M1M0为10(4)模式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为117、当T0用作模式3时,由于TR1已被T0占用,如何控制T1的开启和关闭?答:用T1控制位C/T切换准时器或计数器工作方式就可以使T1运行。准时器T1无工作模式3,将T1设置为工作模式3,就会使T1马上停止计数,关闭。8、以准时器/计数器1进行外面时间计数,每计数1000个脉冲后,准时器/计数器1转为准时工作方式,准时10ms后又转为计数方式,这样循环不仅。假设为6WHZ,用模式1编程。解:T1为准时器时初值:T1为计数器时初值:所以:L1:MOVTMOD,#50H;设置T1为计数方式且工作模式为1MOVTH1,#0FCH;置入计数初值MOVTL1,#18HSETBTR1;启动T1计数器LOOP1:JBCTF1,L2;盘问计数溢出?有溢出(计数满1000个)转L2SJMPLOOP1;无溢出转LOOP1,连续盘问L2:CLRTR1;关闭T1MOVTMOD,#10H;设置T1为准时方式且工作与模式111/18页MOVTH1,#0ECH;置入准时10ms初值14、已知89C51单片机的fosc=12MHz,MOVTL1,#78H用T1准时。试编程由P1.0和P1.1引脚分别输出周SETBTR1;启动T1准时期为2ms和500μs的方波。LOOP2:JBCTF1,L1解:采用模式0作准时初值:;盘问10ms时间到?时间到,转L1所以MOVR2,#04HSJMPLOOP2;R2为“250μ计s”数器,置入初值4CLRP1.0;P1.0输出低电平;时间未到,转LOOP2,连续盘问9、一个准时器准时时间有限,如何实现两个定CLRP1.1;P1.1输出低电平时器的串行准时以满足较长准时时间的要求?MOVTMOD,#00H答:当一个准时器溢出时,设置另一个准时器的L2:MOVTH1,#0F8H初值为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准时时的初值:MOVTMOD,#02H;设置准时器T0工作于模式2L2:CLRP1.0;P1.0输出低电平MOVTH0,#6AH;置入准时300μs初值MOVTL0,#6AHSETBTR0;启动T0LOOP1:JBCTF0,L1;盘问300μs时间到?时间到,转L1SJMPLOOP1;时间未到,转LOOP1,连续盘问L1:SETBP1.0;P1.0输出高电平CLRTR0;关闭T0MOVTH0,#0E7H;置入准时300μs初值MOVTL0,#0E7HSETBTR0;启动T0LOOP2:JBCTF0,L2;盘问50μs时间到?时间到,转L2SJMPLOOP2;时间未到,转LOOP2,连续盘问;置入准时250μs初值MOVTL1,#06HSETBTR1;启动T1LOOP:JBCTF1,L1;盘问250μs时间到?时间到,转L1SJMPLOOP;时间未到,转LOOP,连续盘问L1:CPLP1.1;P1.1输出取反,形成周期为500μsCLRTR1关;闭T1DJNZR2,L2;“250μ计s”数器减1,到1ms吗?未到转L2CPLP1.0;P1.0输出取反,形成周期为2ms方波MOVR2,#04H;重置“250μ计s”数器初值4LJMPL2;重复循环15、单片机8031的时钟频率为6MHz,若要求准市价分别为0.1ms,1ms,10ms,准时器0工作在模式0、模式1和模式2时,其准时器初值各应是多少?解:(1)0.1ms模式0:T0低5位01110B=0EHT0高8位:11111110B=FEH模式1:模式2:2)1ms模式0:T0低5位01100B=0CHT0高8位:11110000B=F0H模式1:模式2:在此情况下最长准时为512μs,无法一次实现准时1ms,可用0.1ms循环10次3)10ms模式0:T0低5位11000B=18H12/18页T0高8位:01100011B=63HSJMPLOOP模式1:;时间未到,转LOOP,连续盘问模式2:在此情况下最长准时为512μs,无法一L1:CLRTR0;关闭T0DJNZR2,L2次实现准时10ms,可用0.1ms循环100次“200μ计s”数器减1,到1ms吗?未到,转L216、89C51单片机的准时器在何种设置下可供给CPLP1.0三个8位计数器准时器?这时,准时器1可作为串;到1ms,P1.0取反,形成周期为2ms的方波行口波特率发生器。若波特率按9600b/s,4800b/MOVR2,#05Hs,2400b/s,1200b/s,600b/s,100b/s来考虑,则此时可采用的波特率是多少(赞同存在必然误差)?设fosc=12MHz。解:当T0为模式3,T1为模式2时,可供给3个8位准时器。可选100b/s17、试编制一段程序,功能为:当P1.2引脚的电平上跳时,对P1.1的输入脉冲进行计数;当P1.2引脚的电平下跳时,停止计数,并将计数值写入R6,R7。解:MOVTMOD,#05H;T0为计数方式且工作于模式1JNBP1.2,$;等待P1.2引脚电平上跳MOVTH0,#00H;P1.2电平上跳,置入计数初值MOVTL0,#00HSETBTR0;启动T0JBP1.2,$;等待P1.2引脚电平下跳CLRTR0;电平下跳,关闭T0MOVR7,TH0;计数初值写入R7,R6MOVR6,TL018、设fosc=12MHz。试编制一段程序,功能为:对定时器T0初始化,使之工作在模式2,产生200μs准时,并用盘问T0溢出标志的方法,控制P1.0输出周期为2ms的方波。解:T0作准时器时初值:所以程序1:CLRP1.0;P1.0输出低电平MOVR2,#05H;R2为“200μs计”数器,置入初值5,计1msMOVTMOD,#02H;设准时器T0工作于模式2L2:MOVTH0,#38H;置入准时初值MOVTL0,#38HSETBTR0;启动T0LOOP:JBCTF0,L1;盘问200μs时间到?时间到,转L1;重置“200μ计s”数器初值LJMPL2;重复循环程序2:MAIN:MOVTMOD,#02H;设准时器T0工作于模式2CLRP1.0;P1.0输出低电平LOOP1:MOVR2,#05H;R2为“200μ计s”数器,置入初值5,计1msLOOP:MOVTH0,#38H;置入准时初值MOVTL0,#38HSETBTR0;启动T0JNBTF0,$;盘问200μs时间到?时间到,连续盘问CLRTR0;关闭T0DJNZR2,LOOP;“200μs计”数器减1,到1ms吗?未到,转LOOPCPLP1.0;到1ms,P1.0取反,形成周期为2ms的方波SJMPLOOP1;重复循环19、以中止方法设计单片机秒、分脉冲发生器。假设P1.0每秒产生1个机器周期的正脉冲,P1.1每分产生1个周期的正脉冲。第七章1、什么是串行异步通信,它有哪些作用?答:在异步串行通信中,数据是一帧一帧(包括一个字符代码或一字节数据)传达的,每一帧的数据格式参照书。通信采用帧格式,无需同步字符。存在悠闲位也是异步通信的特征之一。2、89C51单片机的串行口由哪些功能部件组成?各有什么作用?答:89C51单片机的串行接口由发送缓冲期SBUF,接收缓冲期SBUF、输入移位存放器、串行接口控制器SCON、准时器T1组成的波特率发生器等部件组成。由发送缓冲期SBUF发送数据,接收缓冲期SBUF接收数据。串行接口通信的工作方式选择、接收和发送控制及状态等均由串行接口控制存放器SCON控制和指示。准时器T1产生串行通信所需的波特率。3、简述串行口接收和发送数据的过程。13/18页答:串行接口的接收和发送是对同一地址(99H)两个物理空间的特别功能存放器SBUF进行读和写的。当向SBUF发“写”命令时(执行“MOVSBUF,A”),即向缓冲期SBUF装载并开始TXD引脚向外发送一帧数据,发送完便使发送中止标志位TI=1。在满足串行接口接收中止标志位RI(SCON.0)=0的条件下,置赞同接收位REN(SCON.4)=1,就会接收一帧数据进入移位存放器,并装载到接收SBUF中,同时使RI=1。当发读SBUF命令时(执行“MOVA,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/s6、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;并用盘问串行口状态的方法,读出接收缓冲器的数据并回送到发送缓冲器。解:START:MOVSCON,#40H;串行接口工作于方式1MOVTMOD,#20H;准时器T1工作于模式2MOVTH1,#0E8H;赋准时器计数初值MOVTL1,#0E8HSETBTR1;启动准时器T1MOVA,SBUF;读出接收缓冲器数据MOVSBUF,A;启动发送过程JNBTI,$;等待发送完CLRTI;清TI标志SJMP$;结束8、若晶振为11.0592MHz,串行口工作与方式1,波特率为4800b/s。写出用T1作为波特率发生器的方式字和计数初值。解:MOVTMOD,#20H;准时器T1工作于模式2MOVTH1,#0FAH;赋准时器计数初值MOVTL1,#0FAH9、为什么准时器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中)的值来决定从机可否再接收主机的信息。若(14/18页RB8)=0,说明是数据帧,则使接收中止标志位RI=0,信息扔掉;若(地址帧,数据装入SBUF并置RI=1,中止所有从机,只有被寻
RB8)=1
说明是址的目标从机除掉SM2(SM2=0),以接收主机发来的一帧数据(点对点通信)。其他从机依旧保持SM2=1.13、当89C51串行口按工作方式1进行串行数据通信时。假设波特率为1200b/s,以中止方式传达数据。请编写全双工通信程序。解:设系统时钟频率fosc=6.0MHZ。查教材表9-2可知,可取SMOD=0,T1的计数初值为F3H。程序以下:ORG0000HAJMPMAIN;上电,转向主程序ORG0023H;串行口的中止入口地址AJMPSERVE;转向中止服务程序ORG0040H;主程序MAIN:MOVSP,#60H;设置货仓指针MOVSCON,#50HMOVPCON,#00HMOVTMOD,#20HMOVTH1,#0F3HMOVTL1,#0F3HSETBTR1MOVR0,#20H;置发送数据区首地址MOVR1,#40H;置接收数据区首地址MOVR7,#10H;置发送字节长度MOVR6,#10H;置接收字节长度SETBES;赞同串行口中止SETBEA;CPU赞同中止MOVA,@R0;取第一个数据发送MOVSBUF,A;发送第一个数据SJMP$;等待中止SERVE:JNBRI,SEND;TI=1,为发送中止CLRRIMOVA,SBUF;读出接收缓冲区内容MOV@R1,A;读入接收缓冲区DJNZR6,L1;判断数据块发送完否SJMPL2;数据块接收完,转L2L1:INCR1;更正数据区指针L2:RETI;中止返回SEND:CLRTI;除掉发送中止标志DJNZR7,L3;判断数据块发送完否SJMPL4;数据块接收完,转L4L3:MOVA,@R0;取数据发送MOVSBUF,A;发送数据INCR0;更正数据地址L4:RETI;中止返回END14、以89C51串行口按工作方式3进行串行数据通信。假设波特率为1200b/s,第9数据位作奇偶校验位,以中止方式传达数据。请编写通信程序。解:ORG0000HAJMPMAIN;上电,转向主程序ORG0023H;串行口的中止入口地址AJMPSTOP;转向中止服务程序ORG0040H;主程序MAIN:MOVSP,#60HMOVTMOD,#20HMOVTH1,#0E8HMOVTL1,#0E8HSETBTR1MOVSCON,#0D0HMOVPCON,#00HMOVR0,#20H;置发送数据区首地址MOVR1,#40H;置接收数据区首地址SETBES;赞同串行口中止SETBEA;CPU赞同中止MOVA,@R0MOVC,PSW.0;P→CCPLCMOVTB8,CMOVSBUF,A;发送第一个数据SJMP$STOP:JNBRISOUT;TI=1,为发送中止CLRRIMOVA,SBUF;读出接收缓冲区内容MOVC,PSW.0;P→CCPLC;形成奇校验JCLOOP1;判断接收端的奇偶值,C=1转LOOP1JNBRB8,LOOP2;C=0,RB8=0,转LOOP2SJMPERROR;C=0,RB8=1,转出错办理LOOP1:JBRB8,LOOP2片内256字节数据储藏器RAM/SFR用来存放能够读;C=1,RB8=1,转LOOP2/写的数据,片内4KB程序储藏器FLASHROM用存放SJMPERROR;C=0,RB8=1,转出错办理程序、数据、表格,4个8位并行I/O端口P0-LOOP2:P3,两个16位的准时器/计数器,5其中止源、两其中止个优先级的中止控制系统,MOV@R1,A一个全双工UART的串行口I/O口,片内振荡器和;将接收数据送入接收数据区时钟产生电路,休闲方式和掉电方式。INCR1;更正数据区指针RETI6.89C51片内程序储藏器容量为4KB,地址从0000-SOUT:CLRTI;是发送中止,除掉发送中止标志INCR0;更正数据区指针MOVA,@R0MOVPSW.0,C;P→CCPLCMOVTB8,CMOVSBUF,A;发送第一个数据RETIERROR:15、某异步通信接口,其帧格式由1个初步位(0),7个数据位,1个奇偶校验位和1个停止位(1)组成。当该接口每分钟传达1800个字符时,试计算出传达波特率。解:该异步通信接口的帧格式为10b/字符,当该接口每分钟传达1800个字符时:波特率=(10b/字符)×(1800字符/60s)=300b/s16、串行口工作在方式1和方式3时,其波特率与fosc、准时器T1工作模式2的初值及SMOD位的关系如何?设fosc=6MHz,现利用准时器T1模式2产生的波特率为110b/s。试计算准时器初值。解:关系以下:当波特率为110b/s,fosc=6MHz,令SMOD=0,有:17、设计一个单片机的双机通信系统,并编写通信程序。将甲机内部RAM40H--4FH储藏区中去。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的微办理器,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(对于8051/8751/80C51)或1FFFH(对于8052)时,将自动转向接见外面程序储藏器。当端保持低电平时,无论可否有内部程序储藏器,则只接见外面程序储藏器。
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 工程弱电劳务合同(4篇)
- 办公用品采购合同2025(20篇)
- 广告场地租赁合同(31篇)
- 2025年中国保温材料市场深度研究与投资前景评估报告
- 二手车交易行业市场分析报告2025年
- xxx药品采购合同8篇
- 【劳动合同】试用期公司解除劳动合同协议书范本10篇
- 房屋遗产协议书5篇
- 合同拆分协议5篇
- 公司合并合同(二)5篇
- 油漆涂料行业市场分析
- 人教部编版语文九年级上册第四单元分层作业设计11
- 揭阳市交通分析报告
- 学习有法贵在得法 高二上学期学法指导主题班会
- 初中八年级英语课件the Leaning Tower of Pisa
- 跨境数据流动与治理
- 《水工建筑物介绍》课件
- 300t汽车吊起重性能表
- 输血治疗知情同意书
- 幼儿园副园长聘任园长合同(36篇)
- 30道中国石油天然气地球物理勘探工程师岗位常见面试问题含HR常问问题考察点及参考回答
评论
0/150
提交评论