Thumb指令集與ARM指令集的區(qū)別
Thumb指令集
本文引用地址:http://m.butianyuan.cn/article/201611/319571.htm【1】.代碼密度:單位存儲空間中包含的指令的個數(shù)。例如
Thumb指令集與ARM指令集的區(qū)別
Ø
程序相對轉(zhuǎn)移,特別是條件跳轉(zhuǎn)與ARM代碼下的跳轉(zhuǎn)相比,在范圍上有更多的限制,轉(zhuǎn)向子程序是無條件的轉(zhuǎn)移。
Ø
數(shù)據(jù)處理指令是對通用寄存器進行操作,在大多數(shù)情況下,操作的結(jié)果須放入其中一個操作數(shù)寄存器中,而不是第三個寄存器中。
數(shù)據(jù)處理操作比ARM狀態(tài)的更少,訪問寄存器R8—R15受到一定限制。
(除MOV和ADD指令訪問寄存器R8—R15外,其他數(shù)據(jù)處理指令總是更新CPSR中ALU狀態(tài)標志)
訪問寄存器R8—R15的Thumb數(shù)據(jù)處理指令不能更新CPSR中的ALU狀態(tài)標志
Ø
在Thumb狀態(tài)下,單寄存器加載和存儲指令只能訪問寄存器R0—R7
Ø
LDM和STM指令可以將任何范圍為R0——R7的寄存器子集加載或存儲
評論