Não consigo compilar um programa simples usando o gcc

0

Errada eu instalei ia32-libs mas meu sistema host é de 64 bits. Agora, sempre que eu tento compilar o arquivo c eu recebo uma mensagem

as: unrecognized option '--64'

Eu tenho desinstalar as ia32-libs, mas estou recebendo o mesmo erro. então eu tenho desinstalar o gcc, g + +, multilib e build-essenstial usando o comando purge. novamente instale esses pacotes usando o comando apt-get, mas novamente o mesmo erro. Quando executo o comando "which gcc" no terminal, recebo "/ usr / bin / gcc" e a saída "which ld" é "/ usr / bin / ld". Eu acho que ambas as saídas estão corretas.

Quando eu executo este comando

g++ -v hello hello.c

a saída é

Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/4.6/lto-wrapper
Target: x86_64-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.6.3-1ubuntu5' --with-bugurl=file:///usr/share/doc/gcc-4.6/README.Bugs --enable-languages=c,c++,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.6 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.6 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --enable-objc-gc --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
Thread model: posix
gcc version 4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5) 
COLLECT_GCC_OPTIONS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-linux-gnu/4.6/cc1plus -quiet -v -imultilib . -imultiarch x86_64-linux-gnu -D_GNU_SOURCE he.c -quiet -dumpbase he.c -mtune=generic -march=x86-64 -auxbase he -version -fstack-protector -o /tmp/ccIQSmoy.s
GNU C++ (Ubuntu/Linaro 4.6.3-1ubuntu5) version 4.6.3 (x86_64-linux-gnu)
    compiled by GNU C version 4.6.3, GMP version 5.0.2, MPFR version 3.1.0-p3, MPC version 0.9
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/4.6/../../../../x86_64-linux-gnu/include"
include "..." search starts here:
include <...> search starts here:
 /usr/include/c++/4.6
 /usr/include/c++/4.6/x86_64-linux-gnu/.
 /usr/include/c++/4.6/backward
 /usr/lib/gcc/x86_64-linux-gnu/4.6/include
 /usr/local/include
 /usr/lib/gcc/x86_64-linux-gnu/4.6/include-fixed
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
GNU C++ (Ubuntu/Linaro 4.6.3-1ubuntu5) version 4.6.3 (x86_64-linux-gnu)
    compiled by GNU C version 4.6.3, GMP version 5.0.2, MPFR version 3.1.0-p3, MPC version 0.9
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 65b5171ac1bd7b3f07dbea6bdb24be3d
COLLECT_GCC_OPTIONS='-v' '-shared-libgcc' '-mtune=generic' '-march=x86-64'
 as --64 -o /tmp/ccXDnoi3.o /tmp/ccIQSmoy.s
**as: unrecognized option '--64'**

Você pode me dizer como resolver esse problema?

    
por Aqib Butt 25.07.2014 / 15:01

3 respostas

2

As opções para gcc são '-m32' ou '-m64' para gerar código para um ambiente de 32 ou 64 bits. Não '- 64'

    
por jhilmer 25.07.2014 / 15:06
1

Houve um problema com meu montador.

Quando eu corro as --version

GNU assembler (GNU Binutils for Ubuntu) 2.22 Copyright 2011 Free Software Foundation, Inc. 
This program is free software; you may redistribute it under the terms of the GNU General Public License version 3 or later. 
This program has absolutely no warranty. This assembler was configured for a target of 'arm-linux-gnueabi'.

Meu alvo assembler está erroneamente apontando para o arm-linux-gnueabi (que era um compilador cruzado no meu caso). Então, reinstalando binutils meu problema foi resolvido.

    
por Aqib Butt 04.08.2014 / 15:50
0

Um fenômeno semelhante ocorreu e foi resolvido.

  1. Construído e instalado gcc-4.9.2
  2. Construiu outro software. Não tem problema.
  3. Construído e instalado binutils-2.25
  4. O gcc falhou com a opção .... / bin / as: unrecognized: '-xarch = generic'
  5. Renomeado /usr/local/i386-pc-solaris2.11/ com nome diferente, que foi instalado por binutils incluindo bin / as
  6. O gcc foi bem sucedido

Este é o meu palpite. Historicamente, o gcc usava um assembler externo, como incluído no binutils. Vários anos atrás, o gcc mudou sua implementação para ter a funcionalidade 'as' no próprio gcc. O tempo passado. Mesmo assim, se o gcc encontrar 'as' nos diretórios certos, o gcc irá usá-lo, no lugar da funcionalidade interna 'as'.

    
por Tora 07.01.2015 / 07:14