带有 objcopy 的巨大二进制文件

Dam*_*amn 5 c linker gcc 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;
}
Run Code Online (Sandbox Code Playgroud)

我的程序如下:

int a=10;
int main() {
  int b=5;
  b = (a>b)? a : b;  
  return b;
};
Run Code Online (Sandbox Code Playgroud)

如果我a声明为局部变量,即没有 .data 部分,那么一切正常。美好的。非常感谢任何帮助。

--2011 年 3 月 16 日--
任何人都可以帮忙解决这个问题,我无处可去,并且阅读了手册、论坛等......
我的引导、编译命令和 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
Run Code Online (Sandbox Code Playgroud)
  .text
start:
        ldr   sp, =0x01006000
        bl    main

stop:   b     stop
Run Code Online (Sandbox Code Playgroud)

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-目标=二进制 ./main.bin
arm-none-eabi-objdump ./main.elf --disassemble-all > ./main.dis

Dam*_*amn 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 
}
Run Code Online (Sandbox Code Playgroud)