51單片機 P0口工作原理詳細講解
P0口又作為數據總線(xiàn)使用。在訪(fǎng)問(wèn)外部程序存儲器時(shí),P0口輸出低8位地址信息后,將變?yōu)?a class="contentlabel" href="http://dyxdggzs.com/news/listbylabel/label/數據總線(xiàn)">數據總線(xiàn),以便讀指令碼(輸入)。
在取指令期間,“控制”信號為“0”,V1管截止,多路開(kāi)關(guān)也跟著(zhù)轉向鎖存器反相輸出端Q非;CPU自動(dòng)將0FFH(11111111,即向D鎖存器寫(xiě)入一個(gè)高電平‘1’)寫(xiě)入P0口鎖存器,使V2管截止,在讀引腳信號控制下,通過(guò)讀引腳三態(tài)門(mén)電路將指令碼讀到內部總線(xiàn)。請看下圖

如果該指令是輸出數據,如MOVX @DPTR,A(將累加器的內容通過(guò)P0口數據總線(xiàn)傳送到外部RAM中),則多路開(kāi)關(guān)“控制”信號為‘1’,“與門(mén)”解鎖,與輸出地址信號的工作流程類(lèi)似,數據據由“地址/數據”線(xiàn)→反相器→V2場(chǎng)效應管柵極→V2漏極輸出。
如果該指令是輸入數據(讀外部數據存儲器或程序存儲器),如MOVX A,@DPTR(將外部RAM某一存儲單元內容通過(guò)P0口數據總線(xiàn)輸入到累加器A中),則輸入的數據仍通過(guò)讀引腳三態(tài)緩沖器到內部總線(xiàn),其過(guò)程類(lèi)似于上圖中的讀取指令碼流程圖。
通過(guò)以上的分析可以看出,當P0作為地址/數據總線(xiàn)使用時(shí),在讀指令碼或輸入數據前,CPU自動(dòng)向P0口鎖存器寫(xiě)入0FFH,破壞了P0口原來(lái)的狀態(tài)。因此,不能再作為通用的I/O端口。大家以后在系統設計時(shí)務(wù)必注意,即程序中不能再含有以P0口作為操作數(包含源操作數和目的操作數)的指令。
51單片機相關(guān)文章:51單片機教程
存儲器相關(guān)文章:存儲器原理
評論