(1)引脚的结构图清楚吗?
以上是P0口一位的结构。以上结构说明:读引脚之前一定要对端口先置1,使mosfet V2截止,以免信号被拉低而读错,这一点很容易理解。
(2)什么指令读端口?什么指令读引脚?
一般的教科书上都会强调:读端口的指令为端口内容取反这样的“读-修改-写”指令。而读引脚之前,先置1,然后用Mov A,Px之类的指令即可。
“资料称: 这样的指令才有 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 of PORT X)
CLR PX.Y(clear bit Y of PORT X)
SETB PX.Y(set bit Y of PORT X)
”
(3)有没有读端口的指令(而不修改端口)?
可以说,没有直接的读端口的指令。无论之前是否置1,以下指令
MOV A, P1
MOV 20H, P1
MOV R0, P1
MOV @R0, P1
读的都是引脚,尽管不一定读准确。
要想知道端口内容,可以采用的方法是(以下代码来源于网络):
“
51端口锁存器是能读取!!仿真机才会用到
READ_PORT_P1_REG2ACC:
L_06:
L_05:
L_11:
”
我们只需注意到上面方法中巧妙运用的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口输出的指令,锁存器中的内容一定会及时地传递到引脚上去的。
上一篇:12864实际应用的驱动程序
下一篇:c52串口通讯RS232总结
推荐阅读最新更新时间:2024-03-16 14:36