Reputation: 43
I am trying to generate a very simple binary on Linux RHAS 5.3 64bits using a static library.
test1.cpp, whom resulting .o will be embedded in a static library.
void ctest1(int *i)
{
*i=5;
}
and prog.cpp
#include <stdio.h>
void ctest1(int *);
int main()
{
int x;
ctest1(&x);
printf("Valx=%d\n",x);
return 0;
}
If I compile in 32 bits, no problem:
--(0931:Wed,06 Apr 11:$ )-- g++ -m32 -Wall -c ctest1.cpp
--(0931:Wed,06 Apr 11:$ )-- file ctest1.o
ctest1.o: ELF 32-bit LSB relocatable, Intel 80386, version 1 (SYSV), not stripped
--(0931:Wed,06 Apr 11:$ )-- ar -cvq libctest.a ctest1.o
a - ctest1.o
--(0931:Wed,06 Apr 11:$ )-- g++ -m32 -o prog prog.cpp libctest.a
--(0931:Wed,06 Apr 11:$ )-- ./prog
Valx=5
However, if I try to compile in 64 bits, it fails during the link with the error "could not read symbols: Archive has no index; run ranlib to add one":
--(0933:Wed,06 Apr 11:$ )-- g++ -m64 -Wall -c ctest1.cpp
--(0935:Wed,06 Apr 11:$ )-- file ctest1.o
ctest1.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped
--(0933:Wed,06 Apr 11:$ )-- ar -cvq libctest.a ctest1.o
a - ctest1.o
--(0935:Wed,06 Apr 11:$ )-- g++ -m64 -o prog prog.cpp libctest.a
libctest.a: could not read symbols: Archive has no index; run ranlib to add one
collect2: ld returned 1 exit status
Running ranlib on libctest.a does not change anything.
My Linux version is the following
--(0937:Wed,06 Apr 11:$ )-- uname -a
Linux dev1 2.6.18-128.el5 #1 SMP Wed Dec 17 11:41:38 EST 2008 x86_64 x86_64 x86_64 GNU/Linux
Does anyone have an idea where the problem is coming from?
Thanks.
Upvotes: 4
Views: 13133
Reputation: 754410
Did you delete the library before recompiling with the 64-bit build?
Your compilation sequence worked for me:
$ g++ -m64 -Wall -c prog.cpp
$ g++ -m64 -Wall -c test1.cpp
$ ar -cvq libtest.a test1.o
a - test1.o
$ g++ -m64 -Wall -o prog1 prog.o libtest.a
$ file test1.o prog.o
test1.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped
prog.o: ELF 64-bit LSB relocatable, AMD x86-64, version 1 (SYSV), not stripped
$ ./prog1
Valx=5
$
When I then compiled 32-bit:
$ g++ -m32 -Wall -c prog.cpp
$ g++ -m32 -Wall -c test1.cpp
$ file test1.o prog.o
test1.o: ELF 32-bit LSB relocatable, Intel 80386, version 1 (SYSV), not stripped
prog.o: ELF 32-bit LSB relocatable, Intel 80386, version 1 (SYSV), not stripped
$ ar -cvq libtest.a test1.o
a - test1.o
$ g++ -m32 -Wall -o prog1 prog.o libtest.a
/usr/bin/ld: warning: i386:x86-64 architecture of input file `libtest.a(test1.o)' is incompatible with i386 output
$ file prog1
prog1: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/Linux 2.6.9, dynamically linked (uses shared libs), for GNU/Linux 2.6.9, not stripped
$ ./prog1
Memory fault
$
This is some RHEL 5 release (not all that current):
Linux toru 2.6.18-128.el5 #1 SMP Wed Dec 17 11:41:38 EST 2008 x86_64 x86_64 x86_64 GNU/Linux
My GCC is version 4.1.2. My AR version is as follows, and RANLIB prints the same version:
GNU ar 2.17.50.0.6-9.el5 20061020
I didn't need to use ranlib directly.
Upvotes: 1