加入星计划,您可以享受以下权益:

  • 创作内容快速变现
  • 行业影响力扩散
  • 作品版权保护
  • 300W+ 专业用户
  • 1.5W+ 优质创作者
  • 5000+ 长期合作伙伴
立即加入
  • 正文
    • 11.1  Thumb指令的特点及实现
  • 推荐器件
  • 相关推荐
  • 电子产业图谱
申请入驻 产业图谱

Thumb指令集之: Thumb指令的特点及实现

2013/09/30
2
阅读需 6 分钟
加入交流群
扫码加入
获取工程师必备礼包
参与热点资讯讨论

在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的条件标准位控制由算术和逻辑操作设置并控制条件转移。

推荐器件

更多器件
器件型号 数量 器件厂商 器件描述 数据手册 ECAD模型 风险等级 参考价格 更多信息
KSZ8851SNLI 1 Microchip Technology Inc DATACOM, ETHERNET TRANSCEIVER, PQCC32
$5.06 查看
LAN8710AI-EZK-TR-ABC 1 Microchip Technology Inc DATACOM, ETHERNET TRANSCEIVER
$11.72 查看
SFH250V 1 OSRAM GmbH PIN-TYPE PHOTODIODE,LSR-3
$13.14 查看
Arm

Arm

ARM公司是一家知识产权(IP)供应商,主要为国际上其他的电子公司提供高性能RISC处理器、外设和系统芯片技术授权。目前,ARM公司的处理器内核已经成为便携通讯、手持计算设备、多媒体数字消费品等方案的RISC标准。公司1990年11月由Acorn、Apple和VLSI合并而成。

ARM公司是一家知识产权(IP)供应商,主要为国际上其他的电子公司提供高性能RISC处理器、外设和系统芯片技术授权。目前,ARM公司的处理器内核已经成为便携通讯、手持计算设备、多媒体数字消费品等方案的RISC标准。公司1990年11月由Acorn、Apple和VLSI合并而成。收起

查看更多

相关推荐

电子产业图谱

华清远见(www.farsight.com.cn)是国内领先嵌入师培训机构,2004年注册于中国北京海淀高科技园区,除北京总部外,上海、深圳、成都、南京、武汉、西安、广州均有直营分公司。华清远见除提供嵌入式相关的长期就业培训、短期高端培训、师资培训及企业员工内训等业务外,其下属研发中心还负责嵌入式、Android及物联网方向的教学实验平台的研发及培训教材的出版,截止目前为止已公开出版70余本嵌入式/移动开发/物联网相关图书。企业理念:专业始于专注 卓识源于远见。企业价值观:做良心教育、做专业教育,更要做受人尊敬的职业教育。