<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è) > 嵌入式系統 > 設計應用 > 51單片機時(shí)序及延時(shí)分析介紹

51單片機時(shí)序及延時(shí)分析介紹

作者: 時(shí)間:2016-11-22 來(lái)源:網(wǎng)絡(luò ) 收藏
計算機工作時(shí),是在統一的時(shí)鐘脈沖控制下一拍一拍地進(jìn)行的。這個(gè)脈沖是由單片機控制器中的時(shí)序電路發(fā)出的。單片機的時(shí)序就是CPU在執行指令時(shí)所需控制信號的時(shí)間順序,為了保證各部件間的同步工作,單片機內部電路應在唯一的時(shí)鐘信號下嚴格地控時(shí)序進(jìn)行工作,在學(xué)習51單片機的時(shí)序之前,我們先來(lái)了解下時(shí)序相關(guān)的一些概念。
既然計算機是在統一的時(shí)鐘脈沖控制下工作的,那么,它的時(shí)鐘脈沖是怎么來(lái)的呢?
要給我們的計算機CPU提供時(shí)序,就需要相關(guān)的硬件電路,即振蕩器和時(shí)鐘電路。我們學(xué)習的8051單片機內部有一個(gè)高增益反相放大器,這個(gè)反相放大器的作用就是用于構成振蕩器用的,但要形成時(shí)鐘,外部還需要加一些附加電路。8051單片機的時(shí)鐘產(chǎn)生有以下兩種方法:
一、內部時(shí)鐘方式:
利用單片機內部的振蕩器,然后在引腳XTAL1(18腳)和XTAL2(19腳)兩端接晶振,就構成了穩定的自激振蕩器,其發(fā)出的脈沖直接送入內部時(shí)鐘電路,外接晶振時(shí),晶振兩端的電容一般選擇為30PF左右;這兩個(gè)電容對頻率有微調的作用,晶振的頻率范圍可在1.2MHz-12MHz之間選擇。為了減少寄生電容,更好地保證振蕩器穩定、可靠地工作,振蕩器和電容應盡可能安裝得與單片機芯片靠近。(提示一下,本站提供的學(xué)習套件全部采用的就是這種時(shí)鐘方式)。
二、外部時(shí)鐘方式:
此方式是利用外部振蕩脈沖接入XTAL1或XTAL2。HMOS和CHMOS單片機外時(shí)鐘信號接入方式不同,HMOS型單片機(例如8051)外時(shí)鐘信號由XTAL2端腳注入后直接送至內部時(shí)鐘電路,輸入端XTAL1應接地。由于XTAL2端的邏輯電平不是TTL的,故建議外接一個(gè)上接電阻。對于CHMOS型的單片機(例如 80C51),因內部時(shí)鐘發(fā)生器的信號取自反相器的輸入端,故采用外部時(shí)鐘源時(shí),接線(xiàn)方式為外時(shí)鐘信號接到XTAL1而XTAL2懸空。如下圖


外接時(shí)鐘信號通過(guò)一個(gè)二分頻的觸發(fā)器而成為內部時(shí)鐘信號,要求高、低電平的持續時(shí)間都大于20ns,一般為頻率低于12MHz的方波。片內時(shí)鐘發(fā)生器就是上述的二分頻觸發(fā)器,它向芯片提供了一個(gè)2節拍的時(shí)鐘信號。
前面已提到,計算機工作時(shí),是在統一的時(shí)鐘脈沖控制下一拍一拍地進(jìn)行的。由于指令的字節數不同,取這些指令所需要的時(shí)間也就不同,即使是字節數相同的指令,由于執行操作有較大的差別,不同的指令執行時(shí)間也不一定相同,即所需的拍節數不同。為了便于對CPU時(shí)序進(jìn)行分析,一般按指令的執行過(guò)程規定了幾中周期,即時(shí)鐘周期、機器周期和指令周期,也稱(chēng)為時(shí)序定時(shí)單位,下面分別予以講解。
時(shí)鐘周期
時(shí)鐘周期也稱(chēng)為振蕩周期,定義為時(shí)鐘脈沖的倒數(可以這樣來(lái)理解,時(shí)鐘周期就是單片機外接晶振的倒數,例如12M的晶振,它的時(shí)間周期就是1/12 us),是計算機中最基本的、最小的時(shí)間單位。
在一個(gè)時(shí)鐘周期內,CPU僅完成一個(gè)最基本的動(dòng)作。對于某種單片機,若采用了1MHZ的時(shí)鐘頻率,則時(shí)鐘周期為1us;若采用4MHZ的時(shí)鐘頻率,則時(shí)鐘周期為250us。由于時(shí)鐘脈沖是計算機的基本工作脈沖,它控制著(zhù)計算機的工作節奏(使計算機的每一步都統一到它的步調上來(lái))。顯然,對同一種機型的計算機,時(shí)鐘頻率越高,計算機的工作速度就越快。但是,由于不同的計算機硬件電路和器件的不完全相同,所以其所需要的時(shí)鐘周頻率范圍也不一定相同。我們學(xué)習的8051單片機的時(shí)鐘范圍是1.2MHz-12MHz。
在8051單片機中把一個(gè)時(shí)鐘周期定義為一個(gè)節拍(用P表示),二個(gè)節拍定義為一個(gè)狀態(tài)周期(用S表示)。請大家參考后面的時(shí)序圖。
機器周期
在計算機中,為了便于管理,常把一條指令的執行過(guò)程劃分為若干個(gè)階段,每一階段完成一項工作。例如,取指令、存儲器讀、存儲器寫(xiě)等,這每一項工作稱(chēng)為一個(gè)基本操作。完成一個(gè)基本操作所需要的時(shí)間稱(chēng)為機器周期。一般情況下,一個(gè)機器周期由若干個(gè)S周期(狀態(tài)周期)組成。8051系列單片機的一個(gè)機器周期同6個(gè)S周期(狀態(tài)周期)組成。前面已說(shuō)過(guò)一個(gè)時(shí)鐘周期定義為一個(gè)節拍(用P表示),二個(gè)節拍定義為一個(gè)狀態(tài)周期(用S表示),8051單片機的機器周期由6個(gè)狀態(tài)周期組成,也就是說(shuō)一個(gè)機器周期=6個(gè)狀態(tài)周期=12個(gè)時(shí)鐘周期。參見(jiàn)后面的時(shí)序圖。
指令周期
指令周期是執行一條指令所需要的時(shí)間,一般由若干個(gè)機器周期組成。指令不同,所需的機器周期數也不同。對于一些簡(jiǎn)單的的單字節指令,在取指令周期中,指令取出到指令寄存器后,立即譯碼執行,不再需要其它的機器周期。對于一些比較復雜的指令,例如轉移指令、乘法指令,則需要兩個(gè)或者兩個(gè)以上的機器周期。
時(shí)鐘周期、機器周期、指令周期之間的關(guān)系圖如下。



通常含一個(gè)機器周期的指令稱(chēng)為單周期指令,包含兩個(gè)機器周期的指令稱(chēng)為雙周期指令。
MCS-51指令系統中,按它們的長(cháng)度可分為單字節指令、雙字節指令和三字節指令。執行這些指令需要的時(shí)間是不同的,也就是它們所需的機器周期是不同的,有下面幾種形式:
·單字節指令單機器周期
·單字節指令雙機器周期
·雙字節指令單機器周期
·雙字節指令雙機器周期
·三字節指令雙機器周期
·單字節指令四機器周期(如單字節的乘除法指令)
下圖是MCS-51系列單片機的指令時(shí)序圖:





上圖是單周期和雙周期取指及執行時(shí)序,圖中的ALE脈沖是為了鎖存地址的選通信號,顯然,每出現一次該信號單片機即進(jìn)行一次讀指令操作。從時(shí)序圖中可看出,該信號是時(shí)鐘頻率6分頻后得到,在一個(gè)機器周期中,ALE信號兩次有效,第一次在S1P2和S2P1期間,第二次在S4P2和S5P1期間。
接下來(lái)我們分別對幾個(gè)典型的指令時(shí)序加以說(shuō)明。
·單字節單周期指令:
單字節單周期指令只進(jìn)行一次讀指令操作,當第二個(gè)ALE信號有效時(shí),PC并不加1,那么讀出的還是原指令,屬于一次無(wú)效的讀操作。
·雙字節單周期指令:
這類(lèi)指令兩次的ALE信號都是有效的,只是第一個(gè)ALE信號有效時(shí)讀的是操作碼,第二個(gè)ALE信號有效時(shí)讀的是操作數。
·單字節雙周期指令:
兩個(gè)機器周期需進(jìn)行四讀指令操作,但只有一次讀操作是有效的,后三次的讀操作均為無(wú)效操作。
單字節雙周期指令有一種特殊的情況,象MOVX這類(lèi)指令,執行這類(lèi)指令時(shí),先在ROM中讀取指令,然后對外部數據存儲器進(jìn)行讀或寫(xiě)操作,頭一個(gè)機器周期的第一次讀指令的操作碼為有效,而第二次讀指令操作則為無(wú)效的。在第二個(gè)指令周期時(shí),則訪(fǎng)問(wèn)外部數據存儲器,這時(shí),ALE信號對其操作無(wú)影響,即不會(huì )再有讀指令操作動(dòng)作。
上頁(yè)的時(shí)序圖中,我們只描述了指令的讀取狀態(tài),而沒(méi)有畫(huà)出指令執行時(shí)序,因為每條指令都包含了具體的操作數,而操作數類(lèi)型種類(lèi)繁多,這里不便列出,有興趣的讀者可參閱有關(guān)書(shū)籍。
·外部程序存儲器(ROM)讀時(shí)序


右圖8051外部程序存儲器讀時(shí)序圖,從圖中可看出,P0口提供低8位地址,P2口提供高8位地址,S2結束前,P0口上的低8位地址是有效的,之后出現在P0口上的就不再是低8位的地址信號,而是指令數據信號,當然地址信號與指令數據信號之間有一段緩沖的過(guò)度時(shí)間,這就要求,在S2其間必須把低8位的地址信號鎖存起來(lái),這時(shí)是用ALE選通脈沖去控制鎖存器把低8位地址予以鎖存,而P2口只輸出地址信號,而沒(méi)有指令數據信號,整個(gè)機器周期地址信號都是有效的,因而無(wú)需鎖存這一地址信號。
從外部程序存儲器讀取指令,必須有兩個(gè)信號進(jìn)行控制,除了上述的ALE信號,還有一個(gè)PSEN(外部ROM讀選通脈沖),上圖顯然可看出,PSEN從S3P1開(kāi)始有效,直到將地址信號送出和外部程序存儲器的數據讀入CPU后方才失效。而又從S4P2開(kāi)始執行第二個(gè)讀指令操作。
·外部數據存儲器(RAM)讀時(shí)序
右圖8051外部數據存儲器讀寫(xiě)時(shí)序圖,從ROM中讀取的需執行的指令,而CPU對外部數據存儲的訪(fǎng)問(wèn)是對RAM進(jìn)行數據的讀或寫(xiě)操作,屬于指令的執行周期,值得一提的是,讀或寫(xiě)是兩個(gè)不同的機器周期,但他們的時(shí)序卻是相似的,我們只對RAM的讀時(shí)序進(jìn)行分析。
上一個(gè)機器周期是取指階段,是從ROM中讀取指令數據,接著(zhù)的下個(gè)周期才開(kāi)始讀取外部數據存儲器RAM中的內容。
在S4結束后,先把需讀取RAM中的地址放到總線(xiàn)上,包括P0口上的低8位地址A0-A7和P2口上的高8位地址A8-A15。當RD選通脈沖有效時(shí),將RAM的數據通過(guò)P0數據總線(xiàn)讀進(jìn)CPU。第二個(gè)機器周期的ALE信號仍然出現,進(jìn)行一次外部ROM的讀操作,但是這一次的讀操作屬于無(wú)效操作。
對外部RAM進(jìn)行寫(xiě)操作時(shí),CPU輸出的則是WR(寫(xiě)選通信號),將數據通過(guò)P0數據總線(xiàn)寫(xiě)入外部存儲中。


評論


技術(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>