8031PSENWRRD27641272220VPPPGMOECEHM6116212018WEOECS212018WEOECS291617P2.7P2.6P2.5P2.4P2.3P2.2P2.1P2.02827262524232221HM6116U41922231234567819222312345678A10A9A8A7A6A5A4A3A2A1A0U5D7D6D5D4D3D2D1D0171615141311109ALE/P31130EA/VPU2P0.7P0.6P0.5P0.4P0.3P0.2P0.1P0.03233343536373839O7O6O5O4O3O2O1O0347813141718D0D1D2D3D4D5D6D7Q0Q1Q2Q3Q4Q5Q6Q7256912151619223212425345678910A12A11A10A9A8A7A6A5A4A3A2A1A0U31918171615131211A10A9A8A7A6A5A4A3A2A1A0U6D7D6D5D4D3D2D1D017161514131110911GOC74LS373
14. 答:(1)2864为8KB的存储器,如果首地址为8000H,则其末地址为9FFFH,理由参考第12题;
(2)电路图如下所示:
80313029161728272625242322213233343536373839P2.7P2.6P2.5P2.5P2.6P2.7123645U1ABCG1G2AG2B74LS138Y0Y1Y2Y3Y4Y5Y6Y715141312111097ALE/PPSENWRRDP2.7P2.6P2.5P2.4P2.3P2.2P2.1P2.0P0.7P0.6P0.5P0.4P0.3P0.2P0.1P0.0N1+5v31EA/VPU2
U1ABCG1G2AG2B74LS1382864N1272220223212425345678910WEOECEA12A11A10A9A8A7A6A5A4A3A2A1A0U31Y0Y1Y2Y3Y4Y5Y6Y7(3)电路图如下所示:
P2.5P2.6P2.78031+5vPSENWRRDP2.7P2.6P2.5P2.4P2.3P2.2P2.1P2.0P0.7P0.6P0.5P0.4P0.3P0.2P0.1P0.029161728P2.727P2.626P2.52524232221323334353637383934781314171811U4D0D1D2D3D4D5D6D7G74LS373Q0Q1Q2Q3Q4Q5Q6Q7OC256912151619164512315141312111097N1READY3130EA/VPU2D7D6D5D4D3D2D1D0ALE/P1918171615131211
第9章 MCS-51扩展I/O接口的设计
1.答:I/O端口简称I/O口,常指I/O接口电路中具有端口地址的寄存器或缓冲器。I/O接口是指单片机与外设间的I/O接口芯片。
I/O接口功能:一.实现和不同外设的速度匹配;二.输出数据缓存;三.输入数据三态缓冲。 2. 答:一.独立编址方式:独立编址方式就是I/O地址空间和存储器地址空间分开编址。独
立编址的优点是I/O地址空间和存储器地址空间相互独立,界限分明。但是,却需要设置一套专门的读写I/O的指令和控制信号。二.统一编址方式:这种编址方式是把I/O端口的寄存器与数据存储器单元同等对待,统一进行编址。统一编址的优点是不需要专门的I/O指令,直接使用访问数据存储器的指令进行I/O操作,简单、方便且功能强大。MCS-51单片机使用的是I/O和外部数据存储器RAM统一编址的方式。
3. 答:一、同步传送方式:同步传送又称为有条件传送。当外设速度可与单片机速度相比拟时,常常采用同步传送方式,最典型的同步传送就是单片机和外部数据存储器之间的数据传送。二、查询传送方式:查询传送方式又称为有条件传送,也称异步传送。单片机通过查询得知外设准备好后,再进行数据传送。异步传送的优点是通用性好,硬件连线和查询程序十分简单,但是效率不高。为了提高单片机的工作效率,通常采用中断方式。三、中断传送方式:中断传送方式是利用MCS-51本身的中断功能和I/O接口的中断功能来实现I./O数据的传送。单片机只有在外设准备好后,发出数据传送请求,才中断主程序,而进入与外设进行数据传送的中断服务程序,进行数据的传送。中断服务完成后又返回主程序继续执行。因此,采用中断方式可以大大提高单片机的工作效率。
4.答:本题主要考察对8255A的C口的操作。其方式控制字的高位为0时,低四位对C口进行置位。由题目我们得到了方式控制字的地址为7FFFH。
ORG MOV MOV MOVX MOV MOVX END
0000H DPTR,#7FFFH A,#0EH @DPTR,A A,#09H @DPTR,A
;将PC4置1
;控制字寄存器地址送DPTR ;将PC7置0
MAIN:
5. 答:8255A通过它们的最高位来进行判断,最高位为1时,这时8255A认为这是方式控制字,否则认为是C口按位置位/复位控制字
6. 答:当外设输入一个数据并送到PA7-PA0上时,输入设备自动在选通输入线STBA*向8255A发送一个低电平选通信号。8255A收到选通信号后:首先把PA7-PA0上输入的数据存入A口的输入数据缓冲/锁存器;然后使输入缓冲器输出线IBFA变成高电平,以通知输入设备,8255A的A口已收到它送来的输入数据。8255A检测到联络线STBA*由低电平变成了高电平、IBFA为1状态和中断允许触发器INTEA为1时,使输出线INTRA(PC3)变成高电平,向8031发出中断请求。(INTEA的状态可由用户通过对PC4的置位/复位来控制。8031相应中断后,可以通过中断服务程序从A口的输入数据缓冲/锁存器读取外设发来的输入数据。当输入数据被CPU读走后,8255A撤销INTRA上的中断请求,并使IBFA变为低电平,以通知输入外设可以送下一个输入数据。
7. 答:8155H的端口有以下几种:命令/状态寄存器、A口、B口、C口、计数器和RAM单元。引脚IO/M、A2、A1、A0决定端口地址。TIMERIN是计数器输入线,输入的脉冲上跳沿用于对8155H片内的14位计数器减一。TIMEROUT为计数器输入线。当14位计数器减为0时就可以在该引线上输出脉冲或方波,输出的信号的形状与所选的计数器工作方式有关。 8. 答: (1)8155H具有地址锁存功能;
(2)引脚IO/M、A2、A1、A0决定端口地址和RAM单元编址; (3)8255A不具有三态缓冲器;
(4)8255A的B口只可以设置成方式0和方式1。
9. 答:由于电路图比较简单,在这里就画了,大家可以参考图9-10,A口每一位接二极管
的正极,二极管的负极接低。B口每一位接一开关,开关直接接地。这样我们只需要将读到的B口的值送给A口就可以满足题目要求了。
ORG MOV MOV MOVX MOV MOVX MOV MOVX END
0000H
A,#10000010B DPTR,#0FF7FH @DPTR,A A,@DPTR @DPTR,A
DPTR,#0FF7DH DPTR,#0FF7CH
;A口出,B口入 ;控制地址送DPTR ;送方式控制字 ;B口地址送DPTR ;读开关信息 ;A口地址送DPTR ;将信息反溃到二极管
MIAN:
10. 答:8155H计数器的初值范围是:3FFFH-2H。当频率为4MHz,初值为3FFFH时,最大定时时间为:16383/4E+6=0.00409575S
11. 答:8255A具有3个8位的并行I/O口,3种工作方式,可通过编程改变其功能,因而使用灵活方便,通用性强,可作为单片机与多种外围设备连接时的中间接口电路。8155H芯片内包含有256B的RAM存储器(静态),2个可编程的八位并行口PA和PB,1个可编程的6位并行口PC,以及1个14位减法定时器/计数器。所以它经常用于单片机的外围接口芯片。 12. 答:将1MHz的脉冲改变为10ms的方波,这就让我们想到了在数字电路里面学到的分频器。计算得出分频前后频率之比为10000:1,这样我们只要将定时器初值设置为64H就可以了。(假设I/O口地址为7F00H-7F05H) START:
MOV MOV MOVX INC MOV MOVX MOV MOV MOVX END
DPTR,#7F04H A,#64H DPTR
@DPTR,A A,#40H
;指针指向定时器低8位 ;送初值给A ;初值送给低8位 ;指向高8位 ;定时器方波输出
;指向命令/状态口 ;设定控制字 ;启动定时器
@DPTE,A DPTR,#7F00H A,#0C2H
@DPTE,A
第10章 MCS-51与键盘、显示器、拨盘、打印机的接口设计
1. 答:在按键的闭合和断开过程中,由于开关的机械特性,导致了按键抖动的产生。如果不消除按键的机械抖动,按键的状态读取将有可能出现错误。消除按键抖动一般是采用软件或硬件去抖。软件去抖的原理:在第一次检测到有键按下时,该键所对应的航线是为低电平,执行一端延时10ms的子程序后,确认该行线电平是否仍然为低电平,如果仍为低电平,则确认为该行确实有键按下。
2. 答:(1)正确;(2)正确;(3)错误;(4)错误
3. 答:静态显示时,数据是分开送到每一位LED上的。而动态显示则是数据是送到每一个LED上,再根据位选线来确定是哪一位LED被显示。静态显示亮度很高,但口线占用较多。动态显示则好一点,适合用在显示位数较多的场合。 4. 答:80H(共阴极);7FH(共阳极)
5. 答:按键设置在行、列线交点上,行、列线分别连接到按键开关的两端。行线通过上拉电阻接到+5V上,无按键按下时,行线处于高电平状态,而当有按键按下时,行线电平状态将由与此行线相连的列线的电平决定。列线的电平如果为低,则行线电平为低;列线的电平如果为高,则行线的电平亦为高。将行、列线信号配合起来并做适当的处理,才能确定闭合键的位置。
6. 答:先对P1口高四位送低电平,读取P1口低四位的值;再对P1口低四位送低电平,读取P1口高四位的值,将两次读到的值组合在一起就得到了按键的特征码,在根据特征码查找键值。
KEYIN:
MOV MOV ANL MOV MOV MOV ANL ORL CJNE RET MOV MOV MOV INC MOV MOVC CJNE MOV RET CJNE RET
A,#0FFH,KEYIN2 ;未完,再查
;已查完,未找到,以未按键处理
P1,#0FH A,P1 A,#0FH B,A P1,#0F0H A,P1 A,#0F0H A,B
A,#0FFH,KEYIN1
;未按键 ;暂存特征码 ;指向码表 ;顺序码初始化
B,A
;反转读键
KEYIN1:
DPTR,#KEYCOD R3,#0FFH R3 A,R3 A,@A+DPTR A,B,KEYIN3 A,R3
KEYIN2:
;找到,取顺序码
KEYIN3: KEYCOD:
DB 0E7H,0EBH,0EDH,0EEH DB 0D7H,0DBH,0DDH,0DEH DB 0B7H,0BBH,0BDH,0BEH DB 77H,7BH,7DH,7EH
7. 答:一、编程扫描方式:当单片机空闲时,才调用键盘扫描子程序,反复的扫描键盘,等待用户从键盘上输入命令或数据,来响应键盘的输入请求。二、定时扫描工作方式:单片机对键盘的扫描也可用定时扫描方式,即每隔一定的时间对键盘扫描一次。三、中断工作方式:只有在键盘有键按下时,才执行键盘扫描程序并执行该按键功能程序,如果无键按下,单片机将不理睬键盘。
8. 答:本电路图采用的是动态显示。参考程序如下
DIR:
MOV MOV MOV MOV
R0,#79H R3,#01H A,R3
DPTR,#7F01H ;位选码
;从79H开始里面存放着 ;1,2,3,4,5,6
LD0: