- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《8255方式1-例子》
《8255方式1-例子》
例2:一个16位数据的并行输出接口(查询方式)
例3:两机并行通信接口(查询方式)
例4:两机并行通信接口(查询中断方式)
《例 2》:一个16位数据的并行输出接口(查询方式)
某16位微机处理系统中,利用两片8255A的A端口作为一个16位的并行接口,将内存缓冲区BUF的256个字送到一个16位的输出设备中。8255A送一个低电平给输出设备,通知它取数据,当输出设备获得数据后,将回送一个负脉冲作为应答信号。要求:⑴设计8255A与系统总线的硬件连接(设端口地址为0H~7H);⑵写出利用查询方式完成数据传送的程序段。
⑴16位系统对存储器的管理是通过将其分成奇/偶存储器体两部分,分别连接到数据总线的高/低8位上,然后用A0和 分别控制奇/偶存储器的片选信号。对16位外设的管理也可以通过类似的方法进行:一片8255A分配偶地址为00H、02H、04H、06H,其数据线连数据总线的低8位,用A0控制;另一片8255A分配奇地址为01H、03H、05H、07H,其数据线连数据总线的高8位,用控制。
⑵设偶地址的A端口按方式1工作,奇地址的A端口按方式0工作
,当A端口数据满时,PC7()输出低电平,而PC6用于获得响应信号()。
程序清单如下:
MOV AL ;偶地址8255A初始化、A口方式1、输出
OUT 6H,AL
MOV AL ;奇地址8255A初始化、A口方式0、输出
OUT 7H,AL
MOV CX,256
MOV BX,0
L: MOV AX,BUF[BX]
OUT 0H,AX ;传输一个字从端口经00H、01H输出
ADD BX,2
L0:IN AL,4H
TEST AL ;检测PC7()是否已被恢复为高电平JZ L0
LOOP L
《例 3》:两机并行通信接口(程序查询方式)
用8255A为两台8086单板机设计一个并行数据传送接口。要求:
⑴甲机8255A方式1发送数据,乙机8255A方式1接收数据;
⑵甲、乙两机的CPU与8255A之间均采用查询方式交换数据;
⑶发送和接收数据均存放在内存的数据段,长度为2KB。
如图所示,甲机端口A与乙机端口A相连,甲机的PC7、PC6与乙机的PC4、PC5分别相连。当甲机的CPU送一数据到端口A时,该端口的输出缓冲器满信号变低,给乙机的端口A送一个选通信号,使变低并将数据锁存。当乙机的CPU从端口A取回数据后,输入缓冲器变低,给甲机一个回答信号,使甲机端口A的响应信号变低,从而又使甲机的变高,这样,甲机又可以将下一个数据送到端口A。如此重复,完成2KB个数据的传送。
程序清单:
;甲机发送程序
MOV AX,0100H ;发送数据存放的段地址
MOV DS,AX
MOV BX,0000H ;发送数据段内位移量
MOV CX,07FFH ;发送数据段长度-1
MOV DX,0FFFEH ;8255A控制口地址
MOV AL ;8255A方式1、输出
OUT DX,AL
MOV AL ;置PC7=1(=1)
OUT DX,AL
MOV DX,0FFF8H ;8255A端口A的地址
MOV AL,DS:[BX]
OUT DX,AL ;从内存取出一数据向乙机发送
INC BX ;修改内存单元地址
WAT1:MOV DX,0FFFCH ;8255A状态口地址(C端口)
IN AL,DX
AND AL,80H ;=0?
JZ WAT1 ;外设未取走前一个数据,等待
MOV DX,0FFF8H ;8255A端口A的地址
MOV AL,DS:[BX]
OUT DX,AL ;从内存取出一数据向乙机发送
INC BX ;修改内存单元地址
LOOP WAT1 ;块长度-1≠0继续
HLT ;传送完毕暂停
;乙机接收程序
MOV AX,2000H ;接收数据存放的段地址
MOV DS,AX
MOV BX,0000H ;接收数据段内位移量
MOV CX,0800H ;接收数据段长度
MOV DX,0FFFEH ;8255A控制口地址
MOV AL ;8255A方式1、输入
OUT DX,AL
MOV AL ;PC5=0(=0)
OUT DX,AL
WAT2:MOV DX,0FFFCH ;8255A状态口地址(C端口)
IN AL,DX
AND AL,20H ;=0?
JZ WAT
文档评论(0)