日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

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

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

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

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

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

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

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

【例子】 一個ARM工具箱中用于調(diào)試SWI的例子,是一個SWI號為0x123456的SWI調(diào)用。通常SWI指令是在用戶模式下執(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ù),這可以通過寄存器來完成。

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

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

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

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

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

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

通過load指令拷貝整個SWI指令到寄存器,使用BIC屏蔽指令的高8位,獲取SWI中斷號。

;read the SWI instruction LDR r10, [lr, #-4] BIC r10, r10, #0xff000000 2. 周立功移植uC/OS-II到s3c2410的軟中斷服務級的任務切換 uC/OS-II的任務調(diào)度函數(shù) uC/OS-II的任務級的調(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();
}

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

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

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

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

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


中斷向量表:(見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會跳轉到SoftwareInterrupt代碼處開始執(zhí)行:

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

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

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 ; 如上面所述,此處通過屏蔽SWI指令的高8位來獲取SWI號,r0 = SWI號,R1指向參數(shù)存儲位置
CMP R0, #1
LDRLO PC, =OSIntCtxSw ;為0時跳轉到OSIntCtxSwdi地址處
LDREQ PC, =__OSStartHighRdy ; 為1時,跳轉到__OSStartHighRdy地址處。SWI 0x01為第一次任務切換

BL SWI_Exception ;進入中斷號散轉函數(shù)

LDMFD {R0-R3, R12, PC}^

StackSvc DCD (SvcStackSpace + SVC_STACK_LEGTH * 4 - 4)


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


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

  引言   汽車的普及為人們的生活帶來了方便,同時也給人們提出了一大難題——汽車防盜。本設計是為了解決以往汽車防盜產(chǎn)品的缺點和不足而開發(fā)的集成傳感、報警和遠程圖

關鍵字: 數(shù)據(jù)采集 操作系統(tǒng) s3c2410 汽車防盜系統(tǒng)

  引言   巡航控制系統(tǒng)(CCS)是20世紀60年代發(fā)展起來的,又稱為恒速行駛系統(tǒng)。巡航控制系統(tǒng)工作時,ECU根據(jù)各種傳感器輸送來的信號判斷汽車的運行狀況,通過執(zhí)行元件自動調(diào)節(jié)節(jié)氣門的

關鍵字: ARM 三星 Linux ecu s3c2410 電子控制系統(tǒng)

  在過去一百年里(l906-2005),全球地表平均溫度升高了0.74攝氏度,未來20年,每十年全球溫度將會升高0.2攝氏度。氣候變暖已成為不容忽視的、直接影響全球生產(chǎn)和生活問題。  

關鍵字: can總線 s3c2410

  在此設計的基于 GPRS 的遠程安防監(jiān)控系統(tǒng),是采用的是攝像機傳送視頻信號經(jīng)壓縮編碼后,通過內(nèi)部總線傳送到內(nèi)置的 Web 服務器。用戶在監(jiān)控端可以直接通過瀏覽器觀看 Web服務器上的攝像機視

關鍵字: GPRS s3c2410 安防監(jiān)控

自春節(jié)以來,幣圈最熱鬧的事件當屬火幣HADAX平臺的投票上幣活動了。持續(xù)半個月之久,緊抓圈內(nèi)人眼球。參與投票的75個項目在排名上你追我趕,不到最后一刻都很難預測哪幾家能入圍前十。最終,我們不負眾

關鍵字: uc 區(qū)塊鏈

全球瀏覽器軟件的市場,依然被谷歌Chrome統(tǒng)治。 來自NetMarketShare的數(shù)據(jù)顯示,在剛過去的5月份,Chrome的份額從65.64%進一步提升到67.9%,來到2019年迄今的峰值水平。

關鍵字: chrome qq uc 份額 瀏覽器

網(wǎng)上介紹LINUX下的一般驅(qū)動程序開發(fā)示例浩如煙海,或是因為簡單,關于DMA驅(qū)動的介紹卻寥寥無幾;近期zhaoyang因工作需要,花了幾日時間開發(fā)了某設備在S3C2410處理器Linux下DMA通信的驅(qū)動程序,有感于剛接...

關鍵字: Linux s3c2410 dma驅(qū)動

這段時間已成功把uC/OS-II 2.52移植到51單片機上,現(xiàn)總結移植步驟:1.在main函數(shù)只包括void main(void){OSInit();OSStart();}看是否能編譯通過,可以通過后繼續(xù)下一步。2.驗...

關鍵字: C51 os-ii uc 移植步驟

1引言目前 , 在嵌入式系統(tǒng)里基于ARM核的嵌入式處理器已經(jīng)成為市場主流。隨著ARM技術的廣泛應用 , 建立面向ARM構架的嵌入式操作系統(tǒng)也就成為當前研究的熱點。S3C2410是SAMSUNG公司基于ARM920T處理器...

關鍵字: s3c2410 移植 標準linux
關閉