Thumb指令集支持寄存器的装载和存储,即LDR和STR指令。8和类型的Load/Store指令在Thumb指令集中可用。这些指令使用两种寻址模式:寄存器偏移和立即数偏移。指令所能存取的数据包括字、半字和字节,同时半字和字节可以为有符号数或无符号数。
Thumb中有两个分支跳转指令的变体,第一个变体与ARM版本指令相似,可条件执行,跳转被限制在有符号8位立即数所表示的范围内,或者是±256B。第二个变体不可条件执行(没有条件码部分),但扩展了有效跳转范围,跳转范围为有符号11位立即数表示的范围,即±2048B。
Thumb指令集把32位ARM指令集的一个子集编码为一个16位的指令集。在16位外部数据总线宽度下,ARM处理器上使用Thumb指令的性能要比使用ARM指令的性能更好。
所有的Thumb指令都是16位的。它们都是ARM指令重新编码得到的,所以继承了ARM指令集的许多特点。
Thumb指令集的多寄存器Load/Store指令是ARM指令集的多寄存器Load/Store指令的简化形式。同ARM指令一样,Thumb多寄存器数据传送指令可以用于过程调用与返回以及存储器块拷贝。但为了编码的紧凑性,这两种用法由分开的指令实现,并且这些指令也只使用单一的寻址方式。在其他方面,这些指令的性质与等价的ARM指令相同。
Thumb异常中断产生指令与ARM指令集下的异常中断指令十分相似。同ARM指令集相同,Thumb指令集中同样包含两条异常中断产生指令:软件中断指令SWI用于产生SWI异常中断;断点中断指令BKPT主要用于产生软件断点,供调试程序使用(只在ARMv5及以上版本中使用)。
Thumb指令集中存在未定义的指令空间,如图11.65所示。
对3级流水线的ARM处理器来说,做相对较小的改动就可以实现Thumb指令集(5级流水线的实现要复杂些)。为实现Thumb指令集,在指令流水线中增加了Thumb指令解码逻辑,该解码逻辑将预取的Thumb指令转换成等价的ARM指令。图11.66显示了Thumb指令的扩展逻辑组织。
Thumb以其较高的代码密度和在窄存储器上的性能,使得它在很多系统中得到广泛应用。但在很多情况下,还是不得不使用ARM指令,这是因为: