Mancano "bit / c ++ config.h" durante la compilazione incrociata di programmi a 64 bit su 32 bit in Ubuntu


181

Sto eseguendo la versione a 32 bit di Ubuntu 10.10 e sto cercando di eseguire la compilazione incrociata su un target a 64 bit. Sulla base della mia ricerca, ho installato il pacchetto g ++ - multilib.

Il programma è un mondo ciao molto semplice:

#include <iostream>

int main( int argc, char** argv )
{
  std::cout << "hello world" << std::endl;
  return 0;
}

Compilare:

g++ -m64 main.cpp

Errore:

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.

Ho trovato un c++config.hfile ma risiedono nelle directory i486-linux-gnue i686-linux-gnuin/usr/include/c++/4.4/ Non c'è c++config.hin /usr/include/c++/bits.

Qualche idea su cosa mi sto perdendo? Compilare senza il-m64 flag funziona correttamente (a.out viene creato e funziona correttamente).

Modifica Grazie al suggerimento di @nightcracker, ho fatto un po 'più di indagine sulla struttura di inclusione sui sistemi a 32 e 64 bit. Di seguito ho aggiunto una risposta che "risolve" temporaneamente il problema, ma penso che si interromperà al prossimo aggiornamento. In sostanza, mi manca una directory chiamata /usr/include/c++/4.4/i686-linux-gnu/64che dovrebbe contenere una sottodirectory denominata bitscon il file include mancante. Qualche idea su quale pacchetto dovrebbe occuparsi di questo?


1
Wow ... ho avuto anche questo problema. GCC 4.8 su un ARMv7-a CubieTruck (Cortex-A7) con Ubuntu. La cosa bizzarra (per me) è che la risposta di Anthony l'ha risolto. Qualunque cosa ...
jww

Risposte:


308

Aggiungendo questa risposta parzialmente perché ha risolto il mio problema con lo stesso problema e quindi posso aggiungere questa domanda ai segnalibri.

Sono stato in grado di risolverlo nel modo seguente:

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

Se hai installato una versione di gcc/ g++che non viene fornita per impostazione predefinita (come g++-4.8su lucido), dovrai abbinare anche la versione:

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

30
Assicurati di abbinare le versioni gcc and g++installate sul tuo sistema. Su Ubuntu 14.04 l'avevo installato gcc-4.8e g++-4.8installato, quindi ho installato gcc-4.8-multilib e g++-4.8-multilibinvece.
Zoltán,

3
Ciò ha risolto il mio problema durante la compilazione con -m32 su una macchina a 64 bit. Grazie
nic

41
Grazie per il puntatore, ma sudo apt-get install gcc-multilib g++-multilibsembra migliore (si risolve automaticamente nella tua versione di gcc).
leesei,

^ forse no! Il suggerimento di @Zoltan ha funzionato per me. Anthony Sottile, forse dovresti includere il commento di Zoltan nella tua risposta?
Uomo,

@Man sentiti libero di suggerire una modifica, quando inizialmente l'ho postato ho abbinato la versione posta nella domanda, da allora è cambiata dalle modifiche di altri
Anthony Sottile

11

Hai provato ad aggiungere -I/usr/include/c++/4.4/i486-linux-gnuo -I/usr/include/c++/4.4/i686-linux-gnu?


Funziona davvero. Qualche idea sul perché dovrei farlo per soli 64 bit? Sto cercando di configurare questa macchina per aiutare con build distribuite a 64 bit e voglio evitare troppe personalizzazioni.
Jesse Vogt,

2
Mi dispiace, non ne ho idea, ho appena proposto una soluzione di lavoro veloce e veloce :)
orlp

5

Durante la compilazione in RHEL 6.2 (x86_64), ho installato i pacchetti libstdc ++ - dev sia a 32 bit sia a 64 bit, ma ho riscontrato il problema "c ++ config.h nessun file o directory ".

Risoluzione:

La directory /usr/include/c++/4.4.6/x86_64-redhat-linuxmancava.

Ho fatto quanto segue:

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

Ora sono in grado di compilare binari a 32 bit su un sistema operativo a 64 bit.


1
Su OpenSUSE l'ho fattocd /usr/include/c++/4.6;ln -s x86_64-suse-linux i586-suse-linux
Julian il

3

Sembra essere un errore di battitura in quel pacchetto di gcc. La soluzione:

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

2

Sul mio sistema a 64 bit ho notato che esisteva la seguente directory:

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

Avrebbe quindi senso che sul mio sistema a 32 bit che era stato impostato per la compilazione incrociata a 64 bit ci fosse una directory corrispondente come:

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

Ho ricontrollato e questa directory non esisteva. L'esecuzione g++con il parametro dettagliato ha mostrato che il compilatore stava effettivamente cercando qualcosa in questa posizione:

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.

L'errore riguardo al ignoring nonexistent directoryera l'indizio. Sfortunatamente, non so ancora quale pacchetto devo installare per visualizzare questa directory, quindi ho appena copiato la /usr/include/c++/4.4/x86_64-linux-gnu/bitsdirectory dal mio computer a 64 bit /usr/include/c++/4.4/i686-linux-gnu/64/bitssul mio computer a 32.

Ora compilando -m64correttamente solo le opere. Il principale svantaggio è che questo non è ancora il modo corretto di fare le cose e sto indovinando la prossima volta che Update Manager installa e aggiorna a g ++ le cose potrebbero non funzionare.



1

Fondamentalmente viene utilizzato in HeapOverflow o in altri tipi di inversione Problemi, ad esempio se si desidera modificare un ELF a 64 bit in ELF a 32 bit e durante la conversione viene visualizzato un errore.

Puoi semplicemente eseguire i comandi

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

che aggiornerà le tue librerie Pacchetti aggiornati:

Verranno installati i seguenti pacchetti aggiuntivi: g ++ - 8-multilib gcc-8-multilib lib32asan5 lib32atomic1 lib32gcc-8-dev lib32gomp1 lib32itm1 lib32mpx2 lib32quadmath0 lib32stdc ++ - 8-dev lib32ubsan1 libc-dev-bin libc6 libc6-dbc lib6-devb6 -i386 libc6-dev-x32 libc6-i386 libc6-x32 libx32asan5 libx32atomic1 libx32gcc-8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc ++ - 8-dev libx32stdc ++ 6 libx32d ++ 6-932db ++ ++ 8-dbg glibc-doc Verranno installati i seguenti NUOVI pacchetti: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 libc6x3232 lib326x32 8-dev libx32gcc1 libx32gomp1 libx32itm1 libx32quadmath0 libx32stdc ++ - 8-dev libx32stdc ++ 6 libx32ubsan1

simile a questo verrà mostrato al tuo terminale


0

Dalla mia esperienza, sudo apt-get install gcc-multilib g++-multilibaiuta. Ma il mio altro problema è che DIMENTICANO di pulire la directory in modo da ottenere lo stesso errore. È la prima volta che usi clang o cmake. Quindi elimino la mia directory originale e la ricompila e funziona. Spero che aiuti qualcuno come me.

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.