我已经在x86 Ubuntu12.04 linux上安装了ARM交叉编译器工具链.
现在我有arm-linux-gnueabi-gcc交叉编译器.
我已经将简单的hello world程序编写为如下代码
#include <stdio.h>
int main(){
printf("hello world\n");
return 0;
}
我交叉使用
arm-linux-gnueabi-gcc -o a -c -static
编译后的二进制结果如下
$文件
一个:ELF 32位LSB可执行文件,ARM,版本1(SYSV),静态内嵌,用于GNU / Linux 2.6.31,未剥离
如果我在QEMU的ARM debian linux上运行此二进制文件
上面写着“非法指令”
但是,如果我在ARM debian linux上使用gcc编译相同的源代码,则可以正常运行.
两个二进制文件的文件结果相同.
我的交叉编译ARM二进制文件怎么了?
先感谢您.
meltdown@meltdown-VirtualBox:/var/www$arm-linux-gnueabi-readelf --file-header --arch-specific a
ELF Header:
Magic: 7f 45 4c 46 01 01 01 00 00 00 00 00 00 00 00 00
Class: ELF32
Data: 2's complement, little endian
Version: 1 (current)
OS/ABI: UNIX - System V
ABI Version: 0
Type: EXEC (Executable file)
Machine: ARM
Version: 0x1
Entry point address: 0x8881
Start of program headers: 52 (bytes into file)
Start of section headers: 368052 (bytes into file)
Flags: 0x5000002, has entry point, Version5 EABI
Size of this header: 52 (bytes)
Size of program headers: 32 (bytes)
Number of program headers: 7
Size of section headers: 40 (bytes)
Number of section headers: 30
Section header string table index: 27
Attribute Section: aeabi
File Attributes
Tag_CPU_name: "7-A"
Tag_CPU_arch: v7
Tag_CPU_arch_profile: Application
Tag_ARM_ISA_use: Yes
Tag_THUMB_ISA_use: Thumb-2
Tag_FP_arch: VFPv3-D16
Tag_ABI_PCS_wchar_t: 4
Tag_ABI_FP_denormal: Needed
Tag_ABI_FP_exceptions: Needed
Tag_ABI_FP_number_model: IEEE 754
Tag_ABI_align_needed: 8-byte
Tag_ABI_align_preserved: 8-byte, except leaf SP
Tag_ABI_enum_size: int
Tag_ABI_HardFP_use: SP and DP
Tag_CPU_unaligned_access: v6
Tag_DIV_use: Not allowed
解决方法:
您可以运行readelf命令以确定交叉编译器针对的ARM体系结构吗?我们需要查看Qemu是否支持此目标.
arm-linux-gnueabi-readelf --file-header --arch-specific a
此外,您可以在仿真系统中检查dmesg的输出.它应该包含对非法指令的描述.
另外,您可以在调试器中运行程序以查看哪个指令失败.