bootloader---8.start.S中关于bl指令的理解

原创 2016年08月29日 13:51:33

编译u-boot时,在Makefile 的ALL变量最后加上$(obj)u-boot.dis,会编译出u-boot.dis,u-boot.dis是通过arm-linux-objdum –d 生成u-boot的每一条指令的反汇编。

33d80080:    e59f13f4     ldr    r1, [pc, #1012]    
33d80084:    e59f03f4     ldr    r0, [pc, #1012]    
33d80088:    e5801000   str    r1, [r0] 
33d8008c:     eb000015   bl     33d800e8

………

33d800e8 : 
33d800e8:    e3a00000     mov    r0, #0    ; 0x0

上面的bl指令,从表面上看 bl 33d800e8,好像是跳到了绝对地址0x33d800e8处,此时是运行在绝对0x0地址处,然后用bl一下子跳到了内存地址0x33d800e8处,可是此时内存都还没有初始化就运行,这怎么可能?

这好像是很矛盾,但仔细分析一下,原来是这样的:

将 eb000015  转为二进制:

1110  1011  0000  0000 0000 0000  0001  0101

branch_format

看一下它的具体含义,下面是b/bl 指令的格式-- 出自《ARM Instruction Set》

31-28 –> cond

27-25 –> 101

24     --> L

23-0 –> offset

    "Branch instructions contain a signed 2's complement 24 bit offset. This is shifted left two bits, sign extended to 32 bits, and added to the PC. The instruction can therefore specify a branch of +/- 32Mbytes. The branch offset must take account of the prefetch operation, which causes the PC to be 2 words (8 bytes) ahead of the current instruction. Branches beyond +/- 32Mbytes must use an offset or absolute destination which has been previously loaded into a register. In this case the PC should be manually saved in R14 if a Branch with Link type operation is required.“ 出自《ARM Instruction Set》


1110 –> cond –> always 无条件跳转

27-25 –> 说明是B 跳转指令

24 –> L位 Branch with Link, 跳转时将下一条指令的地址拷贝到R14(lr)中

23-0 –> offset=0x15

执行bl后:pc = 当前pc + ( offset<<2 + 8 ) = 0x8c+(0x15<<2+8)= 0xE8

跳到偏移地址为0xE8的地方,也就是 cpu_init_crit函数中。

版权声明:本文为博主原创文章,转载请注明出处。

ARM汇编指令(B/BL/BX) - (8)

跳转指令用于实现程序流程的跳转,在 ARM 程序中有两种方法可以实现程序流程的跳转: (1) 使用专门的跳转指令。 (2) 直接向程序计数器 PC 写入跳转地址值。     通过向程...

自己写bootloader笔记2---start.S分析

1、程序 #define S3C2440_MPLL_200MHZ     ((0x5c #define MEM_CTL_BASE    0x48000000 //.text表示一个代码段 .te...

自己写bootloader笔记2---start.S分析

1、框架 (1)关看门狗//对2440来说,看门狗一上电是打开的,不关掉过3秒会复位整个开发板 (2)设置时钟//2440一上电时运行频率是12M,所以要让它能运行更快点 (3)初始化SDRAM...
  • bfboys
  • bfboys
  • 2016年09月04日 17:01
  • 173

19、Bootloader(3) -- U-Boot第一阶段代码start.S分析

/******************************************************************** Bootloader第一阶段的功能:(运行在Flash当中...
  • mianyy
  • mianyy
  • 2011年08月23日 15:07
  • 346

stm8s 实践课程之IAP设计编码(bootloader实现)

项目实践1:Bootloader 1.   项目介绍 在之前的例程和实践中,我们都是使用st-link调试下载的方式进行程序烧录。大家可能已经认识到这种烧录方式的弊端了。因为这种烧录方式首先必须要...

Uboot中start.S源码的指令级的详尽解析(二)

第 2 章 start.S的总结 目录 2.1. start.S各个部分的总结2.2. Uboot中的内存的Layout 摘要 2.1....
  • yuzeze
  • yuzeze
  • 2016年06月23日 14:36
  • 359
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:bootloader---8.start.S中关于bl指令的理解
举报原因:
原因补充:

(最多只允许输入30个字)