<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > EDA/PCB > 學(xué)習方法與實(shí)踐 > 51單片機管腳說(shuō)明

51單片機管腳說(shuō)明

作者: 時(shí)間:2008-02-28 來(lái)源:嵌入式技術(shù)網(wǎng) 收藏

當我們拿到一塊單片機芯片時(shí),看到這么多的“大腿”,他們都有干什么用的?了解了51家族的淵源,現在我們就去了解一下它們的“腿”吧。大家可得學(xué)好了,這可是至關(guān)重要的喲。如果連手跟腿都分不清,要學(xué)好單片機那就有如憑空造屋了。

這一章節相當管用,希望大家能用心學(xué)好,如果這一章節學(xué)不好,以后學(xué)習會(huì )有很大的阻力。(我們的教材都是以51系列的單片機來(lái)進(jìn)行講解的)。

引腳功能:

MCS-51是標準的40引腳雙列直插式集成電路芯片,引腳分布請參照----單片機引腳圖:

l P0.0~P0.7 P0口8位雙向口線(xiàn)(在引腳的39~32號端子)。

l P1.0~P1.7 P1口8位雙向口線(xiàn)(在引腳的1~8號端子)。

l P2.0~P2.7 P2口8位雙向口線(xiàn)(在引腳的21~28號端子)。

l P3.0~P3.7 P2口8位雙向口線(xiàn)(在引腳的10~17號端子)。

這4個(gè)I/O口具有不完全相同的功能,大家可得學(xué)好了,其它書(shū)本里雖然有,但寫(xiě)的太深,對于初學(xué)者來(lái)說(shuō)很難理解的,我這里都是按我自已的表達方式來(lái)寫(xiě)的,相信你也能夠理解的。

P0口有三個(gè)功能:

1、外部擴展存儲器時(shí),當做數據總線(xiàn)(如圖1中的D0~D7為數據總線(xiàn)接口)

2、外部擴展存儲器時(shí),當作地址總線(xiàn)(如圖1中的A0~A7為地址總線(xiàn)接口)

3、不擴展時(shí),可做一般的I/O使用,但內部無(wú)上拉電阻,作為輸入或輸出時(shí)應在外部接上拉電阻。

 

P1口只做I/O口使用:其內部有上拉電阻。

P2口有兩個(gè)功能:

1、擴展外部存儲器時(shí),當作地址總線(xiàn)使用

2、做一般I/O口使用,其內部有上拉電阻;

P3口有兩個(gè)功能:

除了作為I/O使用外(其內部有上拉電阻),還有一些特殊功能,由特殊寄存器來(lái)設置,具體功能請參考我們后面的引腳說(shuō)明。

有內部EPROM的單片機芯片(例如8751),為寫(xiě)入程序需提供專(zhuān)門(mén)的編程脈沖和編程電源,這些信號也是由信號引腳的形式提供的,

即:編程脈沖:30腳(ALE/PROG)

編程電壓(25V):31腳(EA/Vpp)

接觸過(guò)工業(yè)設備的兄弟可能會(huì )看到有些印刷線(xiàn)路板上會(huì )有一個(gè)電池,這個(gè)電池是干什么用的呢?這就是單片機的備用電源,當外接電源下降到下限值時(shí),備用電源就會(huì )經(jīng)第二功能的方式由第9腳(即RST/VPD)引入,以保護內部RAM中的信息不會(huì )丟失。

(注:這些引腳的功能應用,除9腳的第二功能外,在“新動(dòng)力2004版”學(xué)習套件中都有應用到。)

在介紹這四個(gè)I/O口時(shí)提到了一個(gè)“上拉電阻”那么上拉電阻又是一個(gè)什么東東呢?他起什么作用呢?都說(shuō)了是電阻那當然就是一個(gè)電阻啦,當作為輸入時(shí),上拉電阻將其電位拉高,若輸入為低電平則可提供電流源;所以如果P0口如果作為輸入時(shí),處在高阻抗狀態(tài),只有外接一個(gè)上拉電阻才能有效。

ALE 地址鎖存控制信號:在系統擴展時(shí),ALE用于控制把P0口的輸出低8位地址送鎖存器鎖存起來(lái),以實(shí)現低位地址和數據的隔離。參見(jiàn)圖2(8051擴展2KB EEPROM電路,在圖中ALE與4LS373鎖存器的G相連接,當CPU對外部進(jìn)行存取時(shí),用以鎖住地址的低位地址,即P0口輸出。

由于A(yíng)LE是以晶振六分之一的固定頻率輸出的正脈沖,當系統中未使用外部存儲器時(shí),ALE腳也會(huì )有六分之一的固定頻率輸出,因此可作為外部時(shí)鐘或外部定時(shí)脈沖使用。

PSEN 外部程序存儲器讀選通信號:在讀外部ROM時(shí)PSEN低電平有效,以實(shí)現外部ROM單元的讀操作。

1、內部ROM讀取時(shí),PSEN不動(dòng)作;

2、外部ROM讀取時(shí),在每個(gè)機器周期會(huì )動(dòng)作兩次;

3、外部RAM讀取時(shí),兩個(gè)PSEN脈沖被跳過(guò)不會(huì )輸出;

4、外接ROM時(shí),與ROM的OE腳相接。

參見(jiàn)圖2—(8051擴展2KB EEPROM電路,在圖中PSEN與擴展ROM的OE腳相接)

EA/VPP 訪(fǎng)問(wèn)和序存儲器控制信號

1、接高電平時(shí):

CPU讀取內部程序存儲器(ROM)

擴展外部ROM:當讀取內部程序存儲器超過(guò)0FFFH(8051)1FFFH(8052)時(shí)自動(dòng)讀取外部ROM。

2、接低電平時(shí):CPU讀取外部程序存儲器(ROM)。

3、8751燒寫(xiě)內部EPROM時(shí),利用此腳輸入21V的燒寫(xiě)電壓。

RST 復位信號:當輸入的信號連續2個(gè)機器周期以上高電平時(shí)即為有效,用以完成單片機的復位初始化操作。

XTAL1和XTAL2 外接晶振引腳。當使用芯片內部時(shí)鐘時(shí),此二引腳用于外接石英晶體和微調電容;當使用外部時(shí)鐘時(shí),用于接外部時(shí)鐘脈沖信號。

VCC:電源+5V輸入
VSS:GND接地。
 

各端口工作原理講解
并行端口

P0端口

總線(xiàn)I/O端口,雙向,三態(tài),數據地址分時(shí)復用,該端口除用于數據的輸入/輸出外,在8031單片機外接程序存儲器時(shí),還分時(shí)地輸出/輸入地址/指令。由Po端口輸出的信號無(wú)鎖存,輸入的信息有讀端口引腳和讀端口鎖存器之分。P0端口8位中的一位結構圖見(jiàn)下圖:
 
由上圖可見(jiàn),P0端口由鎖存器、輸入緩沖器、切換開(kāi)關(guān)與相應控制電路、場(chǎng)效應管驅動(dòng)電路構成。
在輸出狀態(tài)下,當切換開(kāi)關(guān)MUX向下時(shí),從內部總線(xiàn)來(lái)的數據經(jīng)鎖存器反相和場(chǎng)效應管T2反相,輸出到端口引腳線(xiàn)上。此時(shí),場(chǎng)效應管T1關(guān)斷,因而這種輸出方式應為外接上拉電阻的漏極開(kāi)路式。當切換開(kāi)關(guān)MUX向上時(shí),一位地址/數據信號分時(shí)地輸出到端口線(xiàn)上。此外,由T1、T2的通斷組合,形成高電平、低電平與高阻浮動(dòng)三態(tài)的輸出。
在輸入狀態(tài)下,從鎖存器和從引腳上讀來(lái)的信號一般是一致的,但也有例外。例如,當從內部總線(xiàn)輸出低電平后,鎖存器Q=0,Q=1,場(chǎng)效應管T2開(kāi)通,端口線(xiàn)呈低電平狀態(tài)。此時(shí)無(wú)論端口線(xiàn)上外接的信號是低電乎還是高電平,從引腳讀入單片機的信號都是低電平,因而不能正確地讀入端口引腳上的信號。又如,當從內部總線(xiàn)輸出高電平后,鎖存器Q=1,Q=0,場(chǎng)效應管T2截止。如外接引腳信號為低電平,從引腳上讀入的信號就與從鎖存器讀入的信號不同。為此,8031單片機在對端口P0一P3的輸入操作上,有如下約定:為此,8031單片機在對端口P0一P3的輸入操作上,有如下約定:凡屬于讀-修改-寫(xiě)方式的指令,從鎖存器讀入信號,其它指令則從端口引腳線(xiàn)上讀入信號。
讀-修改-寫(xiě)指令的特點(diǎn)是,從端口輸入(讀)信號,在單片機內加以運算(修改)后,再輸出(寫(xiě))到該端口上。下面是幾條讀--修改-寫(xiě)指令的例子。
 
這樣安排的原因在于讀-修改-寫(xiě)指令需要得到端口原輸出的狀態(tài),修改后再輸出,讀鎖存器而不是讀引腳,可以避免因外部電路的原因而使原端口的狀態(tài)被讀錯。
P0端口是8031單片機的總線(xiàn)口,分時(shí)出現數據D7一D0、低8位地址A7一AO,以及三態(tài),用來(lái)接口存儲器、外部電路與外部設備。P0端口是使用最廣泛的I/O端口。

P1端口:

通用I/0端口,準雙向靜態(tài)口。輸出的信息有鎖存,輸入有讀引腳和讀鎖存器之分。P1端口的一位結構見(jiàn)下圖. 由圖可見(jiàn),P1端口與P0端口的主要差別在于,P1端口用內部上拉電阻R代替了P0端口的場(chǎng)效應管T1,并且輸出的信息僅來(lái)自?xún)炔靠偩€(xiàn)。由內部總線(xiàn)輸出的數據經(jīng)鎖存器反相和場(chǎng)效應管反相后,鎖存在端口線(xiàn)上,所以,P1端口是具有輸出鎖存的靜態(tài)口。
由下圖可見(jiàn),要正確地從引腳上讀入外部信息,必須先使場(chǎng)效應管關(guān)斷,以便由外部輸入的信息確定引腳的狀態(tài)。為此,在作引腳讀入前,必須先對該端口寫(xiě)入l。具有這種操作特點(diǎn)的輸入/輸出端口,稱(chēng)為準雙向I/O口。8031單片機的P1、P2、P3都是準雙向口。P0端口由于輸出有三態(tài)功能,輸入前,端口線(xiàn)已處于高阻態(tài),無(wú)需先寫(xiě)入l后再作讀操作。

 
單片機復位后,各個(gè)端口已自動(dòng)地被寫(xiě)入了1,此時(shí),可直接作輸入操作。如果在應用端口的過(guò)程中,已向P1一P3端口線(xiàn)輸出過(guò)0,則再要輸入時(shí),必須先寫(xiě)1后再讀引腳,才能得到正確的信息。此外,隨輸入指令的不同,H端口也有讀鎖存器與讀引腳之分。
Pl端口是803l單片機中唯一僅有的單功能I/O端口,并且沒(méi)有特定的專(zhuān)用功能,輸出信號鎖存在引腳上,故又稱(chēng)為通用靜態(tài)口。

P2端口:
P2端口的一位結構見(jiàn)下圖:

 
由圖可見(jiàn),P2端口在片內既有上拉電阻,又有切換開(kāi)關(guān)MUX,所以P2端口在功能上兼有P0端口和P1端口的特點(diǎn)。這主要表現在輸出功能上,當切換開(kāi)關(guān)MUX向左時(shí),從內部總線(xiàn)輸出的一位數據經(jīng)反相器和場(chǎng)效應管反相后,輸出在端口引腳線(xiàn)上;當MUX向右時(shí),輸出的一位地址信號也經(jīng)反相器和場(chǎng)效應管反相后,輸出在端口引腳線(xiàn)上。
由于8031單片機必須外接程序存儲器才能構成應用電路,而P2端口就是用來(lái)周期性地輸出從外存中取指令的地址(高8位地址),因此,P2端口的切換開(kāi)關(guān)MUX總是在進(jìn)行切換,分時(shí)地輸出從內部總線(xiàn)來(lái)的數據和從地址信號線(xiàn)上來(lái)的地址。因此P2端口是動(dòng)態(tài)的I/O端口。輸出數據雖被鎖存,但不是穩定地出現在端口線(xiàn)上。其實(shí),這里輸出的數據往往也是一種地址,只不過(guò)是外部RAM的高8位地址。
在輸入功能方面,P2端口與P0和H端口相同,有讀引腳和讀鎖存器之分,并且P2端口也是準雙向口。
可見(jiàn),P2端口的主要特點(diǎn)包括:
①不能輸出靜態(tài)的數據;
②自身輸出外部程序存儲器的高8位地址;
②執行MOVX指令時(shí),還輸出外部RAM的高位地址,故稱(chēng)P2端口為動(dòng)態(tài)地址端口。
 
P3端口:
雙功能靜態(tài)I/O口P3端口的一位結構見(jiàn)下圖。

 
由上圖可見(jiàn),P3端口和Pl端口的結構相似,區別僅在于P3端口的各端口線(xiàn)有兩種功能選擇。當處于第一功能時(shí),第二輸出功能線(xiàn)為1,此時(shí),內部總線(xiàn)信號經(jīng)鎖存器和場(chǎng)效應管輸入/輸出,其作用與P1端口作用相同,也是靜態(tài)準雙向I/O端口。當處于第二功能時(shí),鎖存器輸出1,通過(guò)第二輸出功能線(xiàn)輸出特定的內含信號,在輸入方面,即可以通過(guò)緩沖器讀入引腳信號,還可以通過(guò)替代輸入功能讀入片內的特定第二功能信號。由于輸出信號鎖存并且有雙重功能,故P3端口為靜態(tài)雙功能端口。

P3口的特殊功能(即第二功能):

 
使P3端品各線(xiàn)處于第二功能的條件是:

1串行I/O處于運行狀態(tài)(RXD,TXD);

2打開(kāi)了處部中斷(INT0,INT1);

3定時(shí)器/計數器處于外部計數狀態(tài)(T0,T1)

4執行讀寫(xiě)外部RAM的指令(RD,WR)

在應用中,如不設定P3端口各位的第二功能(WR,RD信叼的產(chǎn)生不用設置),則P3端口線(xiàn)自動(dòng)處于第一功能狀態(tài),也就是靜態(tài)I/O端口的工作狀態(tài)。在更多的場(chǎng)合是根據應用的需要,把幾條端口線(xiàn)設置為第二功能,而另外幾條端口線(xiàn)處于第一功能運行狀態(tài)。在這種情況下,不宜對P3端口作字節操作,需采用位操作的形式。
 

端口的負載能力和輸入/輸出操作:

P0端口能驅動(dòng)8個(gè)LSTTL負載。如需增加負載能力,可在P0總線(xiàn)上增加總線(xiàn)驅動(dòng)器。P1,P2,P3端口各能驅動(dòng)4個(gè)LSTTL負載。
前已述及,由于P0-P3端口已映射成特殊功能寄存器中的P0一P3端口寄存器,所以對這些端口寄存器的讀/寫(xiě)就實(shí)現了信息從相應端口的輸入/輸出。例如:
MOV A, P1 ;把Pl端口線(xiàn)上的信息輸入到A
MoV P1, A ;把A的內容由P1端口輸出
MOV P3, #0FFH ;使P3端口線(xiàn)各位置l

串行端口:
MCS-51系列單片機片內有一個(gè)串行I/O端口,通過(guò)引腳RXD(P3.0)和TXD(P3.1)可與外設電路進(jìn)行全雙工的串行異步通信。

1.串行端口的基本特點(diǎn)
8031單片機的串行端口有4種基本工作方式,通過(guò)編程設置,可以使其工作在任一方式,以滿(mǎn)足不同應用場(chǎng)合的需要。其中,方式0主要用于外接移位寄存器,以擴展單片機的I/O電路;方式1多用于雙機之間或與外設電路的通信;方式2,3除有方式l的功能外,還可用作多機通信,以構成分布式多微機系統。
串行端口有兩個(gè)控制寄存器,用來(lái)設置工作方式、發(fā)送或接收的狀態(tài)、特征位、數據傳送的波特率(每秒傳送的位數)以及作為中斷標志等。
串行端口有一個(gè)數據寄存器SBUF(在特殊功能寄存器中的字節地址為99H),該寄存器為發(fā)送和接收所共同。發(fā)送時(shí),只寫(xiě)不讀;接收時(shí),只讀不寫(xiě)。在一定條件下,向陽(yáng)UF寫(xiě)入數據就啟動(dòng)了發(fā)送過(guò)程;讀SBUf就啟動(dòng)了接收過(guò)程。
串行通信的波特率可以程控設定。在不同工作方式中,由時(shí)鐘振蕩頻率的分頻值或由定時(shí)器Tl的定時(shí)溢出時(shí)間確定,使用十分方便靈活。

2.串行端口的工作方式
①方式0
8位移位寄存器輸入/輸出方式。多用于外接移位寄存器以擴展I/O端口。波特率固定為fosc/12。其中,fosc為時(shí)鐘頻率。
在方式0中,串行端口作為輸出時(shí),只要向串行緩沖器SBUF寫(xiě)入一字節數據后,串行端口就把此8位數據以等的波特率,從RXD引腳逐位輸出(從低位到高位);此時(shí),TXD輸出頻率為fosc/12的同步移位脈沖。數據發(fā)送前,僅管不使用中斷,中斷標志TI還必須清零,8位數據發(fā)送完后,TI自動(dòng)置1。如要再發(fā)送,必須用軟件將TI清零。
串行端口作為輸入時(shí),RXD為數據輸入端,TXD仍為同步信號輸出端,輸出頻率為fosc/12的同步移位脈沖,使外部數據逐位移入RxD。當接收到8位數據(一幀)后,中斷標志RI自動(dòng)置。如果再接收,必須用軟件先將RI清零。
串行方式0發(fā)送和接收的時(shí)序過(guò)程見(jiàn)下圖。

②方式1

 
10位異步通信方式。其中,1個(gè)起始位(0),8個(gè)數據位(由低位到高位)和1個(gè)停止位(1)。波特率由定時(shí)器T1的溢出率和SMOD位的狀態(tài)確定。
一條寫(xiě)SBUF指令就可啟動(dòng)數據發(fā)送過(guò)程。在發(fā)送移位時(shí)鐘(由波特率確定)的同步下,從TxD先送出起始位,然后是8位數據位,最后是停止位。這樣的一幀10位數據發(fā)送完后,中斷標志TI置位。
在允許接收的條件下(REN=1),當RXD出現由1到O的負跳變時(shí),即被當成是串行發(fā)送來(lái)的一幀數據的起始位,從而啟動(dòng)一次接收過(guò)程。當8位數據接收完,并檢測到高電乎停止位后,即把接收到的8位數據裝入SBUF,置位RI,一幀數據的接收過(guò)程就完成了。
方式1的數據傳送波特率可以編程設置,使用范圍寬,其計算式為:
波特率=2SMOD/32×(定時(shí)器T1的溢出率)
其中,SMOD是控制寄存器PCON中的一位程控位,其取值有0和l兩種狀態(tài)。顯然,當SMOD=0時(shí),波特率=1/32(定時(shí)器Tl溢出率),而當SMOD=1時(shí),波特率=1/16(定時(shí)器T1溢出率)。所謂定時(shí)器的溢出率,就是指定時(shí)器一秒鐘內的溢出次數。波特率的算法,以及要求一定波特率時(shí)定時(shí)器定時(shí)初值的求法,后面將詳細討論。 ·
串行方式1的發(fā)送和接收過(guò)程的時(shí)序見(jiàn)下圖。

③方式2,3
11位異步通信方式。其中,1個(gè)起始位(0),8個(gè)數據位(由低位到高位),1個(gè)附加的第9位和1個(gè)停止住(1)。方式2和方式3除波特率不同外,其它性能完全相同。方式2,3的發(fā)送、接收時(shí)序見(jiàn)下圖。
由圖可見(jiàn),方式2和方式3與方式l的操作過(guò)程基本相同,主要差別在于方式2,3有第9位數據。

發(fā)送時(shí),發(fā)送機的這第9位數據來(lái)自該機SCON中的TB8,而接收機將接收到的這第9位數據送入本機SCON中的RB8。這個(gè)第9位數據通常用作數據的奇偶檢驗位,或在多機通信中作為地址/數據的特征位。
方式2和方式3的波特率計算式如下:
方式2的波特率=2SMOD/64×fosc
方式3的波特率=2SMOD/32×定時(shí)器T1的溢出率
由此可見(jiàn),在晶振時(shí)鐘頻率一定的條件下,方式2只有兩種波特率,而方式3可通過(guò)編程設置成多種波特率,這正是這兩種方式的差別所在。
3.串行端口的控制寄存器

串行端口共有2個(gè)控制寄存器SCON和PCON,用以設置串行端口的工作方式、接收/發(fā)送的運行狀態(tài)、接收/發(fā)送數據的特征、波特率的大小,以及作為運行的中斷標志等。
 
在這些引腳中,“新動(dòng)力2004版”學(xué)習套件都有這些實(shí)驗功能,并有相應的例程,配套的光盤(pán)中還有試驗板的原理圖。我在后面的章節中也會(huì )按照“新動(dòng)力2004版”的實(shí)驗功能一步一步的深入講解下去。
上拉電阻相關(guān)文章:上拉電阻原理


關(guān)鍵詞: 51 單片機 管腳 說(shuō)明

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>