一、P0 端口的结构及工作原理
P0 端口 8 位中的一位结构图见下图:
由上图可见,P0 端口由锁存器、输入缓冲器、切换开关、一个与非门、
一个与门及场效应管驱动 电路 构成。再看图的右边,标号为 P0.X 引脚的图标,
也就是说 P0.X 引脚可以是 P0.0 到 P0.7 的任何一位,即在 P0 口有 8 个与上图
相同的电路组成。
下面,我们先就组成 P0 口的每个单元部份跟大家介绍一下:
先看输入缓冲器:在 P0 口中,有两个三态的缓冲器,在学数字电路时,我们
已知道,三态门有三个状态,即在其的输出端可以是高电平、低电平,同时还
有一种就是高阻状态(或称为禁止状态),大家看上图,上面一个是读锁存器
的缓冲器,也就是说,要读取 D 锁存器输出端 Q 的数据,那就得使读锁存器的
这个缓冲器的三态控制端(上图中标号为‘读锁存器’端)有效。下面一个是读引
脚的缓冲器,要读取 P0.X 引脚上的数据,也要使标号为‘读引脚’的这个三态缓
冲器的控制端有效,引脚上的数据才会传输到我们单片机的内部数据总线上。
D 锁存器:构成一个锁存器,通常要用一个时序电路,时序的单元电路在
学数字电路时我们已知道,一个触发器可以保存一位的二进制数(即具有保持
功能),在 51 单片机的 32 根 I/O 口线中都是用一个 D 触发器来构成锁存器的。
大家看上图中的 D 锁存器,D 端是数据输入端,CP 是控制端(也就是时序控
制信号输入端),Q 是输出端,Q 非是反向输出端。
对于 D 触发器来讲,当 D 输入端有一个输入信号,如果这时控制端 CP 没有信
号(也就是时序脉冲没有到来),这时输入端 D 的数据是无法传输到输出端 Q
及反向输出端 Q 非的。如果时序控制端 CP 的时序脉冲一旦到了,这时 D 端输
入的数据就会传输到 Q 及 Q 非端。数据传送过来后,当 CP 时序控制端的时序
信号消失了,这时,输出端还会保持着上次输入端 D 的数据(即把上次的数据
锁存起来了)。如果下一个时序控制脉冲信号来了,这时 D 端的数据才再次传
送到 Q 端,从而改变 Q 端的状态。
多路开关:在 51 单片机中,当内部的存储器够用(也就是不需要外扩展存
评论3