51單片機I/O引腳IO口工作原理
一、51單片機管腳p0、p1、p2、p3口區別如下:
1、意思不同
P0口作輸出口用時,需加上拉電阻。P0口有復用功能。當對外部存儲器進行讀寫操作時,P0口先是提供外部存儲器的低8位地址,供外部存儲器地址鎖存器鎖存,
然后充當數據線,用於寫出或讀入數據。P1口、P2口只是普通IO口。
2、功能不同
P0口第一個功能是數據接口,第二個功能是地址低八位,P2口第二個功能是地址高八位。另外除了
P0口沒有內部上拉電阻外,其他三個都有內部上拉電阻。
3、用法
信號輸出和交互接口,編程可以確定不同的功能,例如連接液晶屏,作為控制信號輸出輸入等。
由於沒有端口復用功能,所以,P0口的V1變成了一個上拉電阻。由於內部就有上拉電阻,所以,作為GPIO時,P1口不需要接上拉電阻,當然,您接了也沒關系啦,就相當於兩個上拉電阻並聯。
二、 基本功能:
一、P1就沒多少功能,就是個准雙向I/O口。 二、P0當准IO口使用,也就是既可以用作輸出口,也可以用作輸入口。 三、P3口除了是個准雙向I/O口外。
第二功能很重要 P3.0 (RXD)串行數據接收端,P3.1 (TXD)串行數據發送端,P3.2 (INT0)外部中斷0輸入,
P3.3 (INT1)外部中斷1輸入;P3.4(T0)Timer0計數器輸入,P3.5(T1)Timer1計數器輸入,P3.6(WR)寫外部存儲器的脈沖輸出,P3.7(RD)讀外部存儲器的脈沖輸出。 擴展資料 1、P0口:真正的雙向口,輸出鎖存,輸入緩沖,輸入前要先置1(KEIL包含的頭文件已經有動作 了,如果用匯編,要人工置1),輸出為漏極開路,輸出一般都要上拉電阻。輸入為高阻態,能驅動 8個TTL負載。當有片外存儲器時,作數據線使用。 2、P1口:最簡單的口,輸入也要先置1,無高阻態,只能是輸出或者輸入。能驅動4個TTL負載。 3、P2口:I/O(輸入/輸出)與P1口一樣,當有片外存儲器時,作地址線使用,尋址64K片外數據存 儲器。能驅動4個TTL負載。 4、P3口:I/O(輸入/輸出)與P1口一樣,但無論輸入輸出都要先置1。具有很多復用功能。
三、P0端口的結構及工作原理
P0端口8位中的一位結構圖見下圖:


由上圖可見
P0端口由鎖存器、輸入緩沖器、切換開關、一個與非門、一個與門及場效應管驅動電路構成。
再看圖的右邊,標號為P0.X引腳的圖標,也就是說P0.X引腳可以是P0.0到P0.7的任何一位,
即在P0口有8個與上圖相同的電路組成。
下面,我們先就組成P0口的每個單元部份跟大家介紹一下:
1.先看輸入緩沖器:
在P0口中,有兩個三態的緩沖器,在學數字電路時,我們已知道,三態門有三個狀態,即在其的輸出端可以是高電平、低電平,同時還有一種就是高阻狀態(或稱為禁止狀態),
大家看上圖,上面一個是讀鎖存器的緩沖器,也就是說,要讀取D鎖存器輸出端Q的數據,那就得使讀鎖存器的這個緩沖器的三態控制端(上圖中標號為‘讀鎖存器’端)有效。
下面一個是讀引腳的緩沖器,要讀取P0.X引腳上的數據,也要使標號為‘讀引腳’的這個三態緩沖器的控制端有效,引腳上的數據才會傳輸到我們單片機的內部數據總線上。
2.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端的狀態。
3.多路開關:
在51單片機中,當內部的存儲器夠用(也就是不需要外擴展存儲器時,這里講的存儲器包括數據存儲器及程序存儲器)時,P0口可以作為通用的輸入輸出端口(即I/O)使用,
對於8031(內部沒有ROM)的單片機或者編寫的程序超過了單片機內部的存儲器容量,需要外擴存儲器時,P0口就作為‘地址/數據’總線使用。
那么這個多路選擇開關就是用於選擇是做為普通I/O口使用還是作為‘數據/地址’總線使用的選擇開關了。大家看上圖,當多路開關與下面接通時,
P0口是作為普通的I/O口使用的,當多路開關是與上面接通時,P0口是作為‘地址/數據’總線使用的。
4.輸出驅動部分:
從上圖中我們已看出,P0口的輸出是由兩個MOS管組成的推拉式結構,也就是說,這兩個MOS管一次只能導通一個,當V1導通時,V2就截止,當V2導通時,V1截止。
與門、與非門:
這兩個單元電路的邏輯原理我們在第四課數字及常用邏輯電路時已做過介紹,不明白的同學請回到第四節去看看。
前面我們已將P0口的各單元部件進行了一個詳細的講解,下面我們就來研究一下P0口做為I/O口及地址/數據總線使用時的具體工作過程。
1、作為I/O端口使用時的工作原理
P0口作為I/O端口使用時,多路開關的控制信號為0(低電平),看上圖中的線線部份,多路開關的控制信號同時與與門的一個輸入端是相接的,我們知道與門的邏輯特點是“全1出1,有0出0”那么控制信號是0的話,這時與門輸出的也是一個0(低電平),與讓的輸出是0,V1管就截止,在多路控制開關的控制信號是0(低電平)時,多路開關是與鎖存器的Q非端相接的(即P0口作為I/O口線使用)。
P0口用作I/O口線,其由數據總線向引腳輸出(即輸出狀態Output)的工作過程:當寫鎖存器信號CP 有效,數據總線的信號→鎖存器的輸入端D→鎖存器的反向輸出Q非端→多路開關→V2管的柵極→V2的漏極到輸出端P0.X。前面我們已講了,當多路開關的控制信號為低電平0時,與門輸出為低電平,V1管是截止的,所以作為輸出口時,P0是漏極開路輸出,類似於OC門,當驅動上接電流負載時,需要外接上拉電阻。
下圖就是由內部數據總線向P0口輸出數據的流程圖(紅色箭頭)。
ANL P0,#立即數 ;P0→立即數P0
ORL P0,A ;P0→AP0
INC P1 ;P1+1→P1
DEC P3 ;P3-1→P3
CPL P2 ;P2→P2
這樣安排的原因在於讀-修改-寫指令需要得到端口原輸出的狀態,修改后再輸出,讀鎖存器而不是讀引腳,可以避免因外部電路的原因而使原端口的狀態被讀錯。
P0端口是8031單片機的總線口,分時出現數據D7一D0、低8位地址A7一AO,以及三態,用來接口存儲器、外部電路與外部設備。P0端口是使用最廣泛的I/O端口。
2、作為地址/數據復用口使用時的工作原理
在訪問外部存儲器時P0口作為地址/數據復用口使用。
這時多路開關‘控制’信號為‘1’,‘與門’解鎖,‘與門’輸出信號電平由“地址/數據”線信號決定;多路開關與反相器的輸出端相連,地址信號經“地址/數據”線→反相器→V2場效應管柵極→V2漏極輸出。
例如:控制信號為1,地址信號為“0”時,與門輸出低電平,V1管截止;反相器輸出高電平,V2管導通,輸出引腳的地址信號為低電平。請看下圖(蘭色字體為電平):
點擊看大圖
反之,控制信號為“1”、地址信號為“1”,“與門”輸出為高電平,V1管導通;反相器輸出低電平,V2管截止,輸出引腳的地址信號為高電平。請看下圖(蘭色字體為電平):
點擊看大圖
可見,在輸出“地址/數據”信息時,V1、V2管是交替導通的,負載能力很強,可以直接與外設存儲器相連,無須增加總線驅動器。
P0口又作為數據總線使用。在訪問外部程序存儲器時,P0口輸出低8位地址信息后,將變為數據總線,以便讀指令碼(輸入)。
在取指令期間,“控制”信號為“0”,V1管截止,多路開關也跟着轉向鎖存器反相輸出端Q非;CPU自動將0FFH(11111111,即向D鎖存器寫入一個高電平‘1’)寫入P0口鎖存器,使V2管截止,在讀引腳信號控制下,通過讀引腳三態門電路將指令碼讀到內部總線。請看下圖
點擊看大圖
如果該指令是輸出數據,如MOVX @DPTR,A(將累加器的內容通過P0口數據總線傳送到外部RAM中),則多路開關“控制”信號為‘1’,“與門”解鎖,與輸出地址信號的工作流程類似,數據據由“地址/數據”線→反相器→V2場效應管柵極→V2漏極輸出。
如果該指令是輸入數據(讀外部數據存儲器或程序存儲器),如MOVX A,@DPTR(將外部RAM某一存儲單元內容通過P0口數據總線輸入到累加器A中),則輸入的數據仍通過讀引腳三態緩沖器到內部總線,其過程類似於上圖中的讀取指令碼流程圖。
通過以上的分析可以看出,當P0作為地址/數據總線使用時,在讀指令碼或輸入數據前,CPU自動向P0口鎖存器寫入0FFH,破壞了P0口原來的狀態。因此,不能再作為通用的I/O端口。大家以后在系統設計時務必注意,即程序中不能再含有以P0口作為操作數(包含源操作數和目的操作數)的指令。
二、P1端口的結構及工作原理
P1口的結構最簡單,用途也單一,僅作為數據輸入/輸出端口使用。輸出的信息有鎖存,輸入有讀引腳和讀鎖存器之分。P1端口的一位結構見下圖.
點擊看大圖
由圖可見,P1端口與P0端口的主要差別在於,P1端口用內部上拉電阻R代替了P0端口的場效應管T1,並且輸出的信息僅來自內部總線。由內部總線輸出的數據經鎖存器反相和場效應管反相后,鎖存在端口線上,所以,P1端口是具有輸出鎖存的靜態口。
由上圖可見,要正確地從引腳上讀入外部信息,必須先使場效應管關斷,以便由外部輸入的信息確定引腳的狀態。為此,在作引腳讀入前,必須先對該端口寫入l。具有這種操作特點的輸入/輸出端口,稱為准雙向I/O口。8051單片機的P1、P2、P3都是准雙向口。P0端口由於輸出有三態功能,輸入前,端口線已處於高阻態,無需先寫入l后再作讀操作。
P1口的結構相對簡單,前面我們已詳細的分析了P0口,只要大家認真的分析了P0口的工作原理,P1口我想大家都有能力去分析,這里我就不多論述了。
單片機復位后,各個端口已自動地被寫入了1,此時,可直接作輸入操作。如果在應用端口的過程中,已向P1一P3端口線輸出過0,則再要輸入時,必須先寫1后再讀引腳,才能得到正確的信息。此外,隨輸入指令的不同,H端口也有讀鎖存器與讀引腳之分。
三、P2端口的結構及工作原理:
P2端口的一位結構見下圖:
由圖可見,P2端口在片內既有上拉電阻,又有切換開關MUX,所以P2端口在功能上兼有P0端口和P1端口的特點。這主要表現在輸出功能上,當切換開關向下接通時,從內部總線輸出的一位數據經反相器和場效應管反相后,輸出在端口引腳線上;當多路開關向上時,輸出的一位地址信號也經反相器和場效應管反相后,輸出在端口引腳線上。
對於8031單片機必須外接程序存儲器才能構成應用電路(或者我們的應用電路擴展了外部存儲器),而P2端口就是用來周期性地輸出從外存中取指令的地址(高8位地址),因此,P2端口的多路開關總是在進行切換,分時地輸出從內部總線來的數據和從地址信號線上來的地址。因此P2端口是動態的I/O端口。輸出數據雖被鎖存,但不是穩定地出現在端口線上。其實,這里輸出的數據往往也是一種地址,只不過是外部RAM的高8位地址。
在輸入功能方面,P2端口與P0和H端口相同,有讀引腳和讀鎖存器之分,並且P2端口也是准雙向口。
可見,P2端口的主要特點包括:
①不能輸出靜態的數據;
②自身輸出外部程序存儲器的高8位地址;
②執行MOVX指令時,還輸出外部RAM的高位地址,故稱P2端口為動態地址端口。
即然P2口可以作為I/O口使用,也可以作為地址總線使用,下面我們就不分析下它的兩種工作狀態。
1、作為I/O端口使用時的工作過程
當沒有外部程序存儲器或雖然有外部數據存儲器,但容易不大於256B,即不需要高8位地址時(在這種情況下,不能通過數據地址寄存器DPTR讀寫外部數據存儲器),P2口可以I/O口使用。這時,“控制”信號為“0”,多路開關轉向鎖存器同相輸出端Q,輸出信號經內部總線→鎖存器同相輸出端Q→反相器→V2管柵極→V2管9漏極輸出。
由於V2漏極帶有上拉電阻,可以提供一定的上拉電流,負載能力約為8個TTL與非門;作為輸出口前,同樣需要向鎖存器寫入“1”,使反相器輸出低電平,V2管截止,即引腳懸空時為高電平,防止引腳被鉗位在低電平。讀引腳有效后,輸入信息經讀引腳三態門電路到內部數據總線。
2、作為地址總線使用時的工作過程
P2口作為地址總線時,“控制”信號為‘1’,多路開關車向地址線(即向上接通),地址信息經反相器→V2管柵極→漏極輸出。由於P2口輸出高8位地址,與P0口不同,無須分時使用,因此P2口上的地址信息(程序存儲器上的A15~A8)功數據地址寄存器高8位DPH保存時間長,無須鎖存。
四、P3端口的結構及工作原理
P3口是一個多功能口,它除了可以作為I/O口外,還具有第二功能,P3端口的一位結構見下圖。
點擊看大圖
由上圖可見,P3端口和Pl端口的結構相似,區別僅在於P3端口的各端口線有兩種功能選擇。當處於第一功能時,第二輸出功能線為1,此時,內部總線信號經鎖存器和場效應管輸入/輸出,其作用與P1端口作用相同,也是靜態准雙向I/O端口。當處於第二功能時,鎖存器輸出1,通過第二輸出功能線輸出特定的內含信號,在輸入方面,即可以通過緩沖器讀入引腳信號,還可以通過替代輸入功能讀入片內的特定第二功能信號。由於輸出信號鎖存並且有雙重功能,故P3端口為靜態雙功能端口。
P3口的特殊功能(即第二功能):
口線
第二功能
信號名稱
P3.0
RXD 串行數據接收
P3.1
TXD 串行數據發送
P3.2
INT0 外部中斷0申請
P3.3
INT1 外部中斷1申請
P3.4
T0 定時器/計數器0計數輸入
P3.5
T1 定時器/計數器1計數輸入
P3.6
WR 外部RAM寫選通
P3.7
RD 外部RAM讀選通
使P3端品各線處於第二功能的條件是:
1、串行I/O處於運行狀態(RXD,TXD);
2、打開了處部中斷(INT0,INT1);
3、定時器/計數器處於外部計數狀態(T0,T1)
4、執行讀寫外部RAM的指令(RD,WR)
在應用中,如不設定P3端口各位的第二功能(WR,RD信叼的產生不用設置),則P3端口線自動處於第一功能狀態,也就是靜態I/O端口的工作狀態。在更多的場合是根據應用的需要,把幾條端口線設置為第二功能,而另外幾條端口線處於第一功能運行狀態。在這種情況下,不宜對P3端口作字節操作,需采用位操作的形式。
端口的負載能力和輸入/輸出操作:
P0端口能驅動8個LSTTL負載。如需增加負載能力,可在P0總線上增加總線驅動器。P1,P2,P3端口各能驅動4個LSTTL負載。
前已述及,由於P0-P3端口已映射成特殊功能寄存器中的P0一P3端口寄存器,所以對這些端口寄存器的讀/寫就實現了信息從相應端口的輸入/輸出。例如:
MOV A, P1 ;把Pl端口線上的信息輸入到A
MoV P1, A ;把A的內容由P1端口輸出
MOV P3, #0FFH ;使P3端口線各位置l
