当前位置:首页 > 芯闻号 > 充电吧
[导读]由于Thumb指令在某些特殊情况下可能比ARM指令更有效,所以它在很多方面得到了广泛的应用。但是Thumb知识ARM指令集的一个子集,它不能独立组成一个应用系统,所以在很多情况下应用程序需要二者的混合

由于Thumb指令在某些特殊情况下可能比ARM指令更有效,所以它在很多方面得到了广泛的应用。但是Thumb知识ARM指令集的一个子集,它不能独立组成一个应用系统,所以在很多情况下应用程序需要二者的混合编程,这就必然存在ARM与Thumb状态之间函数调用的问题。下面将分别详细介绍。
      状态切换的实现
ARM/Thumb之间的状态切换是通过一条专用的转移交换指令BX来实现的。BX指令以通用寄存器位操作数,通过拷贝Rn到PC来实现4GB空间范围内的一个绝对跳转。BX利用Rn寄存器中目的地址值的最后一位来判断跳转后的状态。当最后一位为0时,表示转移到ARM状态;当最后一位为1时,表示转移到Thumb状态。如图所示

无论是ARM还是Thumb,其指令在存储器中都是边界对齐的。(2字节或者4字节对齐,最低位不起作用!)因此,在执行跳转过程中,PC寄存器中的最低位被舍弃,不起作用。在BX指令的执行过程中,最低位正好被用作状态判断的标志,不会造成存储器访问不对齐的错误。

下面是一段直接进入状态切换的例程:


                                                                     ;从ARM状态开始


CODE32                                                         ;表明一下是ARM指令


       ADR       R0,Into_Thumb+1                    ;得到目标地址,末位置1,表示转移到Thumb


       BX         R0                                             ;转向Thumb


              …


CODE16                                                         ;表明以下是Thumb指令Into_Thumb


       …


       ADR       R5,Back_to_ARM                       ;得到目标地址,末位缺省为0 ,转移到ARM


       BX         R5                                             ;转向ARM


       …


CODE32


       Back_to_ARM                                          ;ARM代码段起始地址

举例:从ARM态进入thumb态


① 将在Makefile中将.c文件编译指定为thumb态


%.o:%.c
	arm-linux-gcc -mthumb -c -o $@ $^ -fno-builtin
	
%.o:%.S
	arm-linux-gcc -c -o $@ $^

.S文件直接在文件中修改来实现态的转化


② 修改.S文件从arm转化到thumb态


.text
.global _start
.code 32
_start:
	/* 怎样从arm_state -> thumb_state */
	adr r0,thumb_func
	add r0,r0,#1
	bx r0
	
.code 16
thumb_func:	
	bl sdram_init
	//bl sdram_init2 //用到有初始值的数组,不是位置无关码	
	bl copy2sdram	
	bl clean_bss

	//bl main //使用BL命令相对跳转,程序仍然在Nor/sram执行
	ldr r0,=main //绝对跳转,跳到SDRAM
	mov pc,r0
halt:
	b halt

-----------------------------------------------------------------------------------------------------------------------------------------------------


问题:

①:
start.S: Assembler messages:
start.S:60: Error: lo register required -- `ldr pc,=main'
Makefile:11: recipe for target 'start.o' failed

thumb不像arm态那样,不能直接将标号赋值给pc,需要通过寄存器转化:

ldr r0,=main

mov pc,r0


②:

init.o(.text+0x58): In function `sdram_init2':
: undefined reference to `memcpy'

thumb中自动给我们将数组中的值通过memcpy复制到了数组,我们可以通过static来解决这个问题:

参考Getting GCC to compile without inserting call to memcpy:
https://stackoverflow.com/questions/6410595/getting-gcc-to-compile-without-inserting-call-to-memcpy


unsigned int arr[]  = {
0x02000000,     //BWSCON
0x00000700,     //BANKCON0
0x00000700,     //BANKCON1
0x00000700,     //BANKCON2
0x00000700,     //BANKCON3  
0x00000700,     //BANKCON4
0x00000700,     //BANKCON5
0x00018001,     //BANKCON6
0x00018005,     //BANKCON7
0x008404f5,     //REFRESH
 0x000000b1,     //BANKSIZE
0x00000020,     //MRSRB6
0x00000020,     //MRSRB7
};//把那些值全部放在数组里面

->>>>>>
const static unsigned int arr[]  = {
0x02000000,     //BWSCON
0x00000700,     //BANKCON0
0x00000700,     //BANKCON1
0x00000700,     //BANKCON2
0x00000700,     //BANKCON3  
0x00000700,     //BANKCON4
0x00000700,     //BANKCON5
0x00018001,     //BANKCON6
0x00018005,     //BANKCON7
0x008404f5,     //REFRESH
 0x000000b1,     //BANKSIZE
0x00000020,     //MRSRB6
0x00000020,     //MRSRB7
};//把那些值全部放在数组里面


③:


warning: conflicting types for built-in function

解决:在编译的时候加上-fno-builtin不使用内建函数

arm-linux-gcc -mthumb -c -o $@ $^ -fno-builtin









本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

业内消息,近日日本软件银行集团(SoftBank Group)旗下安谋国际科技公司(Arm)计划研发人工智能(AI)芯片,先成立一个AI芯片部门,目标是明年春季建立AI芯片原型产品,然后将量产工作交由代工厂制造,预估20...

关键字: ARM AI芯片

Arm CPU正在从根本上推动AI变革,并造福地球。Arm架构是未来AI计算的基石。​

关键字: ARM AI

近日,Arm推出了Arm® Ethos™-U85神经网络处理器(NPU)和Arm Corstone™-320物联网参考设计平台,旨在满足海量的数据处理和大规模计算,加速推进边缘AI的发展进程。

关键字: ARM

为了赶超云计算市场上的竞争对手,谷歌正试图通过定制的Arm服务器芯片降低云计算服务成本。

关键字: 谷歌 ARM 定制芯片

嵌入式开发作为一个融合了计算机软硬件和系统工程的综合性领域,其成功与否往往取决于三个核心要素的有效整合与协调。这三个要素分别是:硬件平台的选择与设计、软件开发及其优化、以及系统级的设计与集成。深入理解并熟练掌握这三个方面...

关键字: 嵌入式开发 ARM

随着汽车软件数量爆发式的增长,整个行业都需要重新思考汽车产品的开发流程。为此,Arm推出了丰富的硬件IP、新的系统IP,以及全新的汽车计算与计算子系统产品路线图,旨在为各种汽车应用实现性能、功能安全、可扩展等方面的支持。

关键字: ARM 汽车电子

知名移动芯片设计公司ARM最近迈出重要一步,它正式推出汽车芯片设计。ARM推出的芯片设计方案名叫Neoverse,随同芯片一起推出的还有面向汽车制造商、汽车供应商的新系统。

关键字: ARM 汽车芯片 芯片

随着通用人工智能的发展,数据中心的计算需求逐步提高。针对多模态数据、大模型的推理和训练需要更高的算力支持,而随着算力提升与之而来的还需更关注在功耗方面的优化。对于头部云计算和服务厂商而言,针对专门用例提高每瓦性能变得至关...

关键字: ARM 服务器 AI Neoverse CSS

一直以来,riscv架构都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来riscv架构的相关介绍,详细内容请看下文。

关键字: riscv ARM riscv架构

最新消息报道,知情人士透露Arm近日裁掉了中国70多名软件工程师,并会将部分职位转移到中国以外的地区。Arm通过“全球服务”部门已经将支持其中国客户的工作外包给安谋科技,该部门曾经拥有约200名员工。

关键字: ARM 裁员
关闭
关闭