linux-ARM交叉编译

我已经在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的输出.它应该包含对非法指令的描述.

另外,您可以在调试器中运行程序以查看哪个指令失败.

上一篇:使用什么技术/方法即时编译Java? [包含视频]


下一篇:java-Eclipse->错误:找不到或加载主类你好