《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 在AndesCore N1033A-S處理器實現μC/OS-II的移植
在AndesCore N1033A-S處理器實現μC/OS-II的移植
摘要: μC/OS-II是一種代碼公開、可裁剪的嵌入式實時多任務操作系統。該內核通過實現搶占式任務調度算法和多任務間通信等功能,使之具有執行效率高、實時性能優良等特點。
Abstract:
Key words :

  μC/OS-II是一種代碼公開、可裁剪的嵌入式實時多任務操作系統。該內核通過實現搶占式任務調度算法和多任務間通信等功能,使之具有執行效率高、實時性能優良等特點。另外,其占用空間非常小(最小可裁剪至2KB)并且具有高度可移植性,因此被廣泛的應用于微處理器和微控制器上。

  晶心科技 (Andes)作為亞洲首家原創性32位微處理器IP與系統芯片平臺設計公司,推出的AndesCore N10系列產品N1033A-S, 搭配應用廣泛的嵌入式實時操作系統μC/OS-II以及相關的軟硬件開發資源,有效的幫助客戶降低現有成本、提升系統效能、減少系統功耗,并縮短產品開發上市時程。本文將介紹如何將μC/OS-II移植到AndesCore N1033A-S處理器上。

  1. 開發環境及處理器介紹

  1.1 軟/硬件開發環境

  本移植過程使用的軟件環境是AndeSight v1.4集成開發套件,它是晶心科技最新推出的針對各種AndesCore的軟件集成開發環境,包括編譯器、調試器、分析器以及強大的ESL工具。硬件平臺采用晶心科技的FPGA評估板ADP-XC5,該評估板采用AndesCore? N1033A-S作為處理器內核,并具有豐富的片上資源。

 

  AndesCore N1033A-S介紹

 

  AndesCore N10系列產品N1033A-S是一款哈弗結構的32位RISC處理器內核,具有5級流水線(pipeline)及動態分支預測(Dynamic branch predicTION)架構。N1033A-S新加入了最新AndeSTar V2 指令集,把CPU效能推至1.66DMIPS/Mhz之上。同時還實現完整的Audio指令集,達到完全整合CPU與DSP功能的目標。N1033A-S還支持向量中斷模式以及2D 直接內存訪問(DMA)功能,更為實時信號處理添增效能。

  2. μC/OS-II在N1033A-S上的可移植性分析

  μC/OS-II具有高度可移植性,目前已經移植到近40多種處理器體系上,涵蓋從8位到64位的各種CPU(包括DSP)。

  μC/OS-II的正常運行需要處理器平臺滿足以下要求: 1)處理器的C編譯器能產生可重入代碼;2)用C語言就可以打開和關閉中斷;3)處理器支持中斷,并且能產生定時中斷;4)處理器支持能夠容納一定量數據的硬件堆棧;5)處理器有將堆棧指針和其它CPU寄存器讀出和存儲到堆棧或內存中的指令。

  AndesCore N1033A-S內部提供了32個通用寄存器,其中R31被用來做專門的堆棧指針。32根地址線最多可訪問4GB存儲單元,因此只要系統RAM空間允許,堆棧空間理論不會產生限制。N1033A-S處理器提供的AndeStar? V2指令集包含了豐富且十分高效的對堆棧進行操作的指令。例如指令SMW(store multiple word)可實現僅使用一條指令將多個寄存器的值存儲到堆棧中并同時更新堆棧指針位置,而且還能很好的處理地址非對齊字的存取。N1033A-S支持中斷并能產生定時器中斷,處理器中的PSW(Processor Status Word)寄存器中包含一個全局中斷禁止位GIE,控制它便可實現打開和關閉中斷。此外,AndeSight?集成開發環境中內置的編譯器可以產生可重入代碼,并且支持內聯匯編,C環境中可以任意進行開關中斷的操作。綜上所述,μC/OS-II完全可以移植到N1033A-S上運行。

  3. 移植步驟

  為了方便移植,大部分的μC/OS-II代碼是用C語言寫的,用戶只需要用C語言和匯編語言寫一些與處理器相關的代碼就可以實現移植。這部分工作的內容包括:一個完成基本設置的頭文件os_cpu.h、一個與處理器相關的匯編文件os_cpu_a.S和一個與操作系統相關的C代碼文件os_cpu_c.c.

  3.1在os_cpu.h中完成基本的配置和定義

  3.1.1. 定義與處理器相關的數據類型

  為保證可移植性,μC/OS-II沒有直接使用C語言中的short、int和long等數據類型的定義,因為不同的處理器有不同的字長。對于N1033A-S這樣的32位處理器,其數據類型定義實現如下:

<a class=μC/OS-II數據類型定義實現" src="http://files.chinaaet.com/images/2012/03/24/d785d79a-f645-430f-b823-339134bbfcb7.jpg" />
μC/OS-II數據類型定義實現

 

  3.1.2. 定義中斷禁止/允許宏

  做為實時內核,μC/OS-II需要先禁止中斷再訪問代碼臨界區,并且在訪問完畢后重新允許中斷。μC/OS-II定義了兩個宏來禁止和允許中斷:OS_ENteR_CRITICAL()和OS_EXIT_CRITICAL()。在N1033A-S處理器上的實現代碼如下:

μC/OS-II定義中斷禁止/允許宏
μC/OS-II定義中斷禁止/允許宏

   中斷禁止時間是判斷系統實時性的重要指標之一。中斷禁止時間能否達到最短,不僅與操作系統的設計有關,還依賴于處理器結構和編譯器產生的代碼質量。從上面的實現代碼看到,由于Andes處理器提供了setgie.d和setgie.e兩條直接控制中斷的開關的指令,整個禁止/允許中斷的過程經過編譯器產生的機器碼只有3/2條,最大限度地減小了中斷禁止時間。

  3.1.3. 定義棧增長方向

  μC/OS-II使用結構常量OS_STK_GROWTH來指定堆棧的增長方式,設置為0表示堆棧從下往上增長,設置為1表示從上往下增長。這里我們定義成后者,即堆棧的增長方向是從內存高地址向低地址方向遞減并且堆棧指針總是指向棧頂數據:

μC/OS-II定義棧增長方向
μC/OS-II定義棧增長方向

  3.1.4.定義OS_TASK_SW()宏

  OS_TASK_SW()是一個宏,它在μC/OS-Ⅱ從低優先級任務切換到最高優先級任務時被調用的。任務切換只是簡單的將處理器寄存器保存到將被掛起的任務的堆棧中,并且將更高優先級的任務從堆棧中恢復出來。可采用兩種方式定義這個宏,使用軟中斷將中斷向量指向OSCtxSW()函數;或者直接調用OSCtxSW()函數,這里我們采用后者(OSCtxSW()函數的實現將在后面介紹):

定義OS_TASK_SW()宏
定義OS_TASK_SW()宏

3.2處理器相關部分匯編實現

  μC/OS-Ⅱ的移植需要用戶編寫三個最基本的匯編語言函數:OSStartHighRdy(),OSCtxSw(),OSIntCtxSw()。它們會共用一些代碼,為了方便閱讀將它們寫在同一個匯編文件os_cpu_a.S中。

  3.2.1 OSStartHighRdy():運行優先級最高的就緒任務。

  OSStartHighRdy()函數是在OSStart()多任務啟動之后,負責從最高優先級任務的TCB控制塊中獲得該任務的堆棧指針SP,并通過SP恢復CPU現場以啟動最高優先級的任務執行。另外OSStartHighRdy()還必須在最高優先級任務恢復之前和調用OSTaskSwHook()之后設置OSRunning為TRUE.其實現代碼如下:

運行優先級最高的就緒任務
運行優先級最高的就緒任務

 3.2.2 OSCtxSw()和OSIntCtxSw()

  OSCtxSw()是任務優先級切換函數,它的作用是先將當前任務的CPU現場保存到該任務的堆棧中,然后獲得最高優先級任務的堆棧指針,并從該堆棧中恢復此任務的CPU現場,使之繼續執行,該函數就完成了一次任務切換。

  OSIntCtxSw()是中斷級的任務切換函數。由于中斷可能會使更高優先級的任務進入就緒態,因此為了讓更高優先級的任務能立即運行,在中斷服務子程序最后會調用OSIntCtxSw()做任務切換。這樣做能夠盡快的讓高優先級的任務得到相應的處理,保證系統的實時性能。

  OSCtxSw()和OSIntCtxSw()都是用于任務切換的函數,其區別在于,在OSIntCtxSw()中無需再保存處理器寄存器,因為在OSIntCtxSw()之前已發生中斷,所以可以保證所有的處理器寄存器都被正確地保存到了被中斷的任務的堆棧之中。OSCtxSw()和OSIntCtxSw()實現代碼如下:

OSCtxSw()和OSIntCtxSw()實現代碼
OSCtxSw()和OSIntCtxSw()實現代碼

  N1033A-S處理器定義了四級(0-3)中斷,在各級中斷的轉換時需要保存當前中斷層級的寄存器。調用OSCtxSw()時,中斷將由0級(即沒有中斷)轉到1級,所以需要將第0級的寄存器PSW和PC保存到第1級的寄存器IPSW和IPC中。CtxSave和CtxRestore兩個宏用來保存和恢復任務上下文。需要保存或恢復的寄存器包括32個通用寄存器(R0-R31)的值、程序計數器(PC)的值以及處理器狀態字寄存器(PSW)的值。宏IntlSwitch n通過修改PSW.INIT的值來切換中斷層級。CtxSave和IntlSwitch的匯編實現如下(由于CtxRestore與CtxSave過程類似,這里不做贅述):

CtxSave和IntlSwitch的匯編實現
CtxSave和IntlSwitch的匯編實現

  3.3 移植C語言編寫的幾個與操作系統相關的函數

  μC/OS-Ⅱ有六個與CPU相關的函數:OSTaskStkInit()、OSTaskCreateHook()、OSTaskDelHook()、OSTaskSwHook()、OSTaskStatHook()、OSTimeTickHook(),它們被定義在ucos_ii.h中。其中唯一必須移植的函數是任務堆棧初始化函數OSTaskStkInit(),其它五個函數必須得聲明但沒必要包含代碼。因此這里我們只介紹OSTaskStkInit(),其代碼的實現如下:

OSTaskStkInit()代碼的實現
OSTaskStkInit()代碼的實現

 OSTaskStkInit()在任務創建時被調用,負責初始化任務的堆棧結構并返回新堆棧的指針,使得堆棧看起來就像剛發生過中斷并將所有的寄存器保存到堆棧中的情形一樣。除了要保存任務的地址、變量的指針以及處理器狀態字的值外,Andes N1033A-S處理器還要求用戶保存所有32個通用寄存器(R0-R31)、四個用戶寄存器(d0.hi, d0.lo, d1.hi, d1.lo)。還有一點需要注意,在N1033A-S處理器中,堆棧指針的地址必須滿足8Byte對齊,程序最后一段邏輯即將堆棧指針調整到正確的位置,這一點在編寫其他代碼例如在宏CtxSave中同樣需要注意。

  4. 結語

  基于AndesStar架構的優勢,可以很容易的實現μC/OS-Ⅱ在N1033A-S處理器上的移植。不僅μC/OS-Ⅱ,其它嵌入式操作系統也可以很方便地移植到AndesCore相應的處理器上,例如Nuclues、FreeRTOS以及Contiki。

  晶心科技利用 AndesCore N1033A-S高效能的 Audio ISA 和 FPGA開發平臺彈性的設計架構,基于各種RTOS,為客戶提供了的豐富的軟件資源(中間件、優化的函數庫、應用實例等)以及完整的多媒體語音解決方案,從而幫助客戶更快地在Andes平臺上進行產品開發。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久蜜桃香蕉精品一区二区三区| 欧美日韩精品免费观看| a91a精品视频在线观看| 91久久精品国产91久久性色| 欧美在线视频全部完| 亚洲欧美在线免费观看| 亚洲午夜女主播在线直播| 9色porny自拍视频一区二区| 日韩亚洲不卡在线| 日韩视频免费观看| 亚洲精品一二| 亚洲巨乳在线| aa亚洲婷婷| 亚洲一级影院| 午夜精品久久久久久久99热浪潮| 亚洲欧美日韩国产中文 | 夜久久久久久| 亚洲天堂激情| 欧美一级精品大片| 久久精品夜色噜噜亚洲aⅴ| 亚洲第一免费播放区| 91久久久久久久久| 亚洲毛片av在线| 亚洲天堂视频在线观看| 亚洲欧美日韩精品久久奇米色影视| 亚洲欧美资源在线| 久久九九久精品国产免费直播 | 国产精品久久久久高潮| 国产精品乱人伦一区二区| 国产亚洲精品久久飘花| 精品福利电影| 亚洲精品无人区| 亚洲欧美日韩在线综合| 久久精品一二三| 亚洲美女中出| 午夜精品国产更新| 久久中文精品| 欧美日韩亚洲系列| 国产欧美在线播放| 欧美日韩精品一区二区三区四区| 欧美激情片在线观看| 亚洲午夜一区二区三区| 亚洲视频大全| 欧美一区二区三区在线免费观看 | 欧美区在线播放| 国产精品国产自产拍高清av王其| 国产精品一区二区你懂得 | 国产精品嫩草影院一区二区| 国产在线精品自拍| 亚洲人成高清| 亚洲自拍偷拍麻豆| 亚洲精品国产精品乱码不99| 亚洲一区黄色| 久色成人在线| 国产精品va在线播放| 国产专区欧美精品| 亚洲欧洲在线免费| 性欧美videos另类喷潮| 日韩亚洲精品电影| 久久精品国产精品亚洲综合| 欧美日韩大片| 国产一区二区三区观看| 亚洲美女淫视频| 久久se精品一区精品二区| 国产精品99久久久久久久久| 久久九九精品| 国产精品成人播放| 亚洲国产精品毛片| 欧美一区二区| 亚洲素人在线| 欧美国产日韩一区| 国产一区二区观看| 一区二区免费在线观看| 亚洲精品美女在线| 久久久久成人精品| 国产精品久久久久久模特 | 欧美日韩国产美女| 精品96久久久久久中文字幕无| 一区二区三区四区国产精品| 亚洲国产va精品久久久不卡综合| 亚洲男人影院| 欧美日韩不卡合集视频| 在线成人免费视频| 欧美在线播放一区二区| 亚洲影音一区| 欧美久久久久| 亚洲福利视频免费观看| 久久av一区二区三区漫画| 亚洲欧美在线高清| 欧美日韩视频在线第一区| 亚洲国产精品成人一区二区 | 欧美在线首页| 欧美亚洲一区二区在线| 欧美日韩免费一区二区三区| 亚洲风情在线资源站| 欧美伊人影院| 欧美在线观看www| 国产精品久久999| 9久re热视频在线精品| 亚洲美女毛片| 欧美国产激情二区三区| 韩国av一区二区三区在线观看| 亚洲欧美日本国产有色| 亚洲欧美在线看| 国产精品久久久久久妇女6080 | 欧美一区二区三区免费在线看| 欧美日韩精品在线播放| 亚洲欧洲日产国产网站| 亚洲精品日韩综合观看成人91| 另类av导航| 黄色一区二区在线| 久久精彩免费视频| 久久精品五月婷婷| 国产一区二区三区四区hd| 欧美一区二区三区喷汁尤物| 欧美在线网址| 国产午夜精品福利| 欧美一区2区视频在线观看 | 亚洲性av在线| 亚洲欧美成人在线| 国产精品国产精品| 亚洲欧美久久久| 久久精品72免费观看| 国内外成人免费激情在线视频 | 欧美一区高清| 国产一区二区精品| 欧美专区福利在线| 牛牛精品成人免费视频| 亚洲国产激情| 一区二区欧美视频| 国产精品国产| 欧美亚洲午夜视频在线观看| 欧美一区午夜视频在线观看| 国产一区二区三区免费观看| 亚洲国产精品va在线看黑人动漫| 欧美成人久久| 99re热精品| 欧美一级夜夜爽| 韩国三级在线一区| 亚洲美洲欧洲综合国产一区| 欧美日韩一区二区国产| 亚洲一区二区精品视频| 久久久久久久国产| 在线精品国产成人综合| 99视频一区| 国产精品无人区| 亚洲第一区在线| 欧美精品在线观看一区二区| 亚洲美女啪啪| 欧美一区二区久久久| 在线观看精品一区| 一本久久综合亚洲鲁鲁| 国产精品久久久久久久7电影| 欧美一区视频在线| 欧美高清视频一区二区| 亚洲午夜国产成人av电影男同| 久久国产手机看片| 91久久国产综合久久91精品网站 | 午夜精品久久久| 精品成人国产在线观看男人呻吟| av成人动漫| 国产视频一区欧美| 亚洲免费观看高清在线观看| 国产精品乱码妇女bbbb| 久久精品99国产精品日本| 欧美精品自拍偷拍动漫精品| 亚洲欧美国产精品va在线观看| 一区二区三区精品| 国产日韩欧美高清| 日韩视频一区二区在线观看| 国产精品视频大全| 91久久嫩草影院一区二区| 欧美日韩mv| 久久经典综合| 国产精品国色综合久久| 亚洲激情视频在线播放| 国产精品美女在线观看| 亚洲巨乳在线| 国产亚洲精品久久久久婷婷瑜伽| 一本色道久久综合亚洲精品小说| 国产老女人精品毛片久久| 亚洲美女精品久久| 国产一二三精品| 亚洲视频你懂的| 国内成人精品一区| 亚洲男人的天堂在线观看| 在线日韩av永久免费观看| 先锋影院在线亚洲| 亚洲区一区二| 在线一区二区三区四区五区| 午夜精品久久久久久久99樱桃 | 影音先锋在线一区| 亚洲欧美卡通另类91av| 亚洲国产91| 久久国产一二区| 一本色道久久加勒比88综合| 欧美大胆a视频| 亚洲成人在线视频播放| 欧美国产日韩一区二区| 午夜在线不卡|