當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]1.關(guān)于軟中斷指令 軟件中斷指令(SWI)可以產(chǎn)生一個(gè)軟件中斷異常,這為應(yīng)用程序調(diào)用系統(tǒng)例程提供了一種機(jī)制。語(yǔ)法: SWI {} SWI_number SWI執(zhí)行后的寄存器變化: lr_svc = SWI指令后面的指令地址 spsr_svc = cpsr pc

1.關(guān)于軟中斷指令 軟件中斷指令(SWI)可以產(chǎn)生一個(gè)軟件中斷異常,這為應(yīng)用程序調(diào)用系統(tǒng)例程提供了一種機(jī)制。

語(yǔ)法: SWI {} SWI_number SWI執(zhí)行后的寄存器變化:

lr_svc = SWI指令后面的指令地址 spsr_svc = cpsr pc = vectors + 0x08

cpsr模式 = SVC cpsr I = 1(屏蔽IRQ中斷)

處理器執(zhí)行SWI指令時(shí),設(shè)置程序計(jì)數(shù)器pc為向量表的0x08偏移處,同事強(qiáng)制切換處理器模式到SVC模式,以便操作系統(tǒng)例程可以在特權(quán)模式下被調(diào)用。

每個(gè)SWI指令有一個(gè)關(guān)聯(lián)的SWI號(hào)(number),用于表示一個(gè)特定的功能調(diào)用或特性。

【例子】 一個(gè)ARM工具箱中用于調(diào)試SWI的例子,是一個(gè)SWI號(hào)為0x123456的SWI調(diào)用。通常SWI指令是在用戶(hù)模式下執(zhí)行的。

SWI執(zhí)行前: cpsr = nzcVqift_USER pc = 0x00008000 lr = 0x003fffff ;lr = 4 r0 = 0x12

執(zhí)行指令: 0x00008000 SWI 0x123456

SWI執(zhí)行后: cpsr = nzcVqIft_SVC spsr = nzcVqift_USER pc = 0x00000008 lr = 0x00008004 r0 = 0x12

SWI用于調(diào)用操作系統(tǒng)的例程,通常需要傳遞一些參數(shù),這可以通過(guò)寄存器來(lái)完成。

在上面的例子中,r0 用于傳遞參數(shù)0x12,返回值也通過(guò)寄存器來(lái)傳遞。

處理軟件中斷調(diào)用的代碼段稱(chēng)為中斷處理程序(SWI Handler)。中斷處理程序通過(guò)執(zhí)行指令的地址獲取軟件中斷號(hào),指令地址是從lr計(jì)算出來(lái)的。

SWI號(hào)由下式?jīng)Q定: SWI_number = AND NOT<0xff000000> 其中SWI instruction就是實(shí)際處理器執(zhí)行的32位SWI指令

SWI指令編碼為: 31 - 28 27 - 24 23 - 0 cond 1 1 1 1 immed24

指令的二進(jìn)制代碼的bit23-bit0是24bit的立即數(shù),即SWI指令的中斷號(hào),通過(guò)屏蔽高8bit即可獲得中斷號(hào)。

lr寄存器保存的是中斷返回指令的地址,所以 [lr - 4] 就是執(zhí)行SWI的執(zhí)行代碼。

通過(guò)load指令拷貝整個(gè)SWI指令到寄存器,使用BIC屏蔽指令的高8位,獲取SWI中斷號(hào)。

;read the SWI instruction LDR r10, [lr, #-4] BIC r10, r10, #0xff000000 2. 周立功移植uC/OS-II到s3c2410的軟中斷服務(wù)級(jí)的任務(wù)切換 uC/OS-II的任務(wù)調(diào)度函數(shù) uC/OS-II的任務(wù)級(jí)的調(diào)度是由函數(shù)OS_Sched( )完成的。

void OS_Sched (void)
{
#if OS_CRITICAL_METHOD == 3 /* Allocate storage for CPU status register */
OS_CPU_SR cpu_sr;
#endif
INT8U y;


OS_ENTER_CRITICAL();
if ((OSIntNesting == 0) && (OSLockNesting == 0)) { /* Sched. only if all ISRs done & not locked */
y = OSUnMapTbl[OSRdyGrp]; /* Get pointer to HPT ready to run */
OSPrioHighRdy = (INT8U)((y << 3) + OSUnMapTbl[OSRdyTbl[y]]);
if (OSPrioHighRdy != OSPrioCur) { /* No Ctx Sw if current task is highest rdy */
OSTCBHighRdy = OSTCBPrioTbl[OSPrioHighRdy];
OSCtxSwCtr++; /* Increment context switch counter */
OS_TASK_SW(); /* Perform a context switch */
}
}
OS_EXIT_CRITICAL();
}

詳細(xì)解釋可以參考《嵌入式實(shí)時(shí)操作系統(tǒng) uC/OS-II》,os_sched函數(shù)在確定所有就緒任務(wù)的最高優(yōu)先級(jí)高于當(dāng)前任務(wù)優(yōu)先級(jí)時(shí)進(jìn)行任務(wù)切換,通過(guò)OS_TASK_SW( )宏來(lái)調(diào)用。
OS_TASK_SW( )宏實(shí)際上定義的是SWI軟中斷指令。見(jiàn)OS_CPU.H文件的代碼:

__swi(0x00) void OS_TASK_SW(void); /* 任務(wù)級(jí)任務(wù)切換函數(shù) */
__swi(0x01) void _OSStartHighRdy(void); /* 運(yùn)行優(yōu)先級(jí)最高的任務(wù) */
__swi(0x02) void OS_ENTER_CRITICAL(void); /* 關(guān)中斷 */
__swi(0x03) void OS_EXIT_CRITICAL(void); /* 開(kāi)中斷 */

__swi(0x40) void *GetOSFunctionAddr(int Index); /* 獲取系統(tǒng)服務(wù)函數(shù)入口 */
__swi(0x41) void *GetUsrFunctionAddr(int Index);/* 獲取自定義服務(wù)函數(shù)入口 */
__swi(0x42) void OSISRBegin(void); /* 中斷開(kāi)始處理 */
__swi(0x43) int OSISRNeedSwap(void); /* 判斷中斷是否需要切換 */

__swi(0x80) void ChangeToSYSMode(void); /* 任務(wù)切換到系統(tǒng)模式 */
__swi(0x81) void ChangeToUSRMode(void); /* 任務(wù)切換到用戶(hù)模式 */
__swi(0x82) void TaskIsARM(INT8U prio); /* 任務(wù)代碼是ARM代碼 */
__swi(0x83) void TaskIsTHUMB(INT8U prio); /* 任務(wù)代碼是THUMB */

__swi(0x00) void OS_TASK_SW(void); 是與ADS相關(guān)的代碼,通過(guò)反匯編可以看到,調(diào)用OS_TASK_SW實(shí)際上被替換成swi 0x00 軟中斷指令。執(zhí)行此執(zhí)行,pc會(huì)跳轉(zhuǎn)到向量表的0x08偏移處。


中斷向量表:(見(jiàn)Startup.s文件)


CODE32
AREA vectors,CODE,READONLY
; 異常向量表
Reset
LDR PC, ResetAddr
LDR PC, UndefinedAddr
LDR PC, SWI_Addr
LDR PC, PrefetchAddr
LDR PC, DataAbortAddr
DCD IRQ_Addr
LDR PC, IRQ_Addr
LDR PC, FIQ_Addr

ResetAddr DCD ResetInit
UndefinedAddr DCD Undefined
SWI_Addr DCD SoftwareInterrupt
PrefetchAddr DCD PrefetchAbort
DataAbortAddr DCD DataAbort
Nouse DCD 0
IRQ_Addr DCD IRQ_Handler
FIQ_Addr DCD FIQ_Handler


執(zhí)行SWI 0x00指令后,pc會(huì)跳轉(zhuǎn)到SoftwareInterrupt代碼處開(kāi)始執(zhí)行:

見(jiàn)Os_cpu_a.s文件的SoftwareInterrupt函數(shù):

SoftwareInterrupt
LDR SP, StackSvc ; 重新設(shè)置堆棧指針
STMFD {R0-R3, R12, LR}
MOV R1, SP ; R1指向參數(shù)存儲(chǔ)位置

MRS R3, SPSR
TST R3, #T_bit ; 中斷前是否是Thumb狀態(tài)
LDRNEH R0, [LR,#-2] ; 是: 取得Thumb狀態(tài)SWI指令
BICNE R0, R0, #0xff00
LDREQ R0, [LR,#-4] ; 否: 取得arm狀態(tài)SWI指令
BICEQ R0, R0, #0xFF000000 ; 如上面所述,此處通過(guò)屏蔽SWI指令的高8位來(lái)獲取SWI號(hào),r0 = SWI號(hào),R1指向參數(shù)存儲(chǔ)位置
CMP R0, #1
LDRLO PC, =OSIntCtxSw ;為0時(shí)跳轉(zhuǎn)到OSIntCtxSwdi地址處
LDREQ PC, =__OSStartHighRdy ; 為1時(shí),跳轉(zhuǎn)到__OSStartHighRdy地址處。SWI 0x01為第一次任務(wù)切換

BL SWI_Exception ;進(jìn)入中斷號(hào)散轉(zhuǎn)函數(shù)

LDMFD {R0-R3, R12, PC}^

StackSvc DCD (SvcStackSpace + SVC_STACK_LEGTH * 4 - 4)


以上就是任務(wù)切換軟中斷級(jí)服務(wù)的實(shí)現(xiàn)。


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉