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

uCOS II在ARM處理器上移植過程中的中斷處理

發布時間:2010-11-4 20:56    發布者:techshare
關鍵詞: arm , ucos , 處理器 , 移植 , 中斷
uCOS II是一個源碼公開、可移植、可固化、可剪裁和搶占式的實時多任務操作系統,其大部分源碼是用ANSI C編寫,與處理器硬件相關的部分使用匯編語言編寫。總量約200行的匯編語言部分被壓縮到最低限度,以便于移植到任何一種其它的CPU上。

uCOS II最多可支持56個任務,其內核為占先式,總是執行就緒態的優先級最高的任務,并支持Semaphore (信號量)、Mailbox (郵箱)、MessageQueue(消息隊列)等多種常用的進程間通信機制。與大多商用RTOS不同的是,uCOS II公開所有的源代碼.并可以免費獲得,只對商業應用收取少量License費用。

uCOS II移植跟OS_CUP_C.C、OS_CPU_A.S、OS_CPU.H 3個文件有關,中斷處理的移植占據了很大一部分內容。作為移植的一個重點,本文以標準中斷(IRQ)為例討論了移植中的中斷處理。

1 uCOS II系統結構

uCOS II的軟硬件體系結構如圖1。應用程序處于整個系統的頂層.每個任務都可以認為自己獨占了CPU,因而可以設計成為一個無限循環。大部分代碼是使用ANSI C語言書寫的,因此uCOS II的可移植性較好。盡管如此,仍然需要使用C和匯編語言寫一些處理器相關的代碼。uCOS II的移植需要滿足以下要求:

1)處理器的C編譯器可以產生可重入代碼:可以使用C調用進入和退出Critical Code(臨界區代碼);

2)處理器必須支持硬件中斷,并且需要一個定時中斷源;

3)處理器需能容納一定數據的硬件堆棧;

4)處理器需有能在CPU寄存器與內存和堆棧交換數據的指令。

移植uCOS II的主要工作就是處理器和編譯器相關代碼以及BSP(Board Support Package)的編寫。uCOS II處理器無關的代碼提供uCOS II的系統服務,應用程序可以使用這些API函數進行內存管理、任務間通信以及創建、刪除任務等。

2 uCOS II移植過程中需要注意的幾個問題

uCOS II移植的中斷處理跟ARM體系結構和uCOS II處理中斷的過程有關,必須注意這2個方面的問題才能高效移植。

2.1 ARM 處理器7種操作模式

用戶模式(USER MODE)是ARM 通常執行狀態,用于執行大多數應用程序;快速中斷模式(FIQ MODE)支持數據傳輸或通道處理;中斷模式(IRQ MODE)用于通用中斷處理;超級用戶模式(SVC MODE)是一種操作系統受保護的模式:數據中止模式(ABT MODE)指令預取指中止、數據中止時進入該模式;未定義模式(UND MODE)當執行未定義的指令時進入該模式;系統模式(SYS MODE)是操作系統一種特許的用戶模式。

除了用戶模式之外,其他模式都歸為特權模式,特權模式用于中斷服務、異常或者訪問受保護的資源。

特權模式中除系統模式之外另5種模式又稱為異常模式,在移植過程中必須設置中斷向量表來處理異常。uCOS II的移植主要處理標準中斷(IRQ)、快速中斷(FIQ)和軟件中斷(SWI)。

2.2 uCOS II中斷響應的過程

以IRQ中斷為例,假設CRPS中I_bit位為0,當有IRQ中斷時,CPU強制進入IRQ模式,當前的CPSR拷貝到SPSR_irq中,PC值保存在LR_irq中,置CPSR中的I位以關閉IRQ中斷。數據保存之后,CPU強行從0X00000018開始執行,PC值保存了OS_CPU_IRQ_ISR()的地址, 然后執行OS_CPU_IRQ_ISR()。在OS_CPU_IRQ_ISR()中OS_CPU_IRQ_ISR_Handler()被調用來檢測中斷源并執行中斷。OS_CPU_IRQ_ISR_Handler()返回以后,OS_CPU_IRQ_ISR()又調用OSIntExit()來確認是否有比ISR優先級更高的任務要執行。如果當前中斷任務仍然是優先級最高的任務,OSIntExit()返回,OS_CPU_IRQ_ISR()彈出中斷堆棧,如果優先級更高的任務需要執行,OSIntExit()調用OSIntCtxSw()執行優先級更高的任務。

2.3 uCOS II的臨界段代碼

uCOS II使用關中斷來保護臨界代碼。它定義了2個宏來開中斷(OS_EXIT_CRITICAL()),關中斷(OS_ENTER_CRITICAL())。OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()有3種方法來實現,uCOS II建議使用第3種方法可以保存當前處理器狀態的值。

3 uCOS II移植過程中的中斷處理

uCOS II中斷處理跟CRT.S、OS_CPU_A.S和BSP.C有關,其移植過程主要有以下幾個步驟。

3.1 在CRT.S中設置中斷向量表

ARM的中斷向量表位于ROM 的最底部,其地址范圍為0X00000000~0X0000001C,設置如下:

VECTORS:LDR PC,RESET_ADDR

LDR PC,UNDEF_ADDR

LDR PC,SWI_ADDR

LDR PC,PABT_ADDR

LDR PC,DABT_ADDR

NOP /*保留向量*/

LDR PC,IRQ_ADDR

LDR PC,FIQ_ADDR

RESET_ADDR:. WORD RESET_HANDLER

UNDEF_ADDR:.WORD UNDEF—HANDLER

SWI_ADDR:.WORD SWI HANDLER

PABT_ADDR:.WORD PABT_HANDLER

DABT_ADDR:.WORD DABT_ HANDLER

.WORD 0 /*保留地址*/

IRQ_ADDR:.WORD IRQ_HANDLER

FIQ_ADDR:.WORD FIQ HANDLER

UNDEF_HANDLER:B UNDEF_HANDLER

SWI_HANDLER: B SWI_HANDLER

PABT_HANDLER: B PABT_HANDLER

DABT_HANDLER: B DABT_HANDLER

IRQ_HANDLER: B OS_CPU_IRQ_ISR

/*跳轉到OS_CPU_IRQ_ISR(在OS_CPU_A.S中)*/

FIQ_HANDLER: B OS_CPU_FIQ_ISR

/*跳轉到OS_CPU_FIQ_ISR(在OS_CPU_A.S中) */

這里設置了標準中斷異常(IRQ)和快速中斷異常(FIQ)的中斷入口,其余異常都設置為死循環,當發生這些異常的時候,必須使系統復位才能退出死循環。

3.2 移植中斷任務切換

中斷任務切換(OSIntCtxSw)和任務切換函數(OSCtxSw)比較相似,主要有以下幾步組成:

1)調用OSTask SwHook()

2)OSPrioCur=OSPrioHighRdy

3)OSTCBCur=OSTCBHighRdy

4)SP=OSTCBHighRdy->OSTCBStkPtr

//獲取高優先級的任務堆棧指針

5)從高優先級的任務的堆棧中彈出高優先級的任務上下文

6)執行高優先級的任務

3.3 移植中斷服務程序

以IRQ中斷為例中斷服務程序(OS_CPU_IRQ_ISR)主要依據上面所描述的“uCOS II中斷響應的過程”編寫,其主要代碼如下:

……

LDR R0,OS_IntNesting

LDRB R1,[R0]

ADD R1,R1,#1

STRB R1,[R0]

CMP R1,#l

BNE OS_CPU_IRQ_ISR_1

LDR R4,OS_TCBCur

LDR R5,[R4]

STR SP,[R5]

OS_CPU_IRQ_ISR_1:

MSR CPSR_c,#(NO_INT | IRQ32_MODE)

//切換到SVC模式

LDR R0,OS_CPU_IRQ_ISR_Handler

MOV LR,PC

BX R0

MSR CPSR_c,#(NO_INT | SVC32_MODE)

//切換到SVC模式

LDRR0,OS_IntExit //OSIntExit()

MOV LR,PC

BX R0

……

在代碼中省略了現場工作寄存器的保護與恢復及工作模式的切換。

3.4 移植中斷處理程序

以IRQ中斷為例,移植中斷處理程序:

C程序

void OS_CPU_IRQ_ISR_Handler(void)
{
    PFNCT pfnct; //定義中斷函數指針
    pfnct=(PFNCT)VICVectAddr; //獲取函數地址
    while(pfnct!=(PFNCT)0)
    {
        (*pfnct)(); //調用中斷函數
        pfnct=(PFNCT)VICVectAddr; //獲取新的中斷函數
    } //所有中斷都執行完畢退出
}

中斷處理程序依賴中斷控制器的中斷響應順序,所以uCOS II把OS_CPU_IRQ_ISR_Handler()歸屬于用戶程序的一部分。在中斷返回之前,中斷處理程序要處理完所有的中斷響應,以避免在多個中斷同時響應或中斷處理過程中響應中斷的情況下, 進入OS_CPU_IRQ_ISR () 和退出OS_CPU_IRQ_ISR()時,OS_CPU_IRQ_ISR()耗盡保存CPU寄存器的堆棧空間。

另外,在OS_CPU_IRQ_ISR_Handler()中不要清CPSR的I位來開放中斷,因為沒有必要使用中斷嵌套,OS_CPU_IRQ_ISR_Handler()在返回之前會檢查并處理所有的中斷。

3.5 編寫中斷函數

中斷函數一般采用C語言編寫,uCOS II建議中斷函數應盡量短,一般做法是在中斷函數中緩存數據,給任務發送一個信號來處理數據。中斷函數的地址在系統初始化的時候要置人中斷向量寄存器(VICVectAddr0~15)。由于向量中斷控制器(VIC)的特殊結構,在中斷函數中要寫一次中斷向量寄存器(VICV

ectAddr)。

4 中斷處理的應用示例

uCOS II要提供周期性信號源,用于實現時間延時和確認超時。節拍率應為10~100 Hz。時鐘節拍源可以由專門的硬件定時器產生,以下就以IRQ中斷方式產生節拍源為示例。

初始化中斷控制器:

C程序

void VICInit(void)
{
    VICIntEnClr=0xfffff;
    VICDefVectAddr=-(INT32U)Non_Vect_IRQ_Handler;
    VICVectAddr0= (INT32U)OSTickISR;
    VICVectCntl0= (0x20 | 0x04);
    VICIntEnable= 1<<4;
}

定時器0中斷函數:

C程序

void OSTickISR(void)
{
    TO_IR = 0xff;
    OSTimeTick(); //調用OSTimeTick()
    VICVectAddr=0; //通知中斷控制器中斷結束
}

當定時中斷發生時調用OS_CPU_IRQ_ISR Handler(),得到OSTickISR()的地址并執行,在OSTickISR()中調用OSTimeTick()為uCOS II提供周期性信號源。

此代碼在GNU工具鏈ARM-GCC下編譯通過,并在EasyARM2100開發實驗板上得到驗證。

5 結束語

通過示例講述了在uCOS II移植過程中的中斷處理所需要注意的幾個問題和通用方法,經筆者在GNU工具鏈下編譯、調試,并在實驗板上得到很好的驗證。這種移植方案的中斷函數都使用C語言編寫,具有較好的移植性,有利于對不同需求的用戶進行中斷擴充,增強了中斷嵌套時uCOS II運行的穩定性,使移植具有更好的通用性。
本文地址:http://m.qingdxww.cn/thread-36458-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 使用SAM-IoT Wx v2開發板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿澤電子(Mouser)專區

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产日韩精品视频一区二区三区 | 99re最新视频| 国产在线成人一区二区 | 色综合久久久久久 | 91免费精品国自产拍在线可以看 | 午夜性a一级毛片 | 99精品视频在线成人精彩视频 | 中文国产成人精品久久久 | 亚洲精品国产福利 | 亚洲 欧美 自拍 明星合成 | 亚洲欧美成aⅴ人在线观看 亚洲欧美不卡 | 欧美理论大片清免费观看 | 成人久久18网站 | 欧美一级视频在线高清观看 | 向日葵app在线观看 向日葵app看片视频在线观看 | 色玖玖| 国产亚洲一区二区三区 | h色视频在线 | 亚洲视频一区在线观看 | 2021国产精品视频一区 | 曰本亚洲欧洲色a在线 | 欧美一级黄色片在线观看 | 亚洲欧美日本欧美在线播放污 | 免费看国产黄色片 | 国产馆在线观看免费的 | 国产小视频在线免费观看 | 免费视频一区二区三区四区 | 天天摸天天摸色综合舒服网 | 正在播放91大神调教偷偷 | 赌侠1999 | www.99色| 日韩精品亚洲专区在线观看 | 国产欧美一区二区 | 日韩剧情片| 国产乱了真实在线观看 | 四虎网站入口 | 国产在线观看不卡免费高清 | 欧美亚洲国产成人综合在线 | 亚洲精品一二区 | 黄色片视频网站 | 欧美成人动漫在线观看 |