linux的一段代码地址问题

[复制链接]
2764|1
 楼主| jsun98 发表于 2007-2-6 16:32 | 显示全部楼层 |阅读模式
.extern    main
    .global    _start
    .extern    __end_data

    b        _start        
    .equ        ImageSize,__end_data-0x0AFE0100
    .long        ImageSize

_start:
    ldr    r1,=StackInit
    ldr    sp,[r1]
    and    sp, sp, #0xFFFFFFFC // to ensure sp not be odd
    b        main

    .equ        StackInitValue,    __end_data+0x1000        // 4K

StackInit:
    .long        StackInitValue
    .global    JumpToKernel
JumpToKernel:
    mov    pc, r0
    .global    JumpToKernel0x
JumpToKernel0x:
    mov    r8, r0
    mov    r0, r1
    mov    r1, r2
    mov    r2, r3
    mov    r3, r4
    mov    pc, r8
.section ".data.boot"
.section ".bss.boot"

//**************************end*****************************//


下面是lds文件
SECTIONS { . = 0x0AFE00F8; .text : { *(.text)
            *(.fixup)
            *(.rodata)
            *(.rodata.*) }
  .data : { *(.data) }
  .bss : { *(.bss) }
  __end_data = .; } 

为什么这里是0x0AFE00F8,而不是0x0AFE0100?flashloader跳转到0x0AFE0100开始执行.而看bin文件发现前面8个字节也确实不是ARM指令,为0x000000EAC73F0000

 楼主| jsun98 发表于 2007-2-7 17:55 | 显示全部楼层

搞明白了

0x000000EA是跳转指令,符合程序,然后.long在当前位置占去了4个字节,所以砍掉8个字节后就到了_start了.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

2

主题

3

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部