您的位置 首页 汽车

51单片机读端口与读引脚完全研讨(个人浅见)

要弄清读端口、读引脚问题,思考以下问题:(1)引脚的结构图清楚吗?以上是P0口一位的结构。以上结构说明:读引脚之前一定要对端口先置1,

要澄清读端口读引脚问题,考虑以下问题:

(1)引脚的结构图清楚吗?

以上是P0口一位的结构。以上结构阐明:读引脚之前必定要对端口先置1,使mosfet V2截止,避免信号被拉低而读错,这一点很简单了解。

(2)什么指令读端口?什么指令读引脚?

一般的教科书上都会着重:读端口的指令为端口内容取反这样的“读-修正-写”指令。而读引脚之前,先置1,然后用Mov A,Px之类的指令即可。以下是从web(http://www.dzsc.com/dzbbs/20061112/200765184756359377.html)上收集的材料:

“材料称: 这样的指令才有 Read-Modify-Write 成效

ANL (logical AND, e.G., ANL P1,A)
ORL (logical OR, e.g., ORL P2,A)
XRL (logical EX-OR, e.g., XRL P3,A)
JBC (jump if bit = 1 and clear bit, e.g., JBC P1.1, LABEL)
CPL (complement bit, e.g., CPL P3.0)
INC (increment, e.g., INC P2)
DEC (decrement, e.g., DEC P2)
DJNZ (decrement and jump if not zero, e.g., DJNZ P3, LABEL)
MOV PX.Y,C(move carry bit to bit Y ofPORTX)
CLR PX.Y(clear bit Y ofPORTX)
SETB PX.Y(set bit Y ofPORTX)

(3)有没有读端口的指令(而不修正端口)?

能够说,没有直接的读端口的指令。不论之前是否置1,以下指令

MOV A, P1
MOV 20H, P1
MOV R0, P1
MOV @R0, P1

读的都是引脚,虽然不必定读精确。

要想知道端口内容,能够选用的办法是(以下代码来源于网络):

51端口锁存器是能读取!!仿真机才会用到
READ_PORT_P1_REG2ACC:
CLR A ; MOV A, #0FFH
CPL A

JB P1.0, L_11 ; $+11 ; pin 为“1”时,锁存器肯定为“1”
JBC P1.0, L_06; $+ 6 ; 用JBCTEST锁存器, 为“1”时,跳
JBC ACC.0, L_05; $ + 5 ; == clr acc.0/ sjmp L_05
;用2周期/3bytes, 替代 3周期/4bytes
L_06:SETB P1.0; 康复 锁存器 为“1”
L_05:
L_11:

JB P1.1, $+11
JBC P1.1, $+ 6
JBC ACC.1, $ + 5
SETB P1.1

JB P1.2, $+11
JBC P1.2, $+ 6
JBC ACC.2, $ + 5
SETB P1.2

JB P1.3, $+11
JBC P1.3, $+ 6
JBC ACC.3, $ + 5
SETB P1.3

JB P1.4, $+11
JBC P1.4, $+ 6
JBC ACC.4, $ + 5
SETB P1.4

JB P1.5, $+11
JBC P1.5, $+ 6
JBC ACC.5, $ + 5
SETB P1.5

JB P1.6, $+11
JBC P1.6, $+ 6
JBC ACC.6, $ + 5
SETB P1.6

JB P1.7, $+11
JBC P1.7, $+ 6
JBC ACC.7, $ + 5
SETB P1.7

RET

咱们只需留意到上面办法中奇妙运用的JB指令:

“JB P1.0, L_11 ; $+11 ; pin 为“1”时,锁存器肯定为“1””

(4)端口的内容什么时候产生改动?当Px口作为输入,若外部引脚信号不断改动,读取引脚值之后,

端口内容是否改动?

某网友的观点与我不约而同:“因为复位后各引脚存放器的值是清晰的,而今后各引脚的存放器的值的改动不会因为芯片外面而,影响到引脚存放嚣的值,引脚的存放器的值只或许由程序来改动,所以就没有必要只读存放器的值而不改动存放器的内容了。”

参阅引脚内部结构图可知,端口便是一个锁存器,纵使锁存器D口数据在变(内部数据线),只需时钟触发端clk没有触发信号,锁存器中的内容永久都不会改动,也便是说,不论外部引脚信号怎么变,也不论履行过多少次读引脚操作,端口锁存器中的内容是不会产生改动的。

那么,端口内容何时改动?答曰:只需履行过一次输出,端口内容必为输出值,因为端口便是输出的数据锁存器。

(5)端口上的内容亦即反映到引脚上来吗?

Px口假如作为输出口,由引脚内部结构可知,端口内容是直接反映到引脚上去的。这关于P1口更为直接。而其他口,因为有第二功用,是否作为I/O口受内部操控信号的操控(留意mux)。

(6)什么时候是I/O口,什么时候是地址/数据口?

并非取决于硬件,而取决于当时的状况。例如:履行任一条指令时,这时候,在时序的不同阶段,P1口输出地址或读取指令码,这时候mux必定是倒向上面的(也许还受控于地址规模?)。总归,体系自己会决议。但只需履行了向P1口输出的指令,锁存器中的内容必定会及时地传递到引脚上去的。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qiche/257876.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部