Forcing symbol resolution in lib rather than bin

Giorgos Keramidas keramida at ceid.upatras.gr
Fri Aug 19 19:48:56 GMT 2005


On 2005-08-19 20:13, Jonathon McKitrick <jcm at FreeBSD-uk.eu.org> wrote:
>
> I have a binary that links to a shared object library.  That .so calls a
> routine in an archive library (.a).  When I link the main app with -lar-a it
> works fine, even though the function is actually called in the .so.  But when
> I link the .so with -lar-a, the linker doesn't resolve the symbol!
>
> So, here's the call graph:
>
> bin --> shared --> archive
>
> If I link bin to shared and archive, it works.  But if I link shared to
> archive, and then bin to shared, it doesn't, even though the shared object
> calls the archived function, rather than bin.
>
> What basic link concept am I missing here?

Strange.  How are you building these libraries and the program?

I've uploaded a minimal test at:

	http://people.freebsd.org/~keramida/files/jcm-lib.tar.gz

This contains three parts:

	libfoo/			which defines libfoo_init()
				and builds as a non-shared libfoo.a

	libbar/			which defines libbar_init() and
				calls libfoo_init()

	foobar/			a program that links with libbar.so
				and calls only libbar_init()

Here's the output of ldd on the foobar binary and the output of running
the foobar program:

# flame:/tmp/jcm-lib/foobar$ LD_LIBRARY_PATH=`pwd`/../libbar ldd foobar
# foobar:
#         libbar.so.1 => /tmp/jcm-lib/foobar/../libbar/libbar.so.1 (0x80062a000)
#         libc.so.6 => /lib/libc.so.6 (0x80072b000)
# flame:/tmp/jcm-lib/foobar$ LD_LIBRARY_PATH=`pwd`/../libbar ./foobar
# libfoo initialized at 0x80062a8a0
# libbar initialized at 0x4004e4
# flame:/tmp/jcm-lib/foobar$



More information about the freebsd-questions mailing list