久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > ARM匯編的SWI指令軟中斷

ARM匯編的SWI指令軟中斷

作者: 時間:2016-11-11 來源:網絡 收藏
從下面的一個ARM 匯編小程序要弄懂的以下三個問題:

1).在ARM狀態轉到THUNB狀態和BX的應用

本文引用地址:http://cqxgywz.com/article/201611/316759.htm

2).匯編的架構

3).SWI指令的使用

    AREA ADDREG,CODE,READONLY

    ENTRY

MAIN

  ADR r0,ThunbProg 1 ;(為什么要加1呢?因為BX指令跳轉到指定的地址執行程序 時, 若   (BX{cond} Rm)Rm的位[0]為1,則跳轉時自動將CPSR中的標志T置位即把目標 代碼解釋為 Thunb代碼)

    BX r0

   CODE16

ThunbProg

   mov r2,#2

    mov r3,#3

    add r2,r2,r3

    ADR r0,ARMProg

    BX ro

    CODE32

ARMProg

    mov r4,#4

    mov r5,#5

    add r4,r4,r5

stop mov r0,#0x18

LDR r1,=0x20026

SWI 0x123456

END

SWI--軟中斷指令:

SWI指令用于產生軟中斷,從擁護模式變換到管理模式,CPSR保存到管理模式的SPSR中.

 SWI{cond} immed_24 ;immed_24為軟中斷號(服務類型)

使用SWI指令時,通常使用以下兩種方法進行傳遞參數,SWI 異常中斷處理程序就可以提供相關的服務,這兩種方法均是用戶軟件協定.SWI異常中斷處理程序要通過讀取引起軟中斷的SWI指令,以取得24位立即數.

(1) 指令中的24位立即數指定了用戶請求的服務類型,參數通過通用寄存器傳遞.

 mov r0,#34 ;設置子功能號位34

SWI 12 ;調用12號軟中斷

(2) 指令中的24位立即數被忽略,用戶請求的服務類型有寄存器RO的值決定,參數通過其他的通用寄存器傳遞.

 mov r0,#12 ;調用12號軟中斷

 mov r1,#34 ;設置子功能號位34

 SWI  0

在SWI異常中斷處理程序中,取出SWI立即數的步驟為:首先確定引起軟中斷的SWI指令是ARM指令還是Thunb指令,這可通過對SPSR訪問得到;然后取得該SWI指令的地址,這可通過訪問LR寄存器得到;接著讀出指令,分解出立即數.如如下程序:

T_bit EQU 0X20

SWI_Handler

STMFD SP!,{R0-R3,R12,LR} ;現場保護

MRS R0,SPSR ;讀取SPSR

STMFD SP!,{R0} :保存SPSR

TST R0,#T_bit

LDRNEH R0,[LR,#-2] ;若是Thunb指令,讀取指令碼(16位)

   BICNE R0,#0XFF00 :取得Thunb指令的8位立即數

   LDREQ R0,[LR,#-4] ;若是ARM指令,讀取指令碼(32位)

   BICEQ R0,#0XFF000000 ;取得ARM指令的24位立即數

   ....

   LDMFD SP!,{R0-R3,R12,PC}^ ;SWI異常中斷返回



評論


技術專區

關閉