2011-04-14 68 views
1

我希望爲運行Linux 2.6.32.2內核的三星S3C2440 SoC(基於ARM920T內核)編譯C程序。我有一個現有的Gentoo Linux安裝在ARM926EJS上運行。binutils ld使用armv4目標時發射ARM BLX指令

我編譯使用以下的gcc選項S3C2440的C程序:

gcc -mcpu=arm920t -o hello hello.c 

在運行編譯的可執行文件(一個單一的printf的 「Hello World」),我只是得到 '非法指令'。我沒有針對目標編譯的GDB,並且dmesg不報告錯誤指令的地址。

我看到,在可執行文件上運行「objdump -d」列出了ARMX芯片明顯不支持的BLX指令。

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

隨着進一步的調查,似乎BLX用於與GNU-EABI二進制拇指的支持,並通過「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) 

回答

2

是對BLX從用戶代碼或庫中的代碼來了嗎?既然你沒有通過-mthumb我會賭上圖書館。看起來你的GCC是爲armv5tel配置的,所以可能libc或者啓動代碼都是使用ARMv5支持的BLX編譯的。如果您不確定,請將該二進制文件上傳到某處。

我看到幾件事情,你可以嘗試:

  1. 嘗試增加-mthumb-互通(不太可能有幫助IMO)
  2. 嘗試動態鏈接,如果不是已經是這樣了。
  3. 嘗試專門爲armv4重建您的GCC/libc。我不確定它是如何完成的,但例如CodeSourcery工具鏈有單獨的一套庫和armv4的啓動代碼。
+0

爲armv4重建海灣合作委員會和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工具鏈的建議可能也會起作用。 – matja 2011-04-16 17:17:25