bootloader---7.start.S中relocate部分分析,adr与ldr区别

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

u-bootstart.S中有这么一段

relocate:                       /* relocate U-Boot to RAM       */

       adr   r0, _start        /* r0 <- current position of code   */

       ldr   r1, _TEXT_BASE         /* test if we run from flash or RAM */

       cmp     r0, r1                  /* don't reloc during debug         */

       beq     clear_bss

       ldr   r2, _armboot_start

       ldr   r3, _bss_start

       sub  r2, r3, r2        /* r2 <- size of armboot            */

       bl  CopyCode2Ram      /* r0: source, r1: dest, r2: size */

clear_bss:

       …….

比较r0r1,如果不相等就把代码从flashcopyram中去。但问题是单从adrldr这两条指令上怎么就能判断出r0r1不相等呢?

 

既汇编搞不定那就反汇编了,汇编以上代码可以看出这两个指令有不同之处

33d800b0 :

33d800b0:   e24f00b8    sub r0, pc, #184    ; 0xb8

33d800b4:   e51f107c    ldr r1, [pc, #-124] ; 33d80040 <_text_base>

33d800b8:   e1500001    cmp r0, r1

33d800bc:   0a000003    beq 33d800d0

 

adr   r0, _start ==> 33d800b0:   e24f00b8    sub r0, pc, #184    ; 0xb8

pc-184处的标号的地址,并把这个地址赋给r0,而_start是随着加载地址的不同而变化的,所以r0是变化的。当从nandflash运行时,实际上是在sram0x0地址运行,_start的地址是0x0;而从0x33d80000处运行时,此时_start的值是0x33d80000

 

ldr   r1, _TEXT_BASE ==>800b4:   e51f107c    ldr r1, [pc, #-124]

字面意思是要取[pc, #-124]地址中的值,也就是要取_TEXT_BASE这个地址中的值,无论如何链接_TEXT_BASE的地址会变,但是_TEXT_BASE地址处的值TEXT_BASE不变。这条指令就是把 _TEXT_BASE的值也就是 .word       TEXT_BASE 赋给r1,既r1=TEXT_BASE=0x33d80000 这条指令跟程序跑在什么位置没有关系,只要定义了TEXT_BASE, 那么此处r1=TEXT_BASE.

(啰嗦了这么多,希望下一次看的时候自己能明白)

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

u-boot start.S中relocate自搬运部分分析,adr与ldr区别

版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明 http://www.blogbus.com/coon-logs/2738861.html         l...

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析 ARM汇编有ldr指令以及ldr、adr伪指令,它们都可以将标号表达式作为操作数,下面通过分析一段代码以及对应的反汇编结果来说明它们...
  • ce123
  • ce123
  • 2012年02月22日 20:09
  • 8235

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析

转自:http://blog.csdn.net/ce123/article/details/7277114 ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析 ARM汇编有...

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析 ARM汇编有ldr指令以及ldr、adr伪指令,它们都可以将标号表达式作为操作数,下面通过分析一段代码以及对应的反汇编结果来说明它...

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析

ARM汇编中的ldr和adr的区别及其在uboot中相关源码的分析 ARM汇编有ldr指令以及ldr、adr伪指令,它们都可以将标号表达式作为操作数,下面通过分析一段代码以及对应的反汇编结果来说...

ARM伪指令ADR与LDR的区别

  • 2011年08月08日 15:05
  • 5KB
  • 下载

三星uboot1.1.6源码分析——start.s(13)--C语言部分(7)

上一篇主要与NAND和环境变量有关,这一篇接着分析。 ------------------------------------------------------------------------...

三星uboot1.1.6源码分析——start.s(7)--C语言部分(1)

上一篇终于把uboot汇编部分的代码分析完了,这篇开始c语言部分代码的分析。 ------------------------------------------------------------...

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

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

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

/******************************************************************** Bootloader第一阶段的功能:(运行在Flash当中...
  • mianyy
  • mianyy
  • 2011年08月23日 15:07
  • 346
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:bootloader---7.start.S中relocate部分分析,adr与ldr区别
举报原因:
原因补充:

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