binutils ld在使用armv4目标时发出ARM BLX指令

时间:2011-04-14 20:42:30

标签: gcc arm embedded-linux binutils

我希望为运行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”会列出一条BLX指令,而ARM920T内核显然不支持该指令。

# 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) 

1 个答案:

答案 0 :(得分:2)

BLX是来自用户代码还是库代码?既然你没有通过-mthumb,我就打赌了。看来你的GCC是为armv5tel配置的,所以libc或启动代码可能是使用BLX编译的,而ARMX5支持BLX。如果您不确定,请将二进制文件上传到某处。

我看到你可以尝试的几件事:

  1. 尝试添加-mthumb-interwork(不太可能帮助IMO)
  2. 尝试动态关联,如果不是这样的话。
  3. 尝试专门为armv4重建GCC / libc。我不确定它是如何完成的,例如CodeSourcery工具链具有独立的库集和armv4的启动代码。