带有objcopy的巨大二进制文件

时间:2011-03-08 16:04:52

标签: c gcc linker arm objcopy

我在ARM9处理器的基本C程序中定义全局变量时遇到问题。我正在使用EABI GNU编译器,12KB精灵生成的二进制文件是4GB!我假设问题出在我的分散文件中,但我无法理解它。

我有256KB的ROM(基地址0xFFFF0000)和32KB的RAM(基地0x01000000)

SECTIONS {
  . = 0xFFFF0000;
  .text : {
    * (vectors);
    * (.text);
  }
  .rodata : { *(.rodata) }
  . = 0x01000000;
  sbss = .;
  .data : { *(.data) }
  .bss  : { *(.bss) }
  ebss = .;
  bssSize = ebss - sbss;
}

我的计划如下:

int a=10;
int main() {
  int b=5;
  b = (a>b)? a : b;  
  return b;
};

如果我将 a 声明为局部变量,即没有.data部分,则一切正常。  精细。非常感谢任何帮助。

- 2011年3月16日 -
任何人都可以帮助这个,我无处可读,阅读手册,论坛等... 我的boot,compile命令和objcopy命令粘贴在

下面
     .section "vectors"
reset:  b   start
undef:  b   undef
swi:    b   swi
pabt:   b   pabt
dabt:   b   dabt
    nop
irq:    b   irq
fiq:    b   fiq
  .text
start:
        ldr   sp, =0x01006000
        bl    main

stop:   b     stop
  

arm-none-eabi-gcc -mcpu = arm926ej -s -Wall -nostartfiles -Wall main.c boot.s -o main.elf -T \ scatter_file
  arm-none-eabi-objcopy ./main.elf --output-target = binary ./main.bin
  arm-none-eabi-objdump ./main.elf --disassemble-all> ./main.dis

2 个答案:

答案 0 :(得分:2)

您正在创建一个文件,该文件将从地址0x01000000开始,并且至少包含地址0xFFFF0000。难怪它接近4GB。你喜欢什么?如果您不想要它们,请尝试使用选项-R来删除数据段(如果您准备ROM初始化文件可能就是这种情况)。

答案 1 :(得分:2)

我发现了问题。 objcopy命令将尝试创建链接描述文件中描述的整个地址空间,从最低地址到最高地址,包括其间的所有地址。您可以告诉它只生成ROM代码,如下所示:

  

objcopy ./main.elf -j ROM --output-target = binary ./main.bin

我也稍微改变了链接描述文件

MEMORY {
  ram(WXAIL) : ORIGIN = 0x01000000, LENGTH = 32K    
  rom(RX)    : ORIGIN = 0xFFFF0000, LENGTH = 32K                    
}

SECTIONS {
  ROM : { 
    *(vectors);
    *(.text);
    *(.rodata);
  } > rom 

  RAM : {
    *(.data); 
    *(.bss);
  } > ram 
}