單片機相關的三種周期名詞的定義


時鍾周期

時鍾周期也稱為振盪周期,定義為時鍾脈沖的倒數(可以這樣來理解,時鍾周期就是單片機外接晶振的倒數,例如12M的晶振,它的時間周期就是1/12 us),是計算機中最基本的、最小的時間單位。

在一個時鍾周期內,CPU僅完成一個最基本的動作。對於某種單片機,若采用了1MHZ的時鍾頻率,則時鍾周期為1us;若采用4MHZ的時鍾頻率,則時鍾周期為250us。由於時鍾脈沖是計算機的基本工作脈沖,它控制着計算機的工作節奏(使計算機的每一步都統一到它的步調上來)。顯然,對同一種機型的計算機,時鍾頻率越高,計算機的工作速度就越快。但是,由於不同的計算機硬件電路和器件的不完全相同,所以其所需要的時鍾周頻率范圍也不一定相同。我們學習的8051單片機的時鍾范圍是1.2MHz-12MHz。

在8051單片機中把一個時鍾周期定義為一個節拍(用P表示),二個節拍定義為一個狀態周期(用S表示)。請大家參考后面的時序圖。

機器周期

在計算機中,為了便於管理,常把一條指令的執行過程划分為若干個階段,每一階段完成一項工作。例如,取指令、存儲器讀、存儲器寫等,這每一項工作稱為一個基本操作。完成一個基本操作所需要的時間稱為機器周期。一般情況下,一個機器周期由若干個S周期(狀態周期)組成。8051系列單片機的一個機器周期同6個S周期(狀態周期)組成。前面已說過一個時鍾周期定義為一個節拍(用P表示),二個節拍定義為一個狀態周期(用S表示),8051單片機的機器周期由6個狀態周期組成,也就是說一個機器周期=6個狀態周期=12個時鍾周期。參見后面的時序圖。

指令周期

指令周期是執行一條指令所需要的時間,一般由若干個機器周期組成。指令不同,所需的機器周期數也不同。對於一些簡單的的單字節指令,在取指令周期中,指令取出到指令寄存器后,立即譯碼執行,不再需要其它的機器周期。對於一些比較復雜的指令,例如轉移指令、乘法指令,則需要兩個或者兩個以上的機器周期。

時鍾周期、機器周期、指令周期之間的關系圖如下。

2.jpg

通常含一個機器周期的指令稱為單周期指令,包含兩個機器周期的指令稱為雙周期指令。

MCS-51指令系統中,按它們的長度可分為單字節指令、雙字節指令和三字節指令。執行這些指令需要的時間是不同的,也就是它們所需的機器周期是不同的,有下面幾種形式:

·單字節指令單機器周期

·單字節指令雙機器周期

·雙字節指令單機器周期

·雙字節指令雙機器周期

·三字節指令雙機器周期

·單字節指令四機器周期(如單字節的乘除法指令)

下圖是MCS-51系列單片機的指令時序圖:

3.jpg

上圖是單周期和雙周期取指及執行時序,圖中的ALE脈沖是為了鎖存地址的選通信號,顯然,每出現一次該信號單片機即進行一次讀指令操作。從時序圖中可看出,該信號是時鍾頻率6分頻后得到,在一個機器周期中,ALE信號兩次有效,第一次在S1P2和S2P1期間,第二次在S4P2和S5P1期間。

接下來我們分別對幾個典型的指令時序加以說明。

·單字節單周期指令:

單字節單周期指令只進行一次讀指令操作,當第二個ALE信號有效時,PC並不加1,那么讀出的還是原指令,屬於一次無效的讀操作。

·雙字節單周期指令:

這類指令兩次的ALE信號都是有效的,只是第一個ALE信號有效時讀的是操作碼,第二個ALE信號有效時讀的是操作數。

·單字節雙周期指令:

兩個機器周期需進行四讀指令操作,但只有一次讀操作是有效的,后三次的讀操作均為無效操作。

單字節雙周期指令有一種特殊的情況,象MOVX這類指令,執行這類指令時,先在ROM中讀取指令,然后對外部數據存儲器進行讀或寫操作,頭一個機器周期的第一次讀指令的操作碼為有效,而第二次讀指令操作則為無效的。在第二個指令周期時,則訪問外部數據存儲器,這時,ALE信號對其操作無影響,即不會再有讀指令操作動作。

上頁的時序圖中,我們只描述了指令的讀取狀態,而沒有畫出指令執行時序,因為每條指令都包含了具體的操作數,而操作數類型種類繁多,這里不便列出,有興趣的讀者可參閱有關書籍。

·外部程序存儲器(ROM)讀時序

4.jpg

右圖8051外部程序存儲器讀時序圖,從圖中可看出,P0口提供低8位地址,P2口提供高8位地址,S2結束前,P0口上的低8位地址是有效的,之后出現在P0口上的就不再是低8位的地址信號,而是指令數據信號,當然地址信號與指令數據信號之間有一段緩沖的過度時間,這就要求,在S2其間必須把低8位的地址信號鎖存起來,這時是用ALE選通脈沖去控制鎖存器把低8位地址予以鎖存,而P2口只輸出地址信號,而沒有指令數據信號,整個機器周期地址信號都是有效的,因而無需鎖存這一地址信號。

從外部程序存儲器讀取指令,必須有兩個信號進行控制,除了上述的ALE信號,還有一個PSEN(外部ROM讀選通脈沖),上圖顯然可看出,PSEN從S3P1開始有效,直到將地址信號送出和外部程序存儲器的數據讀入CPU后方才失效。而又從S4P2開始執行第二個讀指令操作。

·外部數據存儲器(RAM)讀時序

右圖8051外部數據存儲器讀寫時序圖,從ROM中讀取的需執行的指令,而CPU對外部數據存儲的訪問是對RAM進行數據的讀或寫操作,屬於指令的執行周期,值得一提的是,讀或寫是兩個不同的機器周期,但他們的時序卻是相似的,我們只對RAM的讀時序進行分析。

上一個機器周期是取指階段,是從ROM中讀取指令數據,接着的下個周期才開始讀取外部數據存儲器RAM中的內容。

在S4結束后,先把需讀取RAM中的地址放到總線上,包括P0口上的低8位地址A0-A7和P2口上的高8位地址A8-A15。當RD選通脈沖有效時,將RAM的數據通過P0數據總線讀進CPU。第二個機器周期的ALE信號仍然出現,進行一次外部ROM的讀操作,但是這一次的讀操作屬於無效操作。

對外部RAM進行寫操作時,CPU輸出的則是WR(寫選通信號),將數據通過P0數據總線寫入外部存儲中。

 

學習自 http://www.21ic.com/jichuzhishi/mcu/shixu/2013-01-23/157216.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM