<form id="itnzz"><noscript id="itnzz"></noscript></form>

          1. <menuitem id="itnzz"></menuitem>
          2. 成人午夜激情在线观看,国产精品一线天粉嫩av,99精品国产综合久久久久五月天 ,一卡2卡三卡4卡免费网站,国产高清在线男人的天堂,五月天国产成人AV免费观看,67194熟妇在线观看线路,成人无码潮喷在线观看
            現在位置:范文先生網>理工論文>電子通信論文>uC/OS-II實時操作系統在嵌入式平臺上進行移植的一般方法和技巧

            uC/OS-II實時操作系統在嵌入式平臺上進行移植的一般方法和技巧

            時間:2023-02-21 00:09:23 電子通信論文 我要投稿
            • 相關推薦

            uC/OS-II實時操作系統在嵌入式平臺上進行移植的一般方法和技巧

            引言

            ---實時操作系統的使用,能夠簡化嵌入式系統的應用開發,有效地確保穩定性和可靠性,便于維護和二次開發。

            μC/OS-II是一個基于搶占式的實時多任務內核,可固化、可剪裁、具有高穩定性和可靠性,除此以外,μC/OS-II的鮮明特點就是源碼公開,便于移植和維護。

            在μC/OS-II官方的主頁上可以查找到一個比較全面的移植范例列表。但是,在實際的開發項目中,仍然沒有針對項目所采用芯片或開發工具的合適版本。那么,不妨自己根據需要進行移植。

            本文則以在TMS320C6711 DSP上的移植過程為例,分析了μC/OS-II在嵌入式開發平臺上進行移植的一般方法和技巧。μC/OS-II移植的基本步驟

            在選定了系統平臺和開發工具之后,進行μC/OS-II的移植工作,一般需要遵循以下的幾個步驟:

            ● 深入了解所采用的系統核心
            ● 分析所采用的C語言開發工具的特點
            ● 編寫移植代碼
            ● 進行移植的測試
            ● 針對項目的開發平臺,封裝服務函數
            (類似80x86版本的PC.C和PC.H)

            系統核心

            無論項目所采用的系統核心是MCU、DSP、MPU,進行μC/OS-II的移植時,所需要關注的細節都是相近的。

            首先,是芯片的中斷處理機制,如何開啟、屏蔽中斷,可否保存前一次中斷狀態等。還有,芯片是否有軟中斷或是陷阱指令,又是如何觸發的。

            此外,還需關注系統對于存儲器的使用機制,諸如內存的地址空間,堆棧的增長方向,有無批量壓棧的指令等。

            在本例中,使用的是TMS320C6711 DSP。這是TI公司6000系列中的一款浮點型號,由于其時鐘頻率非常高,且采用了超常指令字(VLIW)結構、類RISC指令集、多級流水等技術,所以運算性能相當強大,在通信設備、圖像處理、醫療儀器等方面都有著廣泛的應用。

            在C6711中,中斷有3種類型,即復位、不可屏蔽中斷(NMI)和可屏蔽中斷(INT4-INT15)?善帘沃袛嘤蒀SR寄存器控制全局使能,此外也可用IER寄存器分別置位使能。而在C6711中并沒有軟中斷機制,所以μC/OS-II的任務切換需要編寫一個專門的函數實現。

            此外,C6711也沒有專門的中斷返回指令、批量壓棧指令,所以相應的任務切換代碼均需編程完成。由于采用了類RISC核心,C6711的內核結構中,只有A0-A15和B0-B15這兩組32bit的通用寄存器。 

            C語言開發工具

            無論所使用的系統核心是什么,C語言開發工具對于μC/OS-II是必不可少的。
            最簡單的信息可以從開發工具的手冊中查找,比如:C語言各種數據類型分別編譯為多少字節;是否支持嵌入式匯編,格式要求怎樣;是否支持“interrupt”非標準關鍵字聲明的中斷函數;是否支持匯編代碼列表(list)功能,等等。

            上述的這樣一些特性,會給嵌入式的開發帶來很多便利。TI的C語言開發工具CCS for C6000就包含上述的所有功能。

            而在此基礎上,可以進一步地弄清開發工具的一些技術細節,以便進行之后真正的移植工作。

            首先,開啟C編譯器的“匯編代碼列表(list)”功能,這樣編譯器就會為每個C語言源文件生成其對應的匯編代碼文件。

            在CCS開發環境中的方法是:在菜單“/Project/Build options”的“Feedback”欄中選擇“Interlisting:Opt/C and ASM(-s)”;或者,也可以直接在CCS的C編譯命令行中加上“-s”參數。

            然后分別編寫幾個簡單的函數進行編譯,比較C源代碼和編譯生成的匯編代碼。例如:

            void FUNC_TEMP (void)
            {
            Func_tmp2(); //調用任一個函數
            }
            在CCS中編譯后生成的ASM代碼為:
            .asg B15, SP // 宏定義
            _FUNC_TEMP:
            STW B3,*SP--(8) // 入棧
            NOP 2
            CALL _ Func_tmp2 //-----------
            MVKL BACK, B3 // 函數調用
            MVKH BACK, B3 //-----------
            NOP 3 
            BACK: LDW *++SP(8),B3 // 出棧
            NOP 4
            RET B3 // 函數返回
            NOP 5

            由此可見,在CCS編譯器的規則中,B15寄存器被用作堆棧指針,使用通用存取指令進行棧操作,而且堆棧指針必須以8字節為單位改變。

            此外,B3寄存器被用來保存函數調用時的返回地址,在函數執行之前需要入棧保護,直到函數返回前再出棧。

            當然,CCS的C編譯器對于每個通用寄存器都有約定的用途,但對于μC/OS-II的移植來說,了解以上信息就足夠了。

            最后,再編寫一個用“interrupt”關鍵字聲明的函數:

            interrupt void ISR_TEMP (void)
            {
            int a;
            a=0;
            }
            生成的ASM代碼為:
            _ISR_TEMP:
            STW B4,*SP--(8) // 入棧
            NOP 2
            ZERO B4 //---------
            STW B4,*+SP(4) // a=0
            NOP 2 //----------
            B IRP // 中斷返回
            LDW *++SP(8),B4 // 出棧
            NOP 4 

            與前一段代碼相比,對于中斷函數的編譯,有兩點不同:

            ● 函數的返回地址不再使用B3寄存器,相應地也無需將B3入棧。(IRP寄存器能自動保存中斷發生時的程序地址)

            ● 編譯器會自動統計中斷函數所用到的寄存器,從而在中斷一開始將他們全部入棧保護——

            例如上述程序段中,只用到了B4寄存器。

            編寫移植代碼

            在深入了解了系統核心與開發工具的基礎上,真正編寫移植代碼的工作就相對比較簡單了。

            μC/OS-II自身的代碼絕大部分都是用ANSI C編寫的,而且代碼的層次結構十分干凈,與平臺相關的移植代碼僅僅存在于OS_CPU_A.ASM、OS_CPU_C.C以及OS_CPU.H這三個文件當中。

            在移植的時候,結合前面兩個步驟中已經掌握的信息,基本上按照《嵌入式實時操作系統μC/OS-II》一書的相關章節的指導來做就可以了。

            但是,由于系統核心、開發工具的千差萬別,在實際項目中,一般都會有一些處理方法上的不同,需要特別注意。以C6711的移植為例:

            ● 中斷的開啟和屏蔽的兩個宏定義為:
            #define OS_ENTER_CRITICAL() Disable_int() 
            #define OS_EXIT_CRITICAL() Enable_int()

            Disable_int和Enable_int是用匯編語言編寫的兩個函數。在這里使用了控制狀態寄存器(CSR)的一個特性——CSR中除了控制全局中斷的GIE位之外,還有一個PGIE位,可用于保存之前的GIE狀態。

            因此在Disable_int中先將GIE的值寫入PGIE,然后再將GIE寫0,屏蔽中斷。而在Enable_int中則從PGIE讀出值,寫入GIE,從而回復到之前的中斷設置。

            這樣,就可以避免使用這兩個宏而意外改變了系統的中斷狀態——此外,也沒有使用堆;蚓植孔兞,比原作者推薦的方法要好。

            ● 任務的切換:
            前文說過,C6711中沒有軟中斷機制,所以任務的切換需要用匯編語言自行編寫一個函數_OSCtxSw來實現,并且
            #define OS_TASK_SW() OSCtxSw()
            在C6711中需要入棧保護的寄存器包括A0-A15、B0-B15、CSR、IER、IRP和AMR,這些再加上當前的程序地址構成一個存儲幀,需要入棧保存。
            _OSCtxSw函數中,需要像發生了一次中斷那樣,將上述存儲幀入棧,然后獲取被激活任務的TCB指針,將其存儲幀的內容彈出,從而完成任務切換。
            需要特別注意的是,在這里OS_TASK_SW是作為函數調用的,所以如前文所述,調用時的當前程序地址是保存在B3寄存器中的,這也就是任務重新激活時的返回地址。

            ● 中斷的編寫:
            如前文所述,如果用“interrupt”關鍵字聲明函數,CCS在編譯時,會自動將該函數中使用到的寄存器入棧、出棧保護。
            但是,這會導致各種中斷發生時,出入棧的內容各不相同。這對于μC/OS-II是會引起嚴重錯誤的。因為μC/OS-II要求中斷發生時的入棧操作使用和發生任務切換時完全一樣的存儲幀結構。
            因此,在移植時、基于μC/OS-II進行開發時,都不應當使用“interrupt”關鍵字,而應用如下結構編寫中斷函數:

            void OSTickISR (void)
            {
            DSP_C6x_Save(); // 服務函數,入棧
            OSIntEnter();
            if (OSIntNesting == 1) // v2.51版本新增加
            {
            OSTCBCur->OSTCBStkPtr
            =(OS_STK*) DSP_C6x_GetCurrentSP(); // 服務函數
            } // 獲取當前SP的值
            // 允許中斷嵌套 則在此處開中斷
            OSTimeTick();
            OSIntExit();
            DSP_C6x_Resume(); // 服務函數,出棧
            }
            DSP_C6x_Save和DSP_C6x_Resume是兩個服務函數,分別完成中斷的出、入棧操作。它們與OS_TASK_SW函數的區別在于:中斷發生時的當前程序地址是自動保存在IRP寄存器的,應將其作為任務返回地址,而不再是B3。此外,DSP_C6x_Resume是一個永遠不會返回的函數,在將所有內容出棧后,它就直接跳轉回到中斷發生前的程序地址處,繼續執行。

            進行移植的測試
            在編寫完了所有的移植代碼之后,就可以編寫幾個簡單的任務程序進行測試了,大體上可以分三個步驟來進行,相關資料比較詳盡,這里就不多作贅述了。

            封裝服務函數
            最后這個步驟,往往是容易被忽視的,但對于保持項目代碼的簡潔、易維護有很重要的意義。
            μC/OS-II的原作者強烈建議將源代碼分路徑進行存儲,例如本文例子中的所有源代碼就應按如下路徑結構存儲:
            \uCOS-II
            ├─SOURCE // 平臺無關代碼
            │ OS_CORE.C
            │ ......
            └─TI_C6711 // 系統核心
            ├─CCS // 開發工具
            │ OS_CPU.H 
            │ OS_CPU_A.ASM
            │ OS_CPU_C.C

            ├─ DSP_C6x_Service // 服務函數
            │ DSP_C6x_ Service.H
            │ DSP_C6x_ Service.ASM 

            └─ TEST // 具體的開發項目代碼
            OS_CFG.H
            INCLUDES.H
            TEST.C ......

            如上,DSP_C6x_Service中的服務函數,類似于原作者提供的80x86版本中的PC.C和PC.H文件。在本文的例子中,服務函數則包括了上文提及的中斷相關函數,以及系統初始化函數DSP_C6x_SystemInit()和時鐘初始化函數DSP_C6x_TimerInit()等。
            而具體的開發項目代碼,則可以分別在“/TI_C6711”路徑下新建自己的目錄,就如同移植測試的“TEST”項目,而無需再關注μC/OS-II的源代碼和服務函數。
            如此,就可以避免不必要的編譯錯誤,也便于開發項目的維護。


            【uC/OS-II實時操作系統在嵌入式平臺上進行移植的一般方法和技巧】相關文章:

            實時嵌入式操作系統μC/OS-II在MPC555上的移植08-06

            實時操作系統μC/OS-II在MCF5272上的移植08-06

            uC/OS-II在EP7312上的移植08-06

            嵌入式實時操作系統μC/OS-II與eCos的比較08-06

            使用uC/OS-II操作系統的短信息電話機08-06

            提高實時操作系統的實時性能和可靠性策略08-19

            uC/OS-II任務棧處理的一種改進方法08-06

            用CPLD實現嵌入式平臺上的實時圖像增強08-06

            用CPLD實現嵌入式平臺上的實時圖像增強08-06

            主站蜘蛛池模板: 欧美嫩交一区二区三区| 久久99国产精品尤物| 妺妺窝人体色www聚色窝仙踪| 视频二区中文字幕在线| 久久精品丝袜高跟鞋| 精品国产一区二区三区国产区| 加勒比无码人妻东京热| 最新国产精品亚洲| 狠狠亚洲色一日本高清色| 亚洲一码二码三码精华液| 日本不卡码一区二区三区| 色综合色国产热无码一| 亚洲天堂免费av在线观看| 久久综合色一综合色88欧美| 欧美亚洲综合成人a∨在线| 久久精品99久久久久久久久| 一区二区三区四区黄色网| 国产精品免费观在线| 成本人片无码中文字幕免费| 欧美乱妇高清无乱码免费| 《五十路》久久| 中文字幕亚洲综合小综合| 国产乱人伦偷精品视频不卡| 亚洲乱色熟女一区二区蜜臀| 大香j蕉75久久精品免费8| 国产精品视频午夜福利| 色悠悠国产精品免费观看| 成av人电影在线观看| 成人性无码专区免费视频| 亚洲国产综合自在线另类| www欧美在线观看| 亚洲精品国模一区二区| 一边捏奶头一边高潮视频| 麻豆国产高清精品国在线| chinese老太交videos| 亚洲成人av一区免费看| 日本福利视频免费久久久| 激情六月丁香婷婷四房播| 欧美亚洲综合成人A∨在线| 九九热精彩视频在线免费| 精品一区二区三区不卡|