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 命令粘贴在下面
Run Code Online (Sandbox Code Playgroud).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
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
我发现了问题。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)