【发布时间】:2018-06-01 14:10:12
【问题描述】:
我正在尝试使用 Linux 2.6.31 为基于 QCA955X 的路由器设置 GCC 4.9.4 交叉编译器。这是一个使用uClibc-0.9.30.1 的MIPS32R2-abi CPU(在/lib 中找到)。因此,我决定用匹配的uClibc 和binutils-2.19.1a 编译一个GCC 4.x。我的主机系统是 Ubuntu 18.04,带有 Linux 4.17-rc5 和 gcc version 7.3.0 (Ubuntu 7.3.0-16ubuntu3)
~/mips-cross-gcc/staging_dir 是我的前缀,~/mips-cross-gcc/staging_dir/sysroot 是我系统的临时 sysroot。
1) 我将binutils-2.19.1a.tar.bz2、gcc-4.9.4.tar.bz2、linux-2.6.31.9.tar.xz 和uClibc-0.9.30.1.tar.bz2 下载到~/mips-cross-gcc/sources。
2) 我解压了所有来源。
3) 安装 linux 头文件:
make ARCH=mips INSTALL_HDR_PATH=/home/user/mips-cross-gcc/staging_dir/sysroot/usr headers_install
4) 构建 binutils:
cd binutils-2.19.1
./configure --prefix=/home/user/mips-cross-gcc/staging_dir --target=mips-linux-uclibc --disable-multilib --disable-werror --enable-shared --without-newlib --with-sysroot=/home/user/mips-cross-gcc/staging_dir/sysroot --enable-languages=c,c++ --disable-libgomp
make all-binutils
make all-ld
make all-gas
make install-binutils
make install-ld
make install-gas
5) 构建“阶段 1”gcc,以引导 uClibc:
cd gcc-4.9.4
mkdir -p build/gcc-stage1
../../configure --target=mips-linux-uclibc --prefix=/home/user/mips-cross-gcc/staging_dir --disable-werror --disable-libgomp --without-newlib --disable-multilib --enable-languages=c,c++ --enable-shared --disable-__cxa_atexit --enable-target-optspace --disable-nls --disable-libmudflap --disable-libssp --with-float=soft --with-sysroot=/home/user/mips-cross-gcc/staging_dir/sysroot --with-gnu-ld --without-headers
make all-gcc
make install-gcc
6) 安装 uClibc 头文件:
cd uClibc-0.9.30.1
make PREFIX=/home/user/mips-cross-gcc/staging_dir/sysroot install_headers
7) 为目标架构构建 libgcc: cd gcc-4.9.4 制作全目标libgcc
Libgcc 一直编译到最后的 libgcc_s 链接阶段:
/home/daniel/mips-cross-gcc/staging_dir/mips-linux-uclibc/bin/ld: cannot find -lc
collect2: error: ld returned 1 exit status
Makefile:937: recipe for target 'libgcc_s.so' failed
我认为引导GCC 不需要libc,因为它还没有被编译,对吧?我可能做错了什么?我会使用这个编译的GCC 来构建uClibc,然后我会用我的新uClibc 再次编译GCC,这样我就可以交叉编译软件。 GCC 在第一次构建中需要 libc 的事实似乎是错误的。
我尝试使用第一个 gcc 而不编译 libgcc 来构建 uClibc,但我几乎立即收到了:
LD ld-uClibc-0.9.30.1.so
mips-linux-uclibc-gcc: error: libgcc.a: No such file or directory
ldso/ldso/Makefile.in:54: recipe for target 'lib/ld-uClibc.so' failed
所以,uClibc 需要 libgcc 来链接自己,而 gcc 需要 libc(任何类型,包括 uClibc)来链接自己的 libgcc。这似乎是一个先有鸡还是先有蛋的问题。如何解决这个问题?
【问题讨论】:
-
路由器固件是否有“官方”构建机制来负责设置工具链?例如,OpenWrt 使用基于 Buildroot 的构建系统。或者您是否正在尝试构建将在路由器本身上运行的 C 编译器?
-
有,但是这是一个使用 Openwrt "Kamikaze" 衍生固件的路由器,未发布修改。 Openwrt buildroot 使用旧脚本,并且在现代计算机上调试的错误太多,遗憾的是。 Kamikaze 已经很老了,它使用的 svn 服务器也永远消失了。所以,这是我目前唯一的选择:(
-
关于在最新主机上使用旧的构建系统,我偶尔会为此设置 Docker 容器(基于一些旧的 Linux 发行版)。但是,缺少 svn 服务器也无济于事!
标签: c linux gcc cross-compiling uclibc