- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
某应用系统以8255A作为接口,采集一组开关S7~S0 的状态,然后通过一组发光二极管LED7~LED0显示开关状态,(Si闭合,则对应LEDi亮,Si断开,则对应的LEDi灭)电路连接如下图3所示,
1).写出8255四个端口的地址。
2).写出8255工作方式控制字。
3).写出实现给定功能的汇编语言程序。
1)A口、B口、C口和控制口的地址分别是330H、331H、332H和333H。
2)A口工作在方式0输入,B口工作在方式0输出,C口空闲,所以其控制字=90H
3)程序如下:
MOV AL, 90H ;置方式字
MOV DX, 333H ;置控制端口地址
OUT DX, AL
L1: MOV DX, 331H ;置B口地址
IN AL, DX ;读开关状态(1断,0通)
NOT AL ;状态取反
MOV DX, 330H ;置A口地址
OUT DX, AL ;输出(1亮,0灭)
JMP L1
四、以下为8088系统中以8255A 为输入设备和输出设备的查询方式接口电路的部分硬件图。(18分)
1、试述8088CPU和输入设备进行数据传送的工作过程。(6分)
输入设备要将数据传送给CPU时,先将数据输出给8255A的PA0-PA7, 然后通过ACK端输出脉冲信号将数据锁存于锁存器,同时将触发器置1。 而CPU要不断查询设备的状态,执行读8255A C口操作,判断从C口读入数据的D1位是1还是0,若为0表示设备未准备好,则等待后再查询;若为1表示设备已将数据送出, CPU 从 8255A的 A口读入数据,然后通过PC 6输出负脉冲将状态触发器清0。之后重复以上的操作,周而复始。
2、以下是8088CPU将存于以BLOCK为首址的内存单元区域中100个数据依次传送给输出设备的程序段,请在划线处填入内容。
BLOCK DB a1,a2,……a100
COUNT EQU $-BLOCK
START: LEA SI, BLOCK ;置数据单元首址指针
MOV CX , COUNT
MOV DX, 383H ;8255A初始化设置
MOV AL, 91H
OUT DX, AL
MOV DX, 383H ;置PC7为低电平
MOV AL, 0EH
OUT DX, AL
AGAIN: MOV DX, 382H ;查询输出设备状态
IN AL, DX
TEST AL, 04H
JNZ AGAIN
MOV AL, [SI] ;取数据传送给输出设备
INC SI
MOV DX, 381H
OUT DX, AL
MOV DX, 383H ;置PC7产生高电平
MOV AL, 0FH
OUT DX, AL
NOP
NOP
MOV AL, 0EH ;置PC7为低电平
OUT DX, AL
LOOP AGAIN
RET
8255A方式控制字 8255A C口复位/置位控制字
1 D6 D5 D4 D3 D2 D1 D0 0 0 0 0 D3 D2 D1 D0
A口方式
00 方式0 A口 C口下半口
01 方式1 0 输出 0 输出 000 PC0 0复位
1× 方式2 1 输入 1 输入 001 PC1 1 置位
B口 010 PC2
C口上半口 B口方式 0 输出 ∶ ∶
文档评论(0)