Отсутствует include «bits / c ++ config.h» при кросс-компиляции 64-битной программы на 32-битной в Ubuntu

181

Я использую 32-битную версию Ubuntu 10.10 и пытаюсь выполнить кросс-компиляцию для 64-битной цели. Основываясь на моих исследованиях, я установил пакет g ++ - multilib.

Программа очень проста:

#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/Eсть не c++config.hв /usr/include/c++/bits.

Любые идеи о том, что мне не хватает? Компиляция без -m64флага работает нормально (a.out создан и работает правильно).

Редактировать Благодаря подсказке @nightcracker я немного больше изучил структуру include в 32- и 64-битных системах. Ниже я добавил ответ, который временно «исправляет» проблему, но думаю, что она будет сломана при следующем обновлении. По сути, мне не хватает каталога, /usr/include/c++/4.4/i686-linux-gnu/64который должен содержать подкаталог bitsс отсутствующим включаемым файлом. Любая идея, какой пакет должен заботиться об этом?

Джесси Фогт
источник
1
Вау ... У меня тоже была эта проблема. GCC 4.8 на ARMv7-CubieTruck (Cortex-A7) под управлением Ubuntu. Странная вещь (для меня) в том, что ответ Энтони исправил это. Безотносительно ...
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вместо этого.
Золтан
3
Это решило мою проблему при компиляции с -m32 на 64-битной машине. Спасибо
приятель
41
Спасибо за указатель, но, sudo apt-get install gcc-multilib g++-multilibкажется, лучше (он автоматически разрешается в вашей версии gcc).
leesei
^ возможно нет! Предложение @ Золтана работало для меня все же. Энтони Соттил, может, тебе стоит включить комментарий Золтана в свой ответ?
Человек
@ Не стесняйтесь предлагать редактирование, когда я первоначально разместил его, я соответствовал версии, заданной в вопросе, с тех пор он изменился по
сравнению
11

Вы пытались добавить -I/usr/include/c++/4.4/i486-linux-gnuили -I/usr/include/c++/4.4/i686-linux-gnu?

orlp
источник
Это действительно работает. Любая идея о том, почему мне нужно сделать это только для 64-битных? Я пытаюсь настроить этот компьютер для работы с распределенными 64-битными сборками и хочу избежать слишком большого количества настроек.
Джесси Фогт
2
Прошу прощения, я понятия не имею, я только что представил быстрое хакерское рабочее решение :)
orlp
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

Теперь я могу скомпилировать 32-битные двоичные файлы на 64-битной ОС.

бекмес
источник
1
На OpenSUSE я это сделалcd /usr/include/c++/4.6;ln -s x86_64-suse-linux i586-suse-linux
Джулиан
3

Кажется, это ошибка опечатки в этом пакете gcc. Решение:

mv /usr/include/c++/4.x/i486-linux-gnu /usr/include/c++/4.x/i686-linux-gnu/64
DanceDance
источник
2

В моей 64-битной системе я заметил, что существует следующий каталог:

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

Тогда будет иметь смысл, что в моей 32-битной системе, которая была настроена для 64-битной кросс-компиляции, должен быть соответствующий каталог, такой как:

/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/bitsна мой 32- разрядный компьютер.

Теперь компилируем только с -m64правильными работами. Основным недостатком является то, что это все еще не правильный способ сделать что-то, и я предполагаю, что в следующий раз, когда Update Manager установит и обновление g ++ может сломаться.

Джесси Фогт
источник
1

В основном это используется в 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-dev dbg libc6-dbg -i386 libc6-dev-x32 libc6-i386 libc6-x32 libx32asan5 libx32atomic1 libx32gcc-8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc ++ - 8-dev libx32stdc ++ 6 libx ++ dst32: libx 6: dg32; 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-i386x32x32 x32 xx32 xx32 xx5 x32 xx5 x32 xx5 x325 x325 x325 x325 x325 x325 x325 x325 x325 x325 x325 x325 x325 x325 xx5 x325 x325 x32 x5 x32 x x5 lib32 x xx5 xx32 xx32 x325 xx32 x325 x325 x32 x x5 lib32 xx32 x325 xx32 x325 lib32 x32 8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc ++ - 8-dev libx32stdc ++ 6 libx32ubsan1

похоже на это будет показано на вашем терминале

Luftatako
источник
0

Из моего опыта sudo apt-get install gcc-multilib g++-multilibпомогает. Но моя другая проблема заключается в том, что я забыл очистить каталог, поэтому я все еще получаю ту же ошибку. Это первый раз, чтобы использовать Clang или Cmake. Поэтому я просто удаляю свой исходный каталог и перекомпилирую, и он работает. Надеюсь, это поможет кому-то вроде меня.

слаженность
источник