国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

在AndesCore N1033A-S處理器實(shí)現(xiàn)μC/OS-II的移植

發(fā)布時(shí)間:2012-3-16 10:57    發(fā)布者:eechina
關(guān)鍵詞: AndesCore , N1033A-S , 處理器 , 移植
μC/OS-II是一種代碼公開、可裁剪的嵌入式實(shí)時(shí)多任務(wù)操作系統(tǒng)。該內(nèi)核通過實(shí)現(xiàn)搶占式任務(wù)調(diào)度算法和多任務(wù)間通信等功能,使之具有執(zhí)行效率高、實(shí)時(shí)性能優(yōu)良等特點(diǎn)。另外,其占用空間非常小(最小可裁剪至2KB)并且具有高度可移植性,因此被廣泛的應(yīng)用于微處理器和微控制器上。

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

1. 開發(fā)環(huán)境及處理器介紹

1.1 軟/硬件開發(fā)環(huán)境

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

AndesCore N1033A-S介紹

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

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

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

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

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

3. 移植步驟

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

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

3.1.1. 定義與處理器相關(guān)的數(shù)據(jù)類型

為保證可移植性,μC/OS-II沒有直接使用C語言中的short、int和long等數(shù)據(jù)類型的定義,因?yàn)椴煌奶幚砥饔胁煌淖珠L(zhǎng)。對(duì)于N1033A-S這樣的32位處理器,其數(shù)據(jù)類型定義實(shí)現(xiàn)如下:



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

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



GIE_SAVE 和GIE_RESTORE的實(shí)現(xiàn)如下:



中斷禁止時(shí)間是判斷系統(tǒng)實(shí)時(shí)性的重要指標(biāo)之一。中斷禁止時(shí)間能否達(dá)到最短,不僅與操作系統(tǒng)的設(shè)計(jì)有關(guān),還依賴于處理器結(jié)構(gòu)和編譯器產(chǎn)生的代碼質(zhì)量。從上面的實(shí)現(xiàn)代碼看到,由于Andes處理器提供了setgie.d和setgie.e兩條直接控制中斷的開關(guān)的指令,整個(gè)禁止/允許中斷的過程經(jīng)過編譯器產(chǎn)生的機(jī)器碼只有3/2條,最大限度地減小了中斷禁止時(shí)間。

3.1.3. 定義棧增長(zhǎng)方向

μC/OS-II使用結(jié)構(gòu)常量OS_STK_GROWTH來指定堆棧的增長(zhǎng)方式,設(shè)置為0表示堆棧從下往上增長(zhǎng),設(shè)置為1表示從上往下增長(zhǎng)。這里我們定義成后者,即堆棧的增長(zhǎng)方向是從內(nèi)存高地址向低地址方向遞減并且堆棧指針總是指向棧頂數(shù)據(jù):



3.1.4.定義OS_TASK_SW()宏

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



3.2 處理器相關(guān)部分匯編實(shí)現(xiàn)

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

3.2.1 OSStartHighRdy():運(yùn)行優(yōu)先級(jí)最高的就緒任務(wù)。

OSStartHighRdy()函數(shù)是在OSStart()多任務(wù)啟動(dòng)之后,負(fù)責(zé)從最高優(yōu)先級(jí)任務(wù)的TCB控制塊中獲得該任務(wù)的堆棧指針SP,并通過SP恢復(fù)CPU現(xiàn)場(chǎng)以啟動(dòng)最高優(yōu)先級(jí)的任務(wù)執(zhí)行。另外OSStartHighRdy()還必須在最高優(yōu)先級(jí)任務(wù)恢復(fù)之前和調(diào)用OSTaskSwHook()之后設(shè)置OSRunning為TRUE.其實(shí)現(xiàn)代碼如下:



3.2.2 OSCtxSw()和OSIntCtxSw()

OSCtxSw()是任務(wù)優(yōu)先級(jí)切換函數(shù),它的作用是先將當(dāng)前任務(wù)的CPU現(xiàn)場(chǎng)保存到該任務(wù)的堆棧中,然后獲得最高優(yōu)先級(jí)任務(wù)的堆棧指針,并從該堆棧中恢復(fù)此任務(wù)的CPU現(xiàn)場(chǎng),使之繼續(xù)執(zhí)行,該函數(shù)就完成了一次任務(wù)切換。

OSIntCtxSw()是中斷級(jí)的任務(wù)切換函數(shù)。由于中斷可能會(huì)使更高優(yōu)先級(jí)的任務(wù)進(jìn)入就緒態(tài),因此為了讓更高優(yōu)先級(jí)的任務(wù)能立即運(yùn)行,在中斷服務(wù)子程序最后會(huì)調(diào)用OSIntCtxSw()做任務(wù)切換。這樣做能夠盡快的讓高優(yōu)先級(jí)的任務(wù)得到相應(yīng)的處理,保證系統(tǒng)的實(shí)時(shí)性能。

OSCtxSw()和OSIntCtxSw()都是用于任務(wù)切換的函數(shù),其區(qū)別在于,在OSIntCtxSw()中無需再保存處理器寄存器,因?yàn)樵贠SIntCtxSw()之前已發(fā)生中斷,所以可以保證所有的處理器寄存器都被正確地保存到了被中斷的任務(wù)的堆棧之中。OSCtxSw()和OSIntCtxSw()實(shí)現(xiàn)代碼如下:




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



  
3.3 移植C語言編寫的幾個(gè)與操作系統(tǒng)相關(guān)的函數(shù)

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



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

4. 結(jié)語

基于AndesStar?架構(gòu)的優(yōu)勢(shì),可以很容易的實(shí)現(xiàn)μC/OS-Ⅱ在N1033A-S處理器上的移植。不僅μC/OS-Ⅱ,其它嵌入式操作系統(tǒng)也可以很方便地移植到AndesCore?相應(yīng)的處理器上,例如Nuclues、FreeRTOS以及Contiki。

晶心科技利用 AndesCore? N1033A-S高效能的 Audio ISA 和 FPGA開發(fā)平臺(tái)彈性的設(shè)計(jì)架構(gòu),基于各種RTOS,為客戶提供了的豐富的軟件資源(中間件、優(yōu)化的函數(shù)庫(kù)、應(yīng)用實(shí)例等)以及完整的多媒體語音解決方案,從而幫助客戶更快地在Andes平臺(tái)上進(jìn)行產(chǎn)品開發(fā)。
本文地址:http://m.qingdxww.cn/thread-87358-1-1.html     【打印本頁(yè)】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點(diǎn)和對(duì)其真實(shí)性負(fù)責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時(shí)間更正或刪除。
您需要登錄后才可以發(fā)表評(píng)論 登錄 | 立即注冊(cè)

廠商推薦

  • Microchip視頻專區(qū)
  • 使用SAM-IoT Wx v2開發(fā)板演示AWS IoT Core應(yīng)用程序
  • 使用Harmony3加速TCP/IP應(yīng)用的開發(fā)培訓(xùn)教程
  • 集成高級(jí)模擬外設(shè)的PIC18F-Q71家族介紹培訓(xùn)教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號(hào) | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 日日操美女 | 在线观看一级毛片免费 | 毛片免费全部完整播放 | 亚洲欧美日韩国产精品一区 | 99在线免费视频 | 成年人在线观看网站 | 亚洲网在线观看 | 国产一区精品在线观看 | 偷偷狠狠的日日高清完整视频 | 99热在线精品免费播放6 | 免费欧美 | 啊嗯啊羞羞网站在线观看 | 青青青青爽极品在线视频 | ww.久久 | 日本在线视频一区 | 香蕉网在线观看 | 国产区高清 | 日韩欧美一区二区三区中文精品 | 成人欧美一区二区三区黑人妖 | 印度最猛性ⅹxxxxx | 黄到女生下面湿的文章 | 亚洲国产成人精品不卡青青草原 | 色综久久天天综合绕视看 | 最新69国产成人精品视频69 | 狠狠色丁香婷婷综合久久来 | 国内自拍经典三级在线 | 欧美vs日韩vs国产在线观看 | 伊人青| 欧美91精品久久久久网免费 | 伊人青青草 | 亚洲视频在线观 | 国产特级毛片aaaaaaa高清 | 中文字幕一区二区在线视频 | 91小视频app 91香蕉在线看私人影院 | 亚洲国产婷婷香蕉久久久久久 | 欧美亚洲国产精品久久蜜芽 | 毛片免费全部完整播放 | 国产欧美一区二区三区观看 | 爽好舒服宝贝添奶吻戏 | 国产剧情自拍 | 女老师在线播放 |