I'm wondering what the -static option on gcc does. I need this option when compiling a certain application, however when I do I get the following error:
gcc -static -O3 -o prog prog.c
/usr/bin/ld: cannot find -lc
collect2: ld returned 1 exit status
What needs installation?
GCC version:
[user@localhost dir]$ gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/libexec/gcc/x86_64-redhat-linux/4.6.1/lto-wrapper
Target: x86_64-redhat-linux
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-linker-build-id --enable-languages=c,c++,objc,obj-c++,java,fortran,ada,go,lto --enable-plugin --enable-java-awt=gtk --disable-dssi --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-1.5.0.0/jre --enable-libgcj-multifile --enable-java-maintainer-mode --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --disable-libjava-multilib --with-ppl --with-cloog --with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux
Thread model: posix
gcc version 4.6.1 20110908 (Red Hat 4.6.1-9) (GCC)
The
-static
option links a program statically, in other words it does not require a dependency on dynamic libraries at runtime in order to run.To achieve static linking requires that the archive (.a) versions of your libraries exist on the system. so /usr/lib/libc.a /usr/lib/crt1.o etc...
On modern linux systems (as you are using red hat): when a binary links together it 1) either puts the code into the executable via .o and .a files, or 2) puts in references to dynamic libraries (.so) files that is resolved by /lib/ld-linux.so (or /lib64/ld-linux=x86-64.so) which is always at a well known place.
For your particular system, if a program is specifically looking to create a static version of itself then you need to install the static versions of your devel tools. You need, at the minimum, glibc-static package. You may also need libstdc++-static package as well.
You generally should avoid statically linking your application (and you should explain us why you don't want usual dynamic linking). I suggest at least to link dynamically the system libraries (
libc
notably) - if you absolutely want, you could link less common libraries statically - . Why do you want to link statically your application? It is generally a mistake (because you don't profit from updates to the system dynamic libraries). In particular name service switch facilities fromlibc
wants dynamic libraries.Your system should have installed the package providing the static libc library. On Debian, it is the
libc-dev
package but I don't know what it is on RedHat.To find out what
gcc
does, pass it the-v
flag likeBut you should not link statically your programs. On my Debian distributions, there are more than 700 programs in
/usr/bin
and only one is statically linked.As to what the
-static
option of GCC does, read on Invoking GCC. It is a linking option which:The
-pie
flag means:The
/usr/bin/ld: cannot find -lc
message is surprising, and might reveal other problems (badly installed or corrupted system, or some missinglibc.a
).The
-static
flag forces the linker to accept only static libraries and not any shared libraries.If you want to use
-static
, you have to ensure that you have a static version of the C library installed, which might be tricky to find (most systems do not have a static C library any more). Or you have to cancel the effect of-static
. However, in the example, that would defeat the purpose of-static
since the only library linked is (implicitly) the C library.