時間:2008-09-01 10:54:00來源:ronggang
圖2 MPC860的中斷處理流程[/align]
4 中斷處理應(yīng)用編程
實際中斷處理應(yīng)用編程主要包括兩部分工作:一是編寫中斷初始化程序,進(jìn)行初始化和中斷連接;二是編寫中斷服務(wù)程序完成中斷服務(wù)功能。
4.1 編寫中斷初始化程序
中斷初始化程序的首要工作是初始化中斷寄存器,包括打開SIU中斷屏蔽寄存器(SIMASK,SIU Interrupt Mask)對應(yīng)的屏蔽位,使能外部中斷。如果是SIU的外部中斷,應(yīng)該初始化SIU中斷邊沿/電平寄存器(SIEL,SIU Interrupt Edge/Level Register),以設(shè)定中斷是下降沿觸發(fā)還是低電平觸發(fā)。如果使用了CPM中斷,還應(yīng)該初始化CPM中斷配置寄存器(CICR,CPM Interrupt Configuration Register)和CPM中斷屏蔽寄存器(CIMR,CPM Interrupt Mask Register),以設(shè)定CPM在SIU中斷控制器中的中斷優(yōu)先級,以及其內(nèi)部的最高優(yōu)先級中斷源。對于子塊可屏蔽中斷源,還應(yīng)該打開對應(yīng)的事件屏蔽寄存器。
中斷初始化程序還必須把SIU中斷服務(wù)程序放到正確的位置。在VxWorks環(huán)境下調(diào)用intConnect()函數(shù)即將中斷服務(wù)程序與外部中斷源連接起來。
4.2 編寫中斷服務(wù)程序
由于中斷服務(wù)程序不是在規(guī)則的任務(wù)上下文中運(yùn)行(它沒有任務(wù)控制塊,中斷處理程序共享一個堆棧等),中斷服務(wù)程序必須遵守一個基本約束:它必須不能調(diào)用可能直接或間接導(dǎo)致阻塞的函數(shù)。例如,ISR不能獲取信號量,但可以釋放信號量;ISR不能直接或間接調(diào)用內(nèi)存操作函數(shù)malloc()和free();ISR不能通過VxWorks驅(qū)動來執(zhí)行I/O操作,但VxWorks的管道驅(qū)動程序是一個例外;ISR也不能使用printf()進(jìn)行打印,VxWorks專門為ISR打印信息設(shè)計了一個記錄功能,允許向系統(tǒng)輸出平臺打印文本信息。具體能被中斷服務(wù)程序調(diào)用的函數(shù)請參見參考文獻(xiàn)[5]。
由于中斷服務(wù)通常涉及到任務(wù)級代碼,并且中斷服務(wù)程序受到種種限制,VxWorks支持在中斷級運(yùn)行的中斷服務(wù)程序直接與一般任務(wù)進(jìn)行通信。其通信機(jī)制有共享數(shù)據(jù)結(jié)構(gòu)、信號量、消息隊列、管道、信號等。其中,信號量是VxWorks提高中斷服務(wù)程序與任務(wù)的合作性能的最好機(jī)制。理想情況下,一個中斷服務(wù)程序僅僅調(diào)用semGive()函數(shù)釋放一個信號量,發(fā)起一個任務(wù)來完成必要的處理[6]。
5 中斷處理應(yīng)用實例
下面給出VxWorks下MPC860的中斷處理的應(yīng)用實例。我們在某項目開發(fā)中利用中斷通知MPC860讀取外圍器件FIFO的數(shù)據(jù)。相關(guān)的硬件連接如圖3所示。
[align=center]
圖3 中斷處理應(yīng)用實例的硬件連接[/align]
其中,F(xiàn)IFO采用IDT公司的IDT72V3650芯片,F(xiàn)PGA采用ALTERA公司APEX20K系列的EP20K1500E器件。FIFO芯片提供了五個空滿狀態(tài)標(biāo)志位,可根據(jù)不同的實際需求方便的通過FPGA編程向MPC860的IRQ2和IRQ1分別發(fā)送開始讀信號和停止讀信號,從而在時鐘的驅(qū)動下讀取FIFO數(shù)據(jù)。
中斷應(yīng)用程序的主要實現(xiàn)函數(shù)的代碼及注釋如下:
/***初始化,中斷連接***/
void tRdFifoInit(void)
。
。猄IEL(RegBase)|=0x28000000; /*設(shè)置外部中斷源IRQ1、IRQ2下降沿觸發(fā)*/
startSem=semBCreate(SEM_Q_FIFO,SEM_EMPTY);
/*創(chuàng)建二進(jìn)制信號量,以便實現(xiàn)中斷與任務(wù)的通信*/
intConnect(IV_IRQ1,(VOIDFUNCPTR)stopRdISR,NULL);
intConnect(IV_IRQ2,(VOIDFUNCPTR)startRdISR,NULL);
/*分別將外部中斷源與中斷服務(wù)程序相連接*/
intEnable(IVEC_TO_INUM(IV_IRQ1)); intEnable(IVEC_TO_INUM(IV_IRQ2));
/*分別使能外部中斷*/
}
/***開始讀FIFO中斷服務(wù)程序***/
void startRdISR(void)
。
semGive(startSem);
/*釋放信號量*/
RdFlag=1;
/*設(shè)置讀FIFO數(shù)據(jù)標(biāo)志*/
。猄IPEND(RegBase)=0x08000000;
/*清除外部中斷源IRQ2的狀態(tài)位*/
。
/***停止讀FIFO中斷服務(wù)程序***/
void stopRdISR(void)
{
RdFlag=0;
/*禁止讀FIFO數(shù)據(jù)標(biāo)志*/
。猄IPEND(RegBase)=0x20000000;
/*清除外部中斷源IRQ1的狀態(tài)位*/
。
/***按照中斷通知讀取FIFO數(shù)據(jù)***/
void tRdFifo(void)
{
while(1)
。
semTake(startSem,WAIT_FOREVER);
/*獲取信號量*/
while(RdFlag)
{
…/*讀取FIFO數(shù)據(jù)*/
。
。
。
6 結(jié)束語
嵌入式實時操作系統(tǒng)VxWorks提供的中斷處理機(jī)制中斷延遲小、用戶編程方便,被廣泛應(yīng)用于實際工程中。MPC860的中斷體系結(jié)構(gòu)是理解如PowerPC系列芯片等雙處理器體系結(jié)構(gòu)的中斷處理機(jī)制的難點(diǎn)。本文在詳細(xì)分析兩者中斷處理機(jī)制的基礎(chǔ)上介紹了具體的開發(fā)實例。該實例已在TornadoⅡ 2.0.2版本上調(diào)試通過,并成功應(yīng)用于某型網(wǎng)絡(luò)設(shè)備開發(fā)中。
參考文獻(xiàn)
[1] 陳智育,溫彥軍,陳琪. VxWorks程序開發(fā)實踐[M]. 北京:人民郵電出版社,2004.
[2] 羅國慶. VxWorks與嵌入式軟件開發(fā)[M]. 北京:機(jī)械工業(yè)出版社,2003.
[3] Wind River. VxWorks Reference Manual: Libraries[OL].
[4] Motorola. MPC860 PowerQuicc Family User’s Manual[Z]. Motorola, 2003.
[5] Wind River. VxWorks Programmer’s Guide 5.5[OL].
[6] 孔祥營,柏桂枝. 嵌入式實時操作系統(tǒng)VxWorks及其開發(fā)環(huán)境Tornado[M]. 北京中國電力出版社,2002.
標(biāo)簽:
傳動網(wǎng)版權(quán)與免責(zé)聲明:凡本網(wǎng)注明[來源:傳動網(wǎng)]的所有文字、圖片、音視和視頻文件,版權(quán)均為傳動網(wǎng)(connectcrack.com)獨(dú)家所有。如需轉(zhuǎn)載請與0755-82949061聯(lián)系。任何媒體、網(wǎng)站或個人轉(zhuǎn)載使用時須注明來源“傳動網(wǎng)”,違反者本網(wǎng)將追究其法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明其他來源的稿件,均來自互聯(lián)網(wǎng)或業(yè)內(nèi)投稿人士,版權(quán)屬于原版權(quán)人。轉(zhuǎn)載請保留稿件來源及作者,禁止擅自篡改,違者自負(fù)版權(quán)法律責(zé)任。
產(chǎn)品新聞
更多>2025-09-23
2025-09-23
2025-09-08
華為昇騰Atlas800iA2 910B服務(wù)器Deepsee...
2025-09-04
TaiShan(泰山)200 2280系列服務(wù)器 鯤...
2025-09-03
2025-08-06