Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 25 Nov 2003 18:49:28 -0800
From:      Marcel Moolenaar <marcel@xcllnt.net>
To:        Terry Lambert <tlambert2@mindspring.com>
Cc:        current@freebsd.org
Subject:   Re: rtld + static linking
Message-ID:  <20031126024927.GA7743@dhcp01.pn.xcllnt.net>
In-Reply-To: <3FC40572.142D4334@mindspring.com>
References:  <Pine.LNX.4.44.0311230707560.13829-100000@a.mx.ict1.everquick.net> <3FC40572.142D4334@mindspring.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, Nov 25, 2003 at 05:44:18PM -0800, Terry Lambert wrote:
> "E.B. Dreger" wrote:
> > After watching the recent shared/dynamic threads, and reading the
> > archives from five or six years ago, I have a question...
> > 
> > Dynamic linking works by the kernel running the dynamic linker,
> > which loads shared objects and fixes the symbol tables, yes?
> 
> No.
> 
> Dynamic linking works because the crt0 mmap's the /usr/libexec/ld.so
> file as executable, and then points known stub offsets into it.

No.

Dynamic linking works because the kernel loads and runs the dynamic
linker when it sees that the executable defines an interpeter.

> > Is there some reason that a statically-linked program couldn't
> > include some "ld-elf.a" type of intelligence?  Would that be
> > necessary and sufficient to allow statically-linked programs to
> > load shared objects?
> 
> Yes, and yes.

No, and no.

A complete executable (i.e. staticly linked) does not export any
symbols, or at least not in the same way a shared executable and
shared libraries do. If I try to dynamicly link libbar into a
complete executable foo and libbar depends on libc, then there's
no guarantee that all the required bits from libc are in foo, nor
is there any guarantee that the bits are actually visible or even
accessable (no linkage table).
Dynamicly loading libc for use by libbar can work, but it's not
guaranteed. One failure mode is suddenly having two instances of
a common variable instead of one. Another is the clobbering of
data caused reinitializations.

So, the problem of dynamic linking a shared library into a static
process is non-trivial and probably cannot be solved genericly.
Under restricted and controlled conditions you can make it work.
I would call it the ability to have plugins, not the ability to
load dynamic libraries.

-- 
 Marcel Moolenaar	  USPA: A-39004		 marcel@xcllnt.net



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20031126024927.GA7743>