資料介紹
所有的Thumb指令都是16位的。它們都是ARM指令重新編碼得到的,所以繼承了ARM指令集的許多特點。
?、?有數(shù)據(jù)處理、數(shù)據(jù)傳送和流控制的指令結(jié)構(gòu)。
?、?支持8位字節(jié)、16位半字和32位字?jǐn)?shù)據(jù)類型,半字以兩字節(jié)邊界對齊,字以4字節(jié)邊界對齊。
?、?32位的無分段存儲器(unsegmented memory)。
Thumb指令集除了繼承了ARM指令集的一些特點外,與ARM指令集存在以下一些差異。
?、?大多數(shù)Thumb指令為無條件執(zhí)行指令(所有ARM指令都是條件執(zhí)行的)。
?、?許多Thumb數(shù)據(jù)處理指令采用了2地址格式(目的寄存器與源寄存器相同)。而ARM指令中除64位乘法指令外,其余指令均采用3地址模式。
?、?Thumb指令格式減少了很多ARM指令格式的限制,使Thumb指令編寫的代碼密度大大提高。
無論處理器處于什么狀態(tài),所有的異常都使處理器返回到ARM狀態(tài),并完成異常處理。但異常發(fā)生時,CPSR狀態(tài)寄存器在進(jìn)入異常時被保存到相應(yīng)的SPSR中,當(dāng)異常處理結(jié)束后,處理器將恢復(fù)到異常發(fā)生前的狀態(tài),并按照發(fā)生異常時處理器的狀態(tài)繼續(xù)執(zhí)行ARM或Thumb指令。
應(yīng)該注意的是,ARM異常返回指令需要根據(jù)ARM流水線的行為對返回地址進(jìn)行調(diào)整。由于Thumb指令是2字節(jié)長,而ARM指令是4字節(jié)長,所以由Thumb執(zhí)行狀態(tài)進(jìn)入異常時其自然偏移量應(yīng)與ARM不同(ARM狀態(tài)下,拷貝到鏈接寄存器的值PC-4)。為了減少編程的復(fù)雜性,ARM體系結(jié)構(gòu)中設(shè)置了硬件邏輯,以實現(xiàn)Thumb狀態(tài)的自動地址偏移調(diào)整,使ARM和Thumb狀態(tài)編程一致。
表11.2列出了Thumb狀態(tài)下發(fā)生異常時LR的值。
表11.2 Thumb狀態(tài)異常返回指令
異 常異常鏈接寄存器值返 回 指 令
Reset不可預(yù)知的值-
未定義指令未定義指令地址+2MOV PC,r14
SWISwi指令地址+2MOV PC,r14
預(yù)取異常預(yù)取異常指令+4MOV PC,r14,#4
數(shù)據(jù)異常產(chǎn)生預(yù)取異常指令地址+8MOV PC,r14,#8
IRQ下一條將被執(zhí)行的指令地址+4MOV PC,r14,#4
FIQ下一條將被執(zhí)行的指令地址+4MOV PC,r14,#4
?
?、?有數(shù)據(jù)處理、數(shù)據(jù)傳送和流控制的指令結(jié)構(gòu)。
?、?支持8位字節(jié)、16位半字和32位字?jǐn)?shù)據(jù)類型,半字以兩字節(jié)邊界對齊,字以4字節(jié)邊界對齊。
?、?32位的無分段存儲器(unsegmented memory)。
Thumb指令集除了繼承了ARM指令集的一些特點外,與ARM指令集存在以下一些差異。
?、?大多數(shù)Thumb指令為無條件執(zhí)行指令(所有ARM指令都是條件執(zhí)行的)。
?、?許多Thumb數(shù)據(jù)處理指令采用了2地址格式(目的寄存器與源寄存器相同)。而ARM指令中除64位乘法指令外,其余指令均采用3地址模式。
?、?Thumb指令格式減少了很多ARM指令格式的限制,使Thumb指令編寫的代碼密度大大提高。
無論處理器處于什么狀態(tài),所有的異常都使處理器返回到ARM狀態(tài),并完成異常處理。但異常發(fā)生時,CPSR狀態(tài)寄存器在進(jìn)入異常時被保存到相應(yīng)的SPSR中,當(dāng)異常處理結(jié)束后,處理器將恢復(fù)到異常發(fā)生前的狀態(tài),并按照發(fā)生異常時處理器的狀態(tài)繼續(xù)執(zhí)行ARM或Thumb指令。
應(yīng)該注意的是,ARM異常返回指令需要根據(jù)ARM流水線的行為對返回地址進(jìn)行調(diào)整。由于Thumb指令是2字節(jié)長,而ARM指令是4字節(jié)長,所以由Thumb執(zhí)行狀態(tài)進(jìn)入異常時其自然偏移量應(yīng)與ARM不同(ARM狀態(tài)下,拷貝到鏈接寄存器的值PC-4)。為了減少編程的復(fù)雜性,ARM體系結(jié)構(gòu)中設(shè)置了硬件邏輯,以實現(xiàn)Thumb狀態(tài)的自動地址偏移調(diào)整,使ARM和Thumb狀態(tài)編程一致。
表11.2列出了Thumb狀態(tài)下發(fā)生異常時LR的值。
表11.2 Thumb狀態(tài)異常返回指令
異 常異常鏈接寄存器值返 回 指 令
Reset不可預(yù)知的值-
未定義指令未定義指令地址+2MOV PC,r14
SWISwi指令地址+2MOV PC,r14
預(yù)取異常預(yù)取異常指令+4MOV PC,r14,#4
數(shù)據(jù)異常產(chǎn)生預(yù)取異常指令地址+8MOV PC,r14,#8
IRQ下一條將被執(zhí)行的指令地址+4MOV PC,r14,#4
FIQ下一條將被執(zhí)行的指令地址+4MOV PC,r14,#4
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- ARM處理器的尋址方式和指令集介紹 33次下載
- ARM和Thumb-2的指令集快速參考卡 21次下載
- Thumb指令集之Thumb跳轉(zhuǎn)指令 1次下載
- Thumb數(shù)據(jù)處理指令 0次下載
- Thumb指令的特點及實現(xiàn) 0次下載
- Thumb指令集之多寄存器數(shù)據(jù)傳送指令解析 0次下載
- Thumb指令集之ARM和Thumb的混合編程 1次下載
- 未定義的指令空間 0次下載
- Thumb指令集之Thumb指令應(yīng)用 0次下載
- Thumb指令集之異常中斷產(chǎn)生指令解析 0次下載
- ARM和Thumb-2指令集快速參考卡 20次下載
- arm7指令集
- ARM指令集詳解
- ARM/THUMB指令系統(tǒng)
- ARM/THUMB微處理器結(jié)構(gòu)及指令系統(tǒng)
- RISC-V開源指令集全面指南與解析 519次閱讀
- 現(xiàn)代處理器的主要指令集架構(gòu) 3025次閱讀
- NB-IOT常用AT指令集簡介 2767次閱讀
- 什么指令集支持原子操作 1305次閱讀
- 總結(jié)20個超好用的 Unix/Linux 命令指令集 2847次閱讀
- Thumb指令、Thumb-2指令、Thumb-2EE 指令區(qū)別是什么 1.3w次閱讀
- 嵌入式處理器的體系架構(gòu)與內(nèi)核 3202次閱讀
- 詳解CPU功耗的方法與技巧 5820次閱讀
- PLC編程入門基礎(chǔ)技術(shù)知識(plc原理和指令集及編程規(guī)則) 6.8w次閱讀
- Cortex-M系列處理器指令集_指令集特性比較總結(jié) 7689次閱讀
- risc指令集是什么_有哪些 1.9w次閱讀
- mips指令集指的是什么 1.2w次閱讀
- mips匯編指令集功能的介紹 2.2w次閱讀
- esp8266 at指令集詳解 14.1w次閱讀
- thumb指令集是什么_thumb指令集與arm指令集的區(qū)別 1.8w次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多