μCOS-II在ATmega128單片機上的移植與開發(fā)
引 言
本文介紹μC/OS-Ⅱ移植到ATMEL公司的8位微控制器ATmega128上的過程。所謂移植,就是使一個實時內(nèi)核可以在某個微處理器上運行,并在此基礎(chǔ)上進行驅(qū)動程序開發(fā),使之成為一個實用的嵌入式系統(tǒng)。嵌入式系統(tǒng)包括了硬件和軟件兩部分,由于系統(tǒng)硬件資源的限制和實際應(yīng)用的要求,應(yīng)用系統(tǒng)對軟件的基本要求是體積小,執(zhí)行速度快,具有較好的裁減性和可移植性。
嵌入式系統(tǒng)的軟件一般由嵌入式操作系統(tǒng)和應(yīng)用軟件組成,通過在操作系統(tǒng)之上開發(fā)應(yīng)用軟件,可以屏蔽掉很多底層硬件細節(jié),使得應(yīng)用程序調(diào)試方便,移植簡單,易維護,同時開發(fā)周期也短。多數(shù)實時操作系統(tǒng)為用戶提供一些標準的API函數(shù),程序開發(fā)人員可以利用這些API函數(shù)進行應(yīng)用程序開發(fā)。但是現(xiàn)在商用型的實時操作系統(tǒng)價格非常昂貴,而免費型的實時操作系統(tǒng)μCOS-II作為一個源代碼公開的實時內(nèi)核已經(jīng)有了10余年使用實踐,許多行業(yè)都有成功應(yīng)用該內(nèi)核的實例。但由于μCOS-II只是一個實時內(nèi)核,它沒有像商用型實時操作系統(tǒng)那樣提供API函數(shù)接口,有很多工作需要用戶去完成,還需要根據(jù)實際應(yīng)用需要進行功能擴展,包
μC/OS-II嵌入式實時操作系統(tǒng)簡介
μC/OS-II是著名的、源碼公開的實時內(nèi)核,可用于各類8位、16 位、32位單片機或DSP。μC/OS-II是一個完整、可移植、可固化、可裁減的占先式實時多任務(wù)內(nèi)核。它用ANSIC語言編寫,包含小部分與硬件有關(guān)的匯編代碼,使之便于移植,可以在不同架構(gòu)的微處理器上使用。到目前為止,該內(nèi)核已有10多年的應(yīng)用史,在醫(yī)療、網(wǎng)絡(luò)、通信等許多領(lǐng)域得到了廣泛應(yīng)用。μC/OS-II內(nèi)核可以分為幾個獨立的部分,分別是任務(wù)管理、時間管理、任務(wù)間通信、內(nèi)存管理幾個獨立的部分,他的許多功能都是可配置的,這樣可以根據(jù)應(yīng)用的需要對操作系統(tǒng)進行裁減。μC/OS-II是占先式實時內(nèi)核,他總是運行在就緒條件下優(yōu)先級最高的任務(wù),μC/OS-II總共可以管理64個任務(wù),賦予每個任務(wù)的優(yōu)先級必須是不同的,每個任務(wù)都有自己獨立的堆棧,可以壓低用戶程序?qū)?nèi)存的需求。全部μC/OS-II的函數(shù)調(diào)用與服務(wù)執(zhí)行時間具有可確定性,它的系統(tǒng)服務(wù)的執(zhí)行時間不依賴于應(yīng)用程序任務(wù)的多少。μC/OS-II中的任務(wù)可以是一個無限的循環(huán),也可以在執(zhí)行完一次后被刪除掉,任務(wù)在休眠、就緒、運行、等待和掛起等幾個狀態(tài)之間進行轉(zhuǎn)換。μC/OS-II要求用戶提供定時中斷來實現(xiàn)延時和超時控制等功能,這個定時中斷稱為時鐘節(jié)拍,他的實際頻率由用戶的應(yīng)用程序決定,一般為10~100Hz 。節(jié)拍頻率越高,系統(tǒng)的負荷越重。μC/OS-II中有三種用于數(shù)據(jù)共享和任務(wù)通信的方法:信號量、郵箱和消息隊列。一個任務(wù)或者中斷服務(wù)子程序可以通過事件控制塊向另外的任務(wù)發(fā)信號;一個任務(wù)可以等待另一個任務(wù)或中斷服務(wù)子程序給它發(fā)送信號;或者是多個任務(wù)等待同一個信號的發(fā)生,在這種情況下,優(yōu)先級最高的任務(wù)將得到這一信號并進入就緒狀態(tài)準備執(zhí)行。
ATmega128微處理器的硬件特點
ATmega128的MCU包括一個算術(shù)邏輯單元(ALU) ,一個狀態(tài)寄存器(SREG) ,一個通用工作寄存器組和一個堆棧指針。狀態(tài)寄存器(SREG) 的最高位I是全局中斷允許位。如果全局中斷允許位為零,則所有中斷都被禁止。當系統(tǒng)響應(yīng)一個中斷后,I位將由硬件自動清“0”;當執(zhí)行中斷返回(RETI) 指令時,I位由硬件自動置“1”,從而允許系統(tǒng)再次響應(yīng)下一個中斷請求。通用工作寄存器組是由32個8位的通用工作寄存器組成。其中R26~R31這6 個寄存器還可以兩兩合并為3 個16位的間接地址寄存器,這些寄存器可以用來對數(shù)據(jù)存儲空間和程序存儲空間進行間接尋址的寄存器。堆棧指針(SP) 是一個指示堆棧頂部地址的16 位寄存器。ATmega128單片機的硬件堆棧的生長方向是向下的(從高地址向低地址生長) ,所以軟件堆棧在定義的時候,也要采取相同的生長方向。ATmega128單片機的數(shù)據(jù)存儲器是線形的,從低地址到高地址依次是CPU寄存器區(qū)(32個通用寄存器) ,I/O寄存器區(qū),數(shù)據(jù)存儲區(qū)。
ATmega128的中斷響應(yīng)機制
ATmega128有34個不同的中斷源,每個中斷源和系統(tǒng)復(fù)位在程序存儲空間都有一個獨立的中斷向量(中斷入口地址) 。每個中斷源都有各自獨立的中斷允許控制位,當某個中斷源的中斷允許控制位為“1”且全局中斷允許位I也為“1”時,系統(tǒng)才響應(yīng)該中斷。當系統(tǒng)響應(yīng)一個中斷請求后,會自動將全局中斷允許位I清零,此時,后續(xù)中斷響應(yīng)被屏蔽。當系統(tǒng)執(zhí)行中斷返回指令RETI時,會將全局中斷允許位I置“1”,以允許響應(yīng)下一個中斷。若用戶想實現(xiàn)中斷嵌套,必須在中斷服務(wù)子程序中將全局中斷允許位I置“1”。在中斷向量表中,處于低地址的中斷具有高的優(yōu)先級。優(yōu)先級高只是表明在多個中斷同時發(fā)生的時候,系統(tǒng)先響應(yīng)優(yōu)先級高的中斷,并不含有高優(yōu)先級的中斷能打斷低優(yōu)先級的中斷處理工作的意思。由于μC/OS-Ⅱ的任務(wù)切換實際上是模擬一次中斷,因此需要知道CPU的中斷響應(yīng)機制。中斷發(fā)生時,ATmega128按以下步驟順序執(zhí)行:
(1) 全局中斷允許位I清零。
(2) 將指向下一條指令的PC值壓入堆棧,同時堆棧指針SP減2。
(3) 選擇最高優(yōu)先級的中斷向量裝入PC,程序從此地址繼續(xù)執(zhí)行中斷處理。
(4) 當執(zhí)行中斷處理時,中斷源的中斷允許控制位清零。中斷結(jié)束后,執(zhí)行RETI指令,此時:
?、偃种袛嘣试S位I置“1”。
?、?PC從堆棧推出,程序從被中斷的地方繼續(xù)執(zhí)行。特別要注意的是:ATmega128A單片機在響應(yīng)中斷及從中斷返回時,并不會對狀態(tài)寄存器SREG 和通用寄存器自動進行保存和恢復(fù)操作,因此,對狀態(tài)寄存器SREG 和通用寄存器的中斷保護工作必須由用戶來完成。
評論