8086cpu 可编程接口技术(一)

本文深入探讨8255A并行接口芯片,详细介绍了其结构,包括输入/输出端口、读/写控制逻辑、A组/B组控制电路和数据总线缓冲器。重点讲解了8255A的40脚DIP配置和工作方式,如方式0、方式1和方式2,并通过实例展示了如何设置和控制端口。此外,还涵盖了8255A的控制字和工作模式选择,以及在实际应用中的配置和操作方法。
摘要由CSDN通过智能技术生成

一,并行接口(重难点)

  • 并行接口是指CPU与外设之间的信息传输是多位同时进行的。
  • 锁存器、缓冲器、收发器都是一种并行接口,但它们都不是可编程的。
  • 8255 是lntel 公司为80x86系列CPU生产的8位通用可编程并行输入/输出接口芯片,可作为任何一个与TTL兼容的并行数字设备与微机间的接口。
  • 40脚DIP,单一+5V电源,TTL电平。

1,8255A 的结构和功能(重点)

image-20211130143931568

image-20211130144246736

1,输入/输出端口
  • A口、B口通常作为独立的I/O端口使用,C口也可以作为一般的I/O端口使用。
  • 当A口、B口作为应答式的l/O口使用时,C口分别用来为A口、B口提供应答控制线。
2,读/写控制逻辑

image-20211130144855631

非CS:片选信号,低电平有效

非RD:读信号,低电平有效
非WR:写信号,低电平有效
RESET:复位信号,高电平有效。清除所有控制寄存器内容,并将各端口都置成输入方式

A1、A0:8255A 片内端口寻址线。

image-20211130145152816

一道例题辅助理解:

假设8255A端口B已设置为输出端口,口地址为1231H,端口C已设置为输入端口,口地址为1232H,写出指令序列满足以下要求:
当开关合上,上面4个灯亮,下面4个灯灭,当开关打开,上面6个灯灭,下面2个灯亮。

image-20211130152839652

分析:检测开关的状态只要读取PC 口判断PC1即可

程序代码如下:

	MOV DX,1232H
A1:	IN AL,DX	;读取PC口检测开关状态
	TEST AL,00000010B	;测试PC1是0还是1
	JNZ	A2	;ZF=0,说明PC1=1
	MOV AL,00001111B	;PC1=0,开关合上
	MOV DX,1231H
	OUT DX,AL	;PB口输出数据
	JMP	A1
A2: MOV AL,11000000B	;PC1=1,开关打开
	MOV DX,1231H
	OUT	DX,AL	;PB口输出数据
	JMP	A1
3,A组/B组控制电路
  • 接受来自CPU的读/写控制信号和CPU送入的控制字,然后分别决定各端口的功能。
  • 还可以对C口的某位实现“置0”或“置1"的操作。
4,数据总线缓冲器

双向三态的8位缓冲器,可与数据总线(D0~D7)直接相连。

2,8255A 的工作方式与应用(难点)

8255A 有三种工作方式:

方式0、方式1、方式2

每个端口允许的工作方式:

  • 端口A:方式0、方式1、方式2
  • 端口B:方式0、方式1
  • 端口C:方式0
1,8255A的控制字

什么叫控制字? 8255A有三种工作方式,每个端口以哪种方式来工作,作为输入接口还是输出接口,取决于CPU对8255发出的命令。CPU对8255发出命令是通过对8255的控制口写控制字实现的。

image-20211130154405104

A组/B组控制电路有两种功能:

  • 设置各端口的工作方式。
  • 对C口的某位实现“置0”或“置1”的操作。

因此,8255A的控制字有两种:

  • 工作方式控制字
  • C口置位/复位控制字

8255A只有一个控制口,当接收到CPU发来的命令时,它是如何区分该控制字的种类呢?它是通过控制字的最高位识别的,当最高位=1,工作方式控制字;最高位=0,C 口置位/复位控制字

  • 1,工作方式控制字(D7=1)(需要记住此结构)

    image-20211130154947771

    小例题:设某8255A的控制寄存器口地址为B6H,各端口工作方式如下:A口方式0、输入端口;B口方式0、输出端口;C口高4位为输出口,低4位为输入口。试编写该8255A接口的初始化程序。

    //根据上面的格式,写出工作方式控制字为 10010001B=91H
    初始化程序如下:
    MOV AL,91H	;CPU控制字91H经AL输出
    OUT 0B6H,AL	;送到8255A 控制寄存器中
    
  • 2,C 口置位/复位控制字(D7=0)

    可以设置C 口某位输出高电平还是低电平

    image-20211130160006038

    小例题:设某8255A的控制寄存器口地址为303H,编写程序,将C口的PC7位置0,PC6位置1。

    MOV DX,303H
    MOV AL,00001110B	;置PC7=0的控制字
    OUT DX,AL	;控制字送8255A控制寄存器中
    MOV AL,0001101	;置PC6=1的控制字
    OUT DX,AL	;控制字送8255A控制寄存器中
    
2,8255A的工作方式
  • (1)工作方式0(基本输入/输出)

    • A口(8位)、B口(8位)、上C口(4位)、下C口(4位)可分别独立定义为输入或输出
    • 输出可锁存,输入有缓冲无锁存
    • C口还有按位置位/复位的能力
    • 不能采用中断方式,但可采用查询方式(C口线可作联络信号)

    小例题image-20211130163134851

    image-20211130165303077

    分析:

    • 1,端口A作为输出端口,工作于方式0,查询式输出。
    • 2,端口C作为状态端口。
    • PC7用于8255A选通打印机,低电平有效。
    • PC2用于打印机送给8255A的状态信号,高电平表示忙,低电平表示空闲。

    设8255A端口地址为0380H~0383H,待打印字符的存放首地址为DS: 0300H,字符数为100个。

    ;8255A初始化程序
    BEGIN:	MOV DX,0383
    		MOV AL,10000001	;A口方式0输出,PC7~PC4输出,PC3~PC0输入
    		OUT DX,AL
    		MOV AL,00001111B	;送C口置位控制字,置PC7=1,STB=1,初始状态为高电平
    		OUT DX,AL
    		
    ;打印机驱动程序
    		MOV SI,0300H	;待打印字符存放内存的首地址
    		MOV CX,100	;打印字符个数
    CONP:	MOV DX,0382H
    LPST:	IN AL,DX
    		TEST AL,00000100B	;检测PC2(BUSY)
    		JNZ	LPST	;若BUSY=1,等待;反之,则向下执行
    		MOV AL,[SI]	;从内存中取等打印的数据
    		MOV DX,0380H	;待打印数据输出至8255A口
    		OUT DX,AL
    		MOV AL,00001110B
    		MOV DX,0383H
    		OUT DX,AL	;置PC7=0,产生选通信号
    		NOP	;使STB信号低电平有一定宽度
    		NOP	;保证传送至打印机数据稳定
    		NOP
    		MOV AL,000011111B	;置PC7=1,即STB=1高电平,利用STB上升沿将数据打入到打印机数据缓冲区中
    		OUT DX,AL
    		INC SI	;修改指针,指向下一次欲打印的数据
    		LOOP CONP	;未打完,继续
    		HLT	;所有数据打印完毕,暂停
    
  • (2)工作方式1 (选通输入/输出)

    • A口(8位)、B口(8位)适用,C口不能工作于方式1
    • A口/B口可分别定义为输入或输出
    • 支持查询、中断方式传送数据
    • C口部分位作为控制信号和状态信号
    • C口其余位可独立置位/复位

    输出

    image-20211130165643281

    image-20211130165800657

    image-20211130165859593

    输入

    image-20211130165952223

    image-20211130170024860

    image-20211130170053155

    image-20211130170113901

    端口A 与端口B 的比较

    image-20211130170230420

  • (3) 工作方式2 (双向输入输出)

    image-20211130170312652

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阔升

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值