51單片機IO口工作原理——P0、P1
讀-修改-寫指令的特點是,從端口輸入(讀)信號,在單片機內加以運算(修改)后,再輸出(寫)到該端口上。下面是幾條讀--修改-寫指令的例子。

2、作為地址/數據復用口使用時的工作原理
例如:控制信號為1,地址信號為“0”時,與門輸出低電平,V1管截止;反相器輸出高電平,V2管導通,輸出引腳的地址信號為低電平。請看下圖(蘭色字體為電平):

反之,控制信號為“1”、地址信號為“1”,“與門”輸出為高電平,V1管導通;反相器輸出低電平,V2管截止,輸出引腳的地址信號為高電平。請看下圖(蘭色字體為電平):

可見,在輸出“地址/數據”信息時,V1、V2管是交替導通的,負載能力很強,可以直接與外設存儲器相連,無須增加總線驅動器.

如果該指令是輸出數據,如MOVX @DPTR,A(將累加器的內容通過P0口數據總線傳送到外部RAM中),則多路開關“控制”信號為‘1’,“與門”解鎖,與輸出地址信號的工作流程類似,數據據由“地址/數據”線→反相器→V2場效應管柵極→V2漏極輸出。
通過以上的分析可以看出,當P0作為地址/數據總線使用時,在讀指令碼或輸入數據前,CPU自動向P0口鎖存器寫入0FFH,破壞了P0口原來的狀態。因此,不能再作為通用的I/O端口。大家以后在系統設計時務必注意,即程序中不能再含有以P0口作為操作數(包含源操作數和目的操作數)的指令。
二、P1端口的結構及工作原理

由圖可見,P1端口與P0端口的主要差別在于,P1端口用內部上拉電阻R代替了P0端口的場效應管T1,并且輸出的信息僅來自內部總線。由內部總線輸出的數據經鎖存器反相和場效應管反相后,鎖存在端口線上,所以,P1端口是具有輸出鎖存的靜態口。
評論