控制/MCU
89C51单片机的P0~P3口不是标准意义的双向口 ,他只是准双向口,你可以对照着P0口的结构图看这段话,向端口写1,就是向锁存器写1,也就是让其口输出FF,为什么,是这样的,给锁存器写1,那么锁存器的反向端就输出0,那么和它相接的MOS管也就在截止状态,也就是呈高阻态,这样P0口上数据就会从读引脚的三态缓冲器上正确的输入,如果不写1,那么锁存器上次锁存的可能为0,那么反向端有可能出现1,这样和反向端相接的MOS管就倒通,也就是直接拉到地,那么不管你P0口上输入什么信号都会拉成低电平,输入就错了双向口与准双向口的区别主要是:准双向口I/O口操作时做数据输入时需要对其置1,否则若前一位为低电平,后一位输入的电平为高则MOS管拉不起来导致出错。而双向口则不需要做此动作,因为双向口有悬浮态。准双向口只能有效的读取0,而对1则是采用读取非零的方式,就是读入的时候要先向接口上写1,然后再读。真正的双向口正如其名,就是真正的双向io不需要任何预操作可直接读入读出
对照MCS-51的各通道结构:
I/O口有三种操作方式:输出数据方式,读端口数据方式,读端口引脚方式
输出数据方式:
只要一条数据操作指令就可以把输出数据写入P0~3的端口锁存器,然后通过输出驱动器送到端口引脚。
eg. MOV P0, A
MOV P0, #data
读端口数据方式:
是一种仅对锁存器中数据进行读入的操作方式,读入的这个数据并非端口引脚输入的数据。CPU只要一条传送指令就可以把端口锁存器中的数绝读入累加器A或内部RAM中。
eg. MOV A, P1
MOV R1, P1
读端口引脚方式:
从端口引脚线上读入信息。CPU首先必须将欲读端口引脚所对应的锁存器置位,以便驱动T2管(其他端口的T管)截止;然后打开输入三态缓冲器,使相应端口引脚上的信号输入MCS-51内部数据总线。所以,要用两条指令来完成读端口引脚。
eg. MOV P1, #0FH
MOV A, P1 ; 先使P1口低四位置位,然后读P1端口第四位引脚线信号送往A。
来源;21ic
全部0条评论
快来发表一下你的评论吧 !