Re: gcc/ld init section and libraries

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



I fixed the problem now I think:
I had an init.c that held the initialization code init. Which wouldnt have been included in the link as the init function and section hook wasnt being referenced. When I put the init function in a file with functions that will be used, the init function gets included. Easy now that I know :)

John Love-Jensen writes:
Hi John,
The linker only pulls out .o from the .a that fulfill currently known
(single pass) missing symbols.
The linker also takes any .o in its entirety, it doesn't check for missing
symbols.
With the GNU linker, there is the -whole-archive switch.  So if you want
libfoo.a wholesale, but libbar.a and libquux.a to only be used to fulfill
missing symbols, do something like this:
gcc -o myapp alpha.c beta.c gamma.o delta.o -L. -Wl,-whole-archive -lfoo
-Wl,-no-whole-archive -lbar -lquux
Because the linker perfoms a single pass for resolution of missing symbols
in libraries (.so, or .a), order is very important.  And if you had an
interdependency (ick ick! avoid avoid!) between, say, bar and quux, you may
need to do something distasteful like -lbar -lquux -lbar.
HTH,
--Eljay



[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux