【问题标题】:binutils ld emitting ARM BLX instructions when using armv4 targetbinutils ld 在使用 armv4 目标时发出 ARM BLX 指令
【发布时间】:2011-08-05 21:07:04
【问题描述】:

我希望为运行 Linux 2.6.32.2 内核的三星 S3C2440 SoC(基于 ARM920T 内核)编译 C 程序。我有一个在 ARM926EJS 上运行的现有 Gentoo Linux 安装。

我使用以下 gcc 选项为 S3C2440 编译 C 程序:

gcc -mcpu=arm920t -o hello hello.c

在运行编译后的可执行文件(单个 printf “hello world”)时,我只会得到“非法指令”。我没有为目标编译 GDB,并且 dmesg 没有报告错误指令的地址。

我看到在可执行文件上运行“objdump -d”会列出一条显然在 ARM920T 内核上不支持的 BLX 指令。

# gcc -mcpu=arm920t -o hello hello.c && objdump -d hello|grep blx
83cc:       e12fff33        blx     r3

经过进一步调查,BLX 似乎用于 GNU-EABI 二进制文件的 Thumb 支持,并且由“ld”生成。使用 GCC 的 '-c' 选项来编译似乎证实了这一点,因为目标文件的 objdump -d 输出中没有 BLX 指令。

BLX 指令会是我遇到的问题吗?如果是,我如何告诉“ld”不要在最终链接的可执行文件中生成 BLX 指令?


软件版本:

# ld -V
GNU ld (GNU Binutils) 2.20.1.20100303
  Supported emulations:
   armelf_linux_eabi
   armelfb_linux_eabi

# gcc -v
Using built-in specs.
Target: armv5tel-softfloat-linux-gnueabi
Configured with: /var/tmp/portage/sys-devel/gcc-4.4.5/work/gcc-4.4.5/configure --prefix=/usr --bindir=/usr/armv5tel-softfloat-linux-gnueabi/gcc-bin/4.4.5 --includedir=/usr/lib/gcc/armv5tel-softfloat-linux-gnueabi/4.4.5/include --datadir=/usr/share/gcc-data/armv5tel-softfloat-linux-gnueabi/4.4.5 --mandir=/usr/share/gcc-data/armv5tel-softfloat-linux-gnueabi/4.4.5/man --infodir=/usr/share/gcc-data/armv5tel-softfloat-linux-gnueabi/4.4.5/info --with-gxx-include-dir=/usr/lib/gcc/armv5tel-softfloat-linux-gnueabi/4.4.5/include/g++-v4 --host=armv5tel-softfloat-linux-gnueabi --build=armv5tel-softfloat-linux-gnueabi --disable-altivec --disable-fixed-point --without-ppl --without-cloog --with-float=soft --enable-nls --without-included-gettext --with-system-zlib --disable-werror --enable-secureplt --disable-multilib --enable-libmudflap --disable-libssp --enable-libgomp --with-python-dir=/share/gcc-data/armv5tel-softfloat-linux-gnueabi/4.4.5/python --enable-checking=release --disable-libgcj --with-arch=armv5te --enable-languages=c,c++,fortran --enable-shared --enable-threads=posix --enable-__cxa_atexit --enable-clocale=gnu --with-bugurl=http://bugs.gentoo.org/ --with-pkgversion='Gentoo 4.4.5 p1.2, pie-0.4.5'
Thread model: posix
gcc version 4.4.5 (Gentoo 4.4.5 p1.2, pie-0.4.5) 

【问题讨论】:

    标签: gcc arm embedded-linux binutils


    【解决方案1】:

    BLX 是来自用户代码还是库代码?既然你没有通过 -mthumb 我会打赌图书馆。您的 GCC 似乎是为 armv5tel 配置的,因此可能是 libc 或启动代码是使用 BLX 编译的,而 BLX 在 ARMv5 上受支持。如果您不确定,请将二进制文件上传到某处。

    我看到了一些你可以尝试的方法:

    1. 尝试添加 -mthumb-interwork(不太可能帮助 IMO)
    2. 如果还没有动态链接,请尝试动态链接。
    3. 尝试专门为 armv4 重建 GCC/libc。我不确定它是如何完成的,但例如CodeSourcery 工具链为 armv4 提供了一组独立的库和启动代码。

    【讨论】:

    • 为 armv4 重建 GCC 和 libc 是解决方案 - 谢谢。 BLX 指令位于 gcc ('frame_dummy') 的函数和 libc ('__libc_csu_init') 的函数中,因为它们是使用 armv5tel 配置文件构建的。在 Gentoo 中,我通过在 /etc/make.conf 中将我的 CHOST 设置为 armv4l-softfloat-linux-gnueabi 并运行“emerge binutils gcc glibc”来做到这一点。您对使用 CodeSourcery armv4 工具链的建议也可能会奏效。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-10-26
    • 1970-01-01
    • 2014-06-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多