gpt4 book ai didi

gcc - 构建交叉编译 64 位 GCC 失败

转载 作者:行者123 更新时间:2023-12-04 14:43:21 25 4
gpt4 key购买 nike

我正在尝试创建一个运行在我本地机器上的 gcc 交叉编译器 [Darwin new-host-2.home 10.7.4 Darwin Kernel Version 10.7.4: Mon Apr 18 21:24:17 PDT 2011; root:xnu-1504.14.12~3/RELEASE_X86_64 x86_64] 并针对 FreeBSD 8.2 x86_64(FreeBSD 术语中的 AMD64)目标。

我正在编译 gcc 4.3.1、binutils 2.19、GMP 4.2.3、MPFR 2.3.2。

我看到一些可能出错的事情,但它们可能是红鲱鱼。值得一提的是,我正在使用已知的工作脚本来构建交叉编译器,并且只是试图让它们适用于 x86_64 体系结构,所以我知道我不在左边的领域。

我正在使用 gcc 编译器目标“x86_64-pc-freebsd7”,这似乎是正确的。我使用以下编译器标志:compilerConfigureFlags="--enable-version-specific-runtime-libs --enable-shared --enable-threads=posix --disable-checking --disable-libunwind-exceptions --with-system-zlib --enable-__cxa_atexit"我使用 "--enable-64-bit-bfd" 配置 binutils

在我最后的错误中;引起我注意的是“-m32”,我不确定它是否应该在那里。错误是因为 ld 无法理解我的“不兼容”文件 /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/libc.a 当搜索-lc .当我跑 file在 FreeBSD 框中的 libc.a 和 libc.so 上,我得到:

sh-3.2# file /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/libc.a/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/libc.a: current ar archive


sh-3.2# file /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/libc.so/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/libc.so: ELF 64-bit LSB shared object, x86-64, version 1 (FreeBSD), dynamically linked, stripped


我的构建的最后一行死在:

/Developer/Cocotron/1.0/build/FreeBSD/x86_64/gcc-4.3.1/./gcc/xgcc -B/Developer/Cocotron/1.0/build/FreeBSD/x86_64/gcc-4.3.1/./gcc/ -B/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ -B/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/ -isystem /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/include -isystem /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/sys-include -O2 -O2 -g -m32 -DIN_GCC -DCROSS_DIRECTORY_STRUCTURE -DNATIVE_CROSS -W -Wall -Wwrite-strings -Wstrict-prototypes -Wmissing-prototypes -Wold-style-definition -isystem ./include -fPIC -pthread -g -DHAVE_GTHR_DEFAULT -DIN_LIBGCC2 -D__GCC_FLOAT_NOT_NEEDED -shared -nodefaultlibs -Wl,--soname=libgcc_s.so.1 -Wl,--version-script=libgcc.map -o ./libgcc_s.so.1.tmp -O2 -g -m32 -B./ _muldi3_s.o _negdi2_s.o _lshrdi3_s.o _ashldi3_s.o _ashrdi3_s.o _cmpdi2_s.o _ucmpdi2_s.o _clear_cache_s.o _enable_execute_stack_s.o _trampoline_s.o __main_s.o _absvsi2_s.o _absvdi2_s.o _addvsi3_s.o _addvdi3_s.o _subvsi3_s.o _subvdi3_s.o _mulvsi3_s.o _mulvdi3_s.o _negvsi2_s.o _negvdi2_s.o _ctors_s.o _ffssi2_s.o _ffsdi2_s.o _clz_s.o _clzsi2_s.o _clzdi2_s.o _ctzsi2_s.o _ctzdi2_s.o _popcount_tab_s.o _popcountsi2_s.o _popcountdi2_s.o _paritysi2_s.o _paritydi2_s.o _powisf2_s.o _powidf2_s.o _powixf2_s.o _powitf2_s.o _mulsc3_s.o _muldc3_s.o _mulxc3_s.o _multc3_s.o _divsc3_s.o _divdc3_s.o _divxc3_s.o _divtc3_s.o _bswapsi2_s.o _bswapdi2_s.o _fixunssfsi_s.o _fixunsdfsi_s.o _fixunsxfsi_s.o _fixsfdi_s.o _fixdfdi_s.o _fixxfdi_s.o _fixtfdi_s.o _fixunssfdi_s.o _fixunsdfdi_s.o _fixunsxfdi_s.o _fixunstfdi_s.o _floatdisf_s.o _floatdidf_s.o _floatdixf_s.o _floatditf_s.o _floatundisf_s.o _floatundidf_s.o _floatundixf_s.o _floatunditf_s.o _divdi3_s.o _moddi3_s.o _udivdi3_s.o _umoddi3_s.o _udiv_w_sdiv_s.o _udivmoddi4_s.o unwind-dw2_s.o unwind-dw2-fde_s.o unwind-sjlj_s.o gthr-gnat_s.o unwind-c_s.o emutls_s.o -lc && rm -f ./libgcc_s.so && if [ -f ./libgcc_s.so.1 ]; then mv -f ./libgcc_s.so.1 ./libgcc_s.so.1.backup; else true; fi && mv ./libgcc_s.so.1.tmp ./libgcc_s.so.1 && ln -s libgcc_s.so.1 ./libgcc_s.so/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ld: skipping incompatible /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib//libc.so when searching for -lc/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ld: skipping incompatible /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/lib/libc.a when searching for -lc/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ld: cannot find -lccollect2: ld returned 1 exit statusmake[2]: *** [libgcc_s.so] Error 1make[1]: *** [all-target-libgcc] Error 2make: *** [all] Error 2


我很惊讶 ld 无法处理它,因为当我运行这个版本的“ld”时,我得到了以下输出:

/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ld: supported targets: elf64-x86-64-freebsd elf32-i386-freebsd coff-i386 efi-app-ia32 efi-bsdrv-ia32 efi-rtdrv-ia32 efi-app-x86_64 efi-bsdrv-x86_64 efi-rtdrv-x86_64 elf32-i386 elf64-x86-64 elf64-little elf64-big elf32-little elf32-big srec symbolsrec tekhex binary ihex/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ld: supported emulations: elf_x86_64_fbsd elf_i386_fbsd elf_x86_64 elf_i386/Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/x86_64-pc-freebsd7/bin/ld: emulation specific options:elf_x86_64_fbsd:


这向我表明我已经正确构建了 binutils .. 但它无法处理 ELF 64 位 x86-64 FreeBSD 共享对象的库?

从一开始就讲这个故事 - 编译 binutils 似乎是完美的。

编译 GMP 和 MPFR 都给了我一些让我有点担心的 ranlib 问题,试图建立一个 .a 库但 .o 文件没有符号..这可能是正常的,但我不知道?

GMP:

/usr/bin/ranlib: file: .libs/libprintf.a(obprintf.o) has no symbols/usr/bin/ranlib: file: .libs/libprintf.a(obvprintf.o) has no symbols/usr/bin/ranlib: file: .libs/libprintf.a(obprntffuns.o) has no symbols/usr/bin/ranlib: file: .libs/libprintf.a(repl-vsnprintf.o) has no symbolsranlib .libs/libprintf.aranlib: file: .libs/libprintf.a(obprintf.o) has no symbolsranlib: file: .libs/libprintf.a(obvprintf.o) has no symbolsranlib: file: .libs/libprintf.a(obprntffuns.o) has no symbolsranlib: file: .libs/libprintf.a(repl-vsnprintf.o) has no symbols


我得到了更多的进展..

ranlib /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libgmp.aranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libgmp.a(mp_clz_tab.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libgmp.a(obprintf.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libgmp.a(obvprintf.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libgmp.a(obprntffuns.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libgmp.a(repl-vsnprintf.o) has no symbols


MPFR:

类似交易:

/usr/bin/ranlib: file: .libs/libmpfr.a(volatile.o) has no symbols/usr/bin/ranlib: file: .libs/libmpfr.a(mp_clz_tab.o) has no symbols/usr/bin/ranlib: file: .libs/libmpfr.a(logging.o) has no symbols/usr/bin/ranlib: file: .libs/libmpfr.a(set_d64.o) has no symbols/usr/bin/ranlib: file: .libs/libmpfr.a(get_d64.o) has no symbolsranlib .libs/libmpfr.aranlib: file: .libs/libmpfr.a(volatile.o) has no symbolsranlib: file: .libs/libmpfr.a(mp_clz_tab.o) has no symbolsranlib: file: .libs/libmpfr.a(logging.o) has no symbolsranlib: file: .libs/libmpfr.a(set_d64.o) has no symbolsranlib: file: .libs/libmpfr.a(get_d64.o) has no symbolscreating libmpfr.la



再往前走一点..

ranlib /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libmpfr.aranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libmpfr.a(volatile.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libmpfr.a(mp_clz_tab.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libmpfr.a(logging.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libmpfr.a(set_d64.o) has no symbolsranlib: file: /Developer/Cocotron/1.0/FreeBSD/x86_64/gcc-4.3.1/lib/libmpfr.a(get_d64.o) has no symbols


然后我们进入 GCC,大概有良好的 binutils、GMP 和 MPFR .. 但最后在 gcc(特别是 libgcc)的构建过程中我得到了 ld 链接失败。

一些更多的支持信息:

我使用以下命令编译 binutils:

CFLAGS="-m32 -Wformat=0 -Wno-error=deprecated-declarations" $sourceFolder/binutils-$binutilsVersion/configure --prefix="$resultFolder" --target=$compilerTarget $binutilsConfigureFlags


但是,如果我切换到 -m64 ,我会遇到同样的问题。

CFLAGS="-m64 -Wformat=0 -Wno-error=deprecated-declarations" $sourceFolder/binutils-$binutilsVersion/configure --prefix="$resultFolder" --target=$compilerTarget $binutilsConfigureFlags


我使用以下方法编译 GMP 和 MPFR:

ABI=32 $sourceFolder/gmp-$gmpVersion/configure --prefix="$resultFolder"


我使用以下命令编译 GCC:

CFLAGS="-m32" $sourceFolder/gcc-$gccVersion/configure -v --prefix="$resultFolder" --target=$compilerTarget \ --with-gnu-as --with-gnu-ld --with-headers=$resultFolder/$compilerTarget/include \ --without-newlib --disable-multilib --disable-libssp --disable-nls --enable-languages="$enableLanguages" \ --with-gmp=$buildFolder/gmp-$gmpVersion --enable-decimal-float --with-mpfr=$resultFolder --enable-checking=release \ --enable-objc-gc \
$compilerConfigureFlags


对于所有这些,我正在使用:

compilerTarget=x86_64-pc-freebsd7compilerConfigureFlags="--enable-version-specific-runtime-libs --enable-shared --enable-threads=posix --disable-checking --disable-libunwind-exceptions --with-system-zlib --enable-__cxa_atexit"binutilsConfigureFlags="--enable-64-bit-bfd"


在我的目标 FreeBSD 系统上,顺便说一下,它是标准的 FreeBSD 8.2 RELEASE amd64,ld 表示与我的交叉编译系统非常相似的功能。事实上,我的交叉编译环境的 ld 似乎处理了实际目标的 ld 处理内容的超集 - 让我觉得我应该能够处理任何文件而不会出现我所看到的不兼容性

ld: supported targets: elf64-x86-64 efi-app-ia32 elf32-i386-freebsd srec symbolsrec tekhex binary ihexld: supported emulations: elf_i386_fbsd elf_x86_64_fbsdld: emulation specific options:elf_i386_fbsd:

最佳答案

64 位库只能链接到 64 位目标代码。您需要 -m64构建 64 位目标代码,-m32确实产生 32 位目标代码。

关于gcc - 构建交叉编译 64 位 GCC 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6159450/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com