Chinaunix

标题: 关于ARM汇编指令BL的问题 [打印本页]

作者: garyv    时间: 2011-12-23 23:36
标题: 关于ARM汇编指令BL的问题
有没有熟悉ARM assembly的高手啊,现在遇到了个问题:
一个函数A位于0x00001000处,现在要在位于0xc7000000的函数B里面call 函数A,B里面都是用汇编写的,A与B之间超过32MB了,bl指令怎么用呢?
作者: tempname2    时间: 2011-12-24 22:32
把地址放到寄存器里。
作者: hzy2hzy    时间: 2011-12-25 16:15
B、BL指令都只能实现正负32M 地址空间内的跳转,通过向PC直接赋值的话,可以实现4GB地址空间内的任意跳转,要保留A程序的返回地址值,可以这样实现:

B_FUNC:

....
MOV LR,PC @保留A_FUNC返回地址
MOV PC,A_FUC@调用A_FUNC
....


A_FUC:
......
MOV PC,LR@从A_FUNC返回

作者: garyv    时间: 2011-12-27 10:03
本帖最后由 garyv 于 2011-12-27 10:04 编辑

回复 3# hzy2hzy


    楼上回复是一种解决方案,但是如果函数B定义在一个c文件里面,这段汇编是一段内嵌汇编怎么解决呢?内嵌汇编里面是不能使用标号的,用PC来算?
作者: hzy2hzy    时间: 2011-12-27 17:25
回复 4# garyv


     func_a 函数是汇编写的global函数吧,在func_b所在C函数这样用内嵌汇编调用func_a看看:

   extern void func_a(void);

   C_Function
    {
          .....
          void ((*function)(void)) = func_a;
          .....

          __asm("MOV LR,PC\n\t"
         "LDR PC,%[func]"::[func]"m"(function):"memory"); //调用func_a
     
          ....
   
    }

  

作者: garyv    时间: 2011-12-27 18:11
本帖最后由 garyv 于 2011-12-27 18:21 编辑

楼上高手写的内嵌汇编里面的"%[func]",这种语法没见过啊,是什么含义?你已经指定了"m",指通过mem传递参数了,[func]是用来干什么的呢?
作者: hzy2hzy    时间: 2011-12-28 13:02
回复 6# garyv


    asm("mov %[result], %[value], ror #1"  

: [result]"=r" (y) /* Rotation result. */  
: [value]"r" (x) /* Rotated value. */  
: /* No clobbers */  
);  
In the code section, operands are referenced by a percent sign followed by the related symbolic name enclosed in square brackets. It refers to the entry in one of the operand lists that contains the same symbolic name. From the rotating bits example:  

%[result] refers to output operand, the C variable y, and  
%[value] refers to the input operand, the C variable x.  

for more info,please refer to

共同学习
作者: garyv    时间: 2011-12-28 14:02
我见过的内嵌汇编里面一般用%0, %1, %2... 来依次表示输出/输入操作数的
作者: hzy2hzy    时间: 2011-12-29 18:04
回复 8# garyv

__asm("MOV LR,PC\n\t"
           "LDR PC,%0"::"m"(function));

这样也行,比较习惯%[name]这种形式,觉得比较清晰   
作者: garyv    时间: 2011-12-29 19:19
回复 9# hzy2hzy


    我测过了,x86的嵌入式汇编不支持这种增加标号的方式,只能用%0,%1...
我先接触的x86内嵌汇编,所以以为所有内嵌汇编都是这样的。
作者: oooooxxxxx    时间: 2012-02-03 12:28
blx 应该可以用寄存器的
这种问题查手册就好,就那么几种操作码几种寻址方式。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2