资料介绍
在ARM体系结构中,ARM指令集中的指令是32位指令,其执行效率很高。对于存储系统数据总线为16位的应用系统,ARM体系提供了Thumb指令集。Thumb指令集是ARM指令集的一个子集,它比ARM指令集有更高的代码密度(一个可执行的程序在内存中所占的空间)。在存储系统受限的嵌入式系统中,比如移动电话、PDA等,代码密度是非常重要的,同时,成本压力也会限制存储器的大小、数据宽度和速度。在ARM体系的T变种(T variable)的版本中,同时支持ARM指令集和Thumb指令集,而且遵循一定的调用规则时,Thumb子程序和ARM子程序可以相互调用。
11.1 Thumb指令的特点及实现
Thumb指令集把32位ARM指令集的一个子集编码为一个16位的指令集。在16位外部数据总线宽度下,ARM处理器上使用Thumb指令的性能要比使用ARM指令的性能更好;而在32位外部数据总线宽度下,使用Thumb指令的性能要比使用ARM指令的性能差。因此,Thumb指令多用于存储器受限的一些系统中。Thumb指令集并没有改变ARM系统底层的程序设计模型,只是在该模型上增加了一些限制条件。Thumb指令集中的数据处理指令的操作数仍然是32位,指令寻址地址也是32位的。
代码密度是Thumb指令集的一个主要优势。平均而言,对于同一个程序,使用Thumb指令实现所需的存储空间,要比等效的ARM指令实现少30%左右。下面的例子代码,使用ARM指令和Thumb指令实现相同的除法操作。从例子中可以看出,虽然Thumb指令的实现使用了更多的指令,但是它占用的总的存储空间却比较小。
【例11.1】使用ARM指令实现除法运算
MOV r3,#0
loop
SUB r0,r0,r1
ADDGE r3,r3,#1
BGE loop
ADD r2,r0,r1
【例11.1】中r0为被除数,r1存放除数,r2和r3分别存放余数和商。完成整个除法运算使用了5条指令,每一条指令所占的字节数为4,所以实现一个除法运算,ARM指令所占有的字节数为20。
【例11.2】使用Thumb指令实现除法运算
MOV r3,#0
loop
ADD r3,#1
SUB r0,r1
BGE loop
SUB r3,#1
ADD r2,r0,r1
【例11.2】使用Thumb指令完成了和【例11.1】完全相同的功能。Thumb指令虽然使用了6条指令,但其每条指令占用2个字节,所以总的字节数为6×2=12,小于ARM指令所占用的20个字节。
Thumb指令是ARM指令的一个受限子集,在Thumb状态下,不能直接访问所有的处理器寄存器,只有r0~r7是可以被任意访问的,在Thumb状态下使用该8个寄存器和在ARM状态下使用没有区别。寄存器r8~r12只能通过MOV、ADD或CMP指令访问。CMP指令和所有操作r0~r7的数据处理指令都会影响CPSR中的条件标志位。一些Thumb指令还使用到了程序计数器PC(r15),链接地址寄存器LR(r14)和堆栈指针寄存器SP(r13)。在Thumb状态下,读取r15寄存器时,bit[0]值为0,bit [31∶1]包含了PC的值。当对r15进行写入时,bit[0]被忽略,bit[31∶1]被设置成当前程序计数器的值。
表11.1列出了Thumb状态下,各寄存器的使用情况。
表11.1 Thumb寄存器的使用
寄 存 器访 问
r0~r7完全访问
r8~r12只能通过MOV、ADD及CMP访问
r13限制访问
r14限制访问
r15限制访问
CPSR间接访问
SPSR不能访问
从表11.1可以看出,Thumb状态下不能直接访问CPSR和SPSR。也就是没有和MSR和MRS等价的指令。为了改变CPSR和SPSR的值,必须使处理器状态切换到ARM状态,再使用指令MSR和MRS来实现。同样,在Thumb状态下也没有协处理器访问指令,要访问协处理器寄存器来配置cache和进行内存管理,也必须使处理器切换到ARM状态。
注意Thumb状态下,对CPSR的条件标准位控制由算术和逻辑操作设置并控制条件转移。
11.1 Thumb指令的特点及实现
Thumb指令集把32位ARM指令集的一个子集编码为一个16位的指令集。在16位外部数据总线宽度下,ARM处理器上使用Thumb指令的性能要比使用ARM指令的性能更好;而在32位外部数据总线宽度下,使用Thumb指令的性能要比使用ARM指令的性能差。因此,Thumb指令多用于存储器受限的一些系统中。Thumb指令集并没有改变ARM系统底层的程序设计模型,只是在该模型上增加了一些限制条件。Thumb指令集中的数据处理指令的操作数仍然是32位,指令寻址地址也是32位的。
代码密度是Thumb指令集的一个主要优势。平均而言,对于同一个程序,使用Thumb指令实现所需的存储空间,要比等效的ARM指令实现少30%左右。下面的例子代码,使用ARM指令和Thumb指令实现相同的除法操作。从例子中可以看出,虽然Thumb指令的实现使用了更多的指令,但是它占用的总的存储空间却比较小。
【例11.1】使用ARM指令实现除法运算
MOV r3,#0
loop
SUB r0,r0,r1
ADDGE r3,r3,#1
BGE loop
ADD r2,r0,r1
【例11.1】中r0为被除数,r1存放除数,r2和r3分别存放余数和商。完成整个除法运算使用了5条指令,每一条指令所占的字节数为4,所以实现一个除法运算,ARM指令所占有的字节数为20。
【例11.2】使用Thumb指令实现除法运算
MOV r3,#0
loop
ADD r3,#1
SUB r0,r1
BGE loop
SUB r3,#1
ADD r2,r0,r1
【例11.2】使用Thumb指令完成了和【例11.1】完全相同的功能。Thumb指令虽然使用了6条指令,但其每条指令占用2个字节,所以总的字节数为6×2=12,小于ARM指令所占用的20个字节。
Thumb指令是ARM指令的一个受限子集,在Thumb状态下,不能直接访问所有的处理器寄存器,只有r0~r7是可以被任意访问的,在Thumb状态下使用该8个寄存器和在ARM状态下使用没有区别。寄存器r8~r12只能通过MOV、ADD或CMP指令访问。CMP指令和所有操作r0~r7的数据处理指令都会影响CPSR中的条件标志位。一些Thumb指令还使用到了程序计数器PC(r15),链接地址寄存器LR(r14)和堆栈指针寄存器SP(r13)。在Thumb状态下,读取r15寄存器时,bit[0]值为0,bit [31∶1]包含了PC的值。当对r15进行写入时,bit[0]被忽略,bit[31∶1]被设置成当前程序计数器的值。
表11.1列出了Thumb状态下,各寄存器的使用情况。
表11.1 Thumb寄存器的使用
寄 存 器访 问
r0~r7完全访问
r8~r12只能通过MOV、ADD及CMP访问
r13限制访问
r14限制访问
r15限制访问
CPSR间接访问
SPSR不能访问
从表11.1可以看出,Thumb状态下不能直接访问CPSR和SPSR。也就是没有和MSR和MRS等价的指令。为了改变CPSR和SPSR的值,必须使处理器状态切换到ARM状态,再使用指令MSR和MRS来实现。同样,在Thumb状态下也没有协处理器访问指令,要访问协处理器寄存器来配置cache和进行内存管理,也必须使处理器切换到ARM状态。
注意Thumb状态下,对CPSR的条件标准位控制由算术和逻辑操作设置并控制条件转移。
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- ARM处理器的寻址方式和指令集介绍 33次下载
- ARM和Thumb-2的指令集快速参考卡 21次下载
- Thumb指令集之Thumb跳转指令 1次下载
- Thumb数据处理指令 0次下载
- Thumb指令集之Thumb编程模型 0次下载
- Thumb指令集之多寄存器数据传送指令解析 0次下载
- Thumb指令集之ARM和Thumb的混合编程 1次下载
- 未定义的指令空间 0次下载
- Thumb指令集之Thumb指令应用 0次下载
- Thumb指令集之异常中断产生指令解析 0次下载
- ARM和Thumb-2指令集快速参考卡 20次下载
- ARM指令集详解
- ARM/THUMB指令系统
- ARM/THUMB微处理器结构及指令系统
- arm7tdmi(s)指令系统
- 电路块ANB指令与ORB指令操作 4916次阅读
- PLC实例:顺序控制指令,实现搬运动作 2452次阅读
- PLC表格指令说明 3189次阅读
- PLC循环指令的工作原理 1.2w次阅读
- PLC跳转/标号指令的工作原理及应用举例 5152次阅读
- 什么是位逻辑指令?plc位逻辑指令有哪些?plc位逻辑指令应用方法图解 1.5w次阅读
- ARM架构常用术语解析 2407次阅读
- Thumb指令、Thumb-2指令、Thumb-2EE 指令区别是什么 1.3w次阅读
- 嵌入式处理器的体系架构与内核 3202次阅读
- Trim指令与GC功能,让你的SSD性能不减 9290次阅读
- 详解CPU功耗的方法与技巧 5820次阅读
- 指令和伪指令分得清吗? 6725次阅读
- 浅谈ARM伪指令地址读取 2036次阅读
- thumb指令集是什么_thumb指令集与arm指令集的区别 1.8w次阅读
- 干货分享:PIC单片机常用指令介绍与指令功能分类表 4067次阅读
下载排行
本周
- 1TC358743XBG评估板参考手册
- 1.36 MB | 330次下载 | 免费
- 2开关电源基础知识
- 5.73 MB | 6次下载 | 免费
- 3100W短波放大电路图
- 0.05 MB | 4次下载 | 3 积分
- 4嵌入式linux-聊天程序设计
- 0.60 MB | 3次下载 | 免费
- 5基于FPGA的光纤通信系统的设计与实现
- 0.61 MB | 2次下载 | 免费
- 6基于FPGA的C8051F单片机开发板设计
- 0.70 MB | 2次下载 | 免费
- 751单片机窗帘控制器仿真程序
- 1.93 MB | 2次下载 | 免费
- 8基于51单片机的RGB调色灯程序仿真
- 0.86 MB | 2次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 2555集成电路应用800例(新编版)
- 0.00 MB | 33564次下载 | 免费
- 3接口电路图大全
- 未知 | 30323次下载 | 免费
- 4开关电源设计实例指南
- 未知 | 21548次下载 | 免费
- 5电气工程师手册免费下载(新编第二版pdf电子书)
- 0.00 MB | 15349次下载 | 免费
- 6数字电路基础pdf(下载)
- 未知 | 13750次下载 | 免费
- 7电子制作实例集锦 下载
- 未知 | 8113次下载 | 免费
- 8《LED驱动电路设计》 温德尔著
- 0.00 MB | 6653次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935054次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 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十天学会AVR单片机与C语言视频教程 下载
- 158M | 183278次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138040次下载 | 免费
评论
查看更多