在 Ubuntu 中在 32 位上交叉编译 64 位程序时缺少包含“bits/c++config.h”

Posted

技术标签:

【中文标题】在 Ubuntu 中在 32 位上交叉编译 64 位程序时缺少包含“bits/c++config.h”【英文标题】:Missing include "bits/c++config.h" when cross compiling 64 bit program on 32 bit in Ubuntu 【发布时间】:2011-06-06 07:18:33 【问题描述】:

我正在运行 32 位版本的 Ubuntu 10.10 并尝试交叉编译为 64 位目标。根据我的研究,我已经安装了 g++-multilib 包。

程序是一个非常简单的hello world:

#include <iostream>

int main( int argc, char** argv )

  std::cout << "hello world" << std::endl;
  return 0;

编译:

g++ -m64 main.cpp

错误:

In file included from main.cpp:1:
/usr/include/c++/4.4/iostream:39: fatal error: bits/c++config.h: No such file or directory
compilation terminated.

我找到了一个c++config.h 文件,但它们位于/usr/include/c++/4.4/ 中的i486-linux-gnui686-linux-gnu 目录下/usr/include/c++/bits 中没有c++config.h

关于我缺少什么的任何想法?不带-m64 标志的编译工作正常(a.out 已创建并正确运行)。

编辑感谢@nightcracker 的提示,我对 32 位和 64 位系统上的包含结构进行了更多调查。我在下面添加了一个answer,它暂时“修复”了这个问题,但我认为它会在下一次更新时中断。基本上,我缺少一个名为/usr/include/c++/4.4/i686-linux-gnu/64 的目录,该目录应该包含一个名为bits 的子目录,其中缺少包含文件。知道应该用什么包来解决这个问题吗?

【问题讨论】:

哇...我也有这个问题。运行 Ubuntu 的 ARMv7-a CubieTruck (Cortex-A7) 上的 GCC 4.8。 (对我来说)奇怪的是,安东尼的回答解决了这个问题。随便... 【参考方案1】:

部分添加此答案是因为它解决了我的同一问题,因此我可以自己为这个问题添加书签。

我能够通过执行以下操作来修复它:

sudo apt-get install gcc-multilib g++-multilib

如果您安装了默认不提供的 gcc / g++ 版本(例如 lucid 上的 g++-4.8),您也需要匹配该版本:

sudo apt-get install gcc-4.8-multilib g++-4.8-multilib

【讨论】:

确保与系统上安装的gcc and g++ 的版本相匹配。在 Ubuntu 14.04 上,我安装了 gcc-4.8g++-4.8,所以我安装了 gcc-4.8-multilib g++-4.8-multilib 这解决了我在 64 位机器上使用 -m32 编译时的问题。谢谢 感谢您的指点,但sudo apt-get install gcc-multilib g++-multilib 似乎更好(它会自动解析为您的 gcc 版本)。 ^也许不是! @Zoltan 的建议对我有用。 Anthony Sottile,也许您应该在回答中加入 Zoltan 的评论? @Man 随时提出修改建议,当我最初发布它时,我匹配了问题中提出的版本,它已经从其他人的修改中改变了【参考方案2】:

您是否尝试添加-I/usr/include/c++/4.4/i486-linux-gnu-I/usr/include/c++/4.4/i686-linux-gnu

【讨论】:

确实有效。关于为什么我只需要为 64 位执行此操作的任何想法?我正在尝试设置这台机器以帮助进行分布式 64 位构建,并希望避免过多的自定义。 对不起,我不知道,我只是提出了一个快速的 hacky 工作解决方案 :) 仅仅因为“bits/c++config.h”就在那里:)【参考方案3】:

在 RHEL 6.2 (x86_64) 中编译时,我安装了 32 位和 64 位 libstdc++-dev 软件包,但我遇到了“c++config.h 没有此类文件或目录”的问题。

分辨率:

目录/usr/include/c++/4.4.6/x86_64-redhat-linux 丢失。

我做了以下事情:

cd /usr/include/c++/4.4.6/
mkdir x86_64-redhat-linux
cd x86_64-redhat-linux
ln -s ../i686-redhat-linux 32

我现在可以在 64 位操作系统上编译 32 位二进制文​​件。

【讨论】:

在 OpenSUSE 上我做了cd /usr/include/c++/4.6;ln -s x86_64-suse-linux i586-suse-linux【参考方案4】:

似乎是那个 gcc 包中的拼写错误。解决办法:

mv /usr/include/c++/4.x/i486-linux-gnu /usr/include/c++/4.x/i686-linux-gnu/64

【讨论】:

【参考方案5】:

基本上它用于 HeapOverflows 或其他反转类型的问题,即如果您想将 64 位 ELF 更改为 32 位 ELF,并且在转换时显示错误。

你可以简单地运行命令

apt-get install gcc-multilib g++-multilib

这将更新您的库 升级包:

将安装以下附加软件包: g++-8-multilib gcc-8-multilib lib32asan5 lib32atomic1 lib32gcc-8-dev lib32gomp1 lib32itm1 lib32mpx2 lib32quadmath0 lib32stdc++-8-dev lib32ubsan1 libc-dev-bin libc6 libc6-dbg libc6-dev libc6-dev-i386 libc6-dev-x32 libc6-i386 libc6-x32 libx32asan5 libx32atomic1 libx32gcc-8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc++-8-dev libx32stdc++6 libx32ubsan1 推荐套餐: lib32stdc++6-8-dbg libx32stdc++6-8-dbg glibc-doc 将安装以下新软件包: g++-8-multilib g++-multilib gcc-8-multilib gcc-multilib lib32asan5 lib32atomic1 lib32gcc-8-dev lib32gomp1 lib32itm1 lib32mpx2 lib32quadmath0 lib32stdc++-8-dev lib32ubsan1 libc6-dev-i386 libc6-dev-x32 libc6-x32 libx32asan5 libx32atomic1 libx32gcc-8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc++-8-dev libx32stdc++6 libx32ubsan1

类似的会显示到你的终端

【讨论】:

在 Debian 10 上,我想保留的一些软件包已被删除。以下软件包将被删除: g++-8-arm-linux-gnueabi g++-8-arm-linux-gnueabihf g++-arm-linux-gnueabi g++-arm-linux-gnueabihf gcc-8-aarch64-linux-gnu gcc- 8-arm-linux-gnueabi gcc-8-arm-linux-gnueabihf gcc-aarch64-linux-gnu gcc-arm-linux-gnueabi gcc-arm-linux-gnueabihf【参考方案6】:

在我的 64 位系统上,我注意到存在以下目录:

/usr/include/c++/4.4/x86_64-linux-gnu/32/bits

在我的 32 位系统上设置为 64 位交叉编译应该有一个相应的目录,如:

/usr/include/c++/4.4/i686-linux-gnu/64/bits

我仔细检查过,这个目录不存在。使用 verbose 参数运行 g++ 表明编译器实际上是在这个位置寻找东西:

jesse@shalored:~/projects/test$ g++ -v -m64 main.cpp 
Using built-in specs.
Target: i686-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.4.4-14ubuntu5' --with-bugurl=file:///usr/share/doc/gcc-4.4/README.Bugs --enable-languages=c,c++,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.4 --enable-shared --enable-multiarch --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.4 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-objc-gc --enable-targets=all --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=i686-linux-gnu --host=i686-linux-gnu --target=i686-linux-gnu
Thread model: posix
gcc version 4.4.5 (Ubuntu/Linaro 4.4.4-14ubuntu5) 
COLLECT_GCC_OPTIONS='-v' '-m64' '-shared-libgcc' '-mtune=generic'
 /usr/lib/gcc/i686-linux-gnu/4.4.5/cc1plus -quiet -v -imultilib 64 -D_GNU_SOURCE main.cpp -D_FORTIFY_SOURCE=2 -quiet -dumpbase main.cpp -m64 -mtune=generic -auxbase main -version -fstack-protector -o /tmp/ccMvIfFH.s
ignoring nonexistent directory "/usr/include/c++/4.4/i686-linux-gnu/64"
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring nonexistent directory "/usr/lib/gcc/i686-linux-gnu/4.4.5/../../../../i686-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/include/c++/4.4
 /usr/include/c++/4.4/backward
 /usr/local/include
 /usr/lib/gcc/i686-linux-gnu/4.4.5/include
 /usr/lib/gcc/i686-linux-gnu/4.4.5/include-fixed
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
GNU C++ (Ubuntu/Linaro 4.4.4-14ubuntu5) version 4.4.5 (i686-linux-gnu)
    compiled by GNU C version 4.4.5, GMP version 4.3.2, MPFR version 3.0.0-p3.
GGC heuristics: --param ggc-min-expand=98 --param ggc-min-heapsize=128197
Compiler executable checksum: 1fe36891f4a5f71e4a498e712867261c
In file included from main.cpp:1:
/usr/include/c++/4.4/iostream:39: fatal error: bits/c++config.h: No such file or directory
compilation terminated.

关于ignoring nonexistent directory 的错误是线索。不幸的是,我仍然不知道需要安装什么软件包才能显示此目录,所以我只是将 /usr/include/c++/4.4/x86_64-linux-gnu/bits 目录从我的 64 位机器复制到了我的 32 机器上的 /usr/include/c++/4.4/i686-linux-gnu/64/bits

现在仅使用 -m64 进行编译可以正常工作。主要缺点是这仍然不是正确的处理方式,我猜下次更新管理器安装和更新到 g++ 时可能会中断。

【讨论】:

【参考方案7】:

此错误已在“gcc-4.6”中修复。

https://bugs.launchpad.net/ubuntu/+source/gcc-4.5/+bug/793411

【讨论】:

【参考方案8】:

根据我的经验,sudo apt-get install gcc-multilib g++-multilib 会有所帮助。但我的另一个问题是我忘记清理目录,所以我仍然得到同样的错误。这是第一次使用clang或cmake。所以我只是删除了我的原始目录并重新编译它就可以了。希望它可以帮助像我这样的人。

【讨论】:

【参考方案9】:

就我而言,这只是一个路径问题。我减少了源文件的路径长度并且它起作用了......

【讨论】:

以上是关于在 Ubuntu 中在 32 位上交叉编译 64 位程序时缺少包含“bits/c++config.h”的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Ubuntu 上交叉编译 ARM 架构的 CGO 程序

在ubuntu上交叉编译Boost 1.57.0 for arm

windows上交叉编译go程序

windows上交叉编译go程序

致命错误:gnu / stubs-soft.h:没有这样的文件或目录

mp4v2开发笔记: mp4v2库介绍,mp4v2在ubuntu上交叉编译移植到海思Hi35xx平台