Ubuntuで32ビット上で64ビットプログラムをクロスコンパイルすると、「bits / c ++ config.h」が含まれていない


181

Ubuntu 10.10の32ビットバージョンを実行していて、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ファイルを、彼らは下に常駐i486-linux-gnuしてi686-linux-gnuいるディレクトリ/usr/include/c++/4.4/ありませんc++config.hでは/usr/include/c++/bits

私が欠けているものについてのアイデアはありますか?-m64フラグなしのコンパイルは正常に機能します(a.outが作成され、正しく実行されます)。

編集 @nightcrackerからのヒントのおかげで、32ビットシステムと64ビットシステムのインクルード構造についてもう少し調査しました。以下に、問題を一時的に「修正」する回答を追加しましたが、次のアップデートで壊れると思います。基本的に、インクルードファイルが不足している/usr/include/c++/4.4/i686-linux-gnu/64というサブディレクトリが含まれているはずのというディレクトリbitsが不足しています。どのパッケージがこれを処理する必要があるか考えていますか?


1
うわー...私もこの問題を抱えていました。Ubuntuを実行するARMv7-a CubieTruck(Cortex-A7)上のGCC 4.8。(私にとって)奇妙なことは、アンソニーの答えがそれを修正したことです。なんでも...
jww

回答:


308

同じ問題の私の問題を修正し、この質問を自分でブックマークできるようにしたため、この回答を部分的に追加しました。

私は次のようにしてそれを修正することができました:

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

gcc/のバージョンをインストールしg++ていて、デフォルトで出荷されていない場合(g++-4.8lucid など)、バージョンも一致させる必要があります。

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

30
gcc and g++システムにインストールされているのバージョンと一致していることを確認してください。Ubuntuの14.04で私が持っていたgcc-4.8し、g++-4.8私がインストールされて、インストールgcc-4.8-multilib してg++-4.8-multilib代わりに。
ゾルタン2014

3
これにより、64ビットマシンで-m32を使用してコンパイルするときの問題が解決しました。ありがとう
nic

41
ポインタをありがとう、しかしsudo apt-get install gcc-multilib g++-multilibより良いようです(あなたのgccバージョンに自動的に解決されます)。
leesei 2014年

^多分そうではない!@ゾルタンの提案は私にとってもうまくいった。Anthony Sottile、おそらくZoltanのコメントを回答に組み込む必要がありますか?
マン

@男は自由に編集を提案し、私が最初に投稿したとき、質問で尋ねられたバージョンと一致しました。それ以来、他の編集から変更されました
Anthony Sottile

11

追加してみました-I/usr/include/c++/4.4/i486-linux-gnu-I/usr/include/c++/4.4/i686-linux-gnu


それは確かに機能します。なぜこれを64ビットだけで実行する必要があるのか​​、何か考えはありますか?私はこのマシンを64ビットビルドの分散に役立つようにセットアップしようとしており、カスタマイズしすぎないようにしたいと考えています。
Jesse Vogt、2011年

2
申し訳ありませんが、私には
わかり

5

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ビットOSで32ビットバイナリをコンパイルできるようになりました。


1
OpenSUSEで私がやったcd /usr/include/c++/4.6;ln -s x86_64-suse-linux i586-suse-linux
Julian

3

gccのそのパッケージのタイプミスのようです。ソリューション:

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

2

私の64ビットシステムでは、次のディレクトリが存在することに気付きました。

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

次に、64ビットクロスコンパイル用にセットアップされた32ビットシステムでは、次のような対応するディレクトリがあるはずです。

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

もう一度確認したところ、このディレクトリは存在しませんでした。g++verboseパラメーターを指定して実行すると、コンパイラーが実際にこの場所で何かを探していることがわかりました。

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ビットマシンから/usr/include/c++/4.4/i686-linux-gnu/64/bits32マシンにディレクトリをコピーしました。

-m64正しく動作するようにコンパイルします。主な欠点は、これがまだ正しい方法ではないことです。次にUpdate Managerをインストールしてg ++に更新すると、壊れる可能性があると思います。



1

基本的には、HeapOverflowsまたはその他の逆転タイプの問題で使用されます。つまり、64ビットのELFを32ビットのELFに変更したいが、変換中にエラーが表示される場合。

コマンドを実行するだけです

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

アップグレードされたライブラリパッケージを更新します。

次の追加パッケージがインストールされます。 -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-dbdc ++++ 32dbg32ddc ++-6db 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 libx32g1at32gx32a5an5 8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc ++-8-dev libx32stdc ++ 6 libx32ubsan1

これと同様にあなたの端末に表示されます


0

私の経験から、sudo apt-get install gcc-multilib g++-multilib助けます。しかし、私のもう1つの問題は、ディレクトリをクリーンアップするのを忘れたため、同じエラーが発生することです。clangまたはcmakeを使用するのは初めてです。したがって、元のディレクトリを削除して再コンパイルするだけで機能します。それが私のような誰かを助けることを願っています。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.