打印

linux的一段代码地址问题

[复制链接]
1884|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

粉丝