Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 28 Nov 2003 18:59:11 +1100
From:      Peter Jeremy <peterjeremy@optushome.com.au>
To:        freebsd-current@freebsd.org
Subject:   Re: Apples linking
Message-ID:  <20031128075911.GB23322@server.vk2pj.dyndns.org>
In-Reply-To: <Pine.NEB.3.96L.1031127101515.30532A-100000@fledge.watson.org>
References:  <3FC60848.5030908@catpa.com> <Pine.NEB.3.96L.1031127101515.30532A-100000@fledge.watson.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, Nov 27, 2003 at 11:24:23AM -0500, Robert Watson wrote:
[Darwin pre-binding]
>presumably applies to other processor architectures.  The one thing that
>turns me off to this scheme is that I'd like it if we could find a way to
>represent this using solely existing BSD/UNIX kernel primitives (mmap, et
>al) and userspace, rather than adding special-purpose system calls that
>complicated various code paths, and that aren't portable.

Compaq/HP Tru64 supports link-time pre-binding, called "Quickstart".
To use it, shared libraries are linked to load at mutually exclusive
addresses and applications are linked assuming the preferred .so load
addresses.  At run-time, the rtld verifies that it can map every
shared library at its preferred address and that each shared library
is the same one the application was linked against (using checksums in
the COFF headers).  If all this is true, all the relocations are
correct and execution starts immediately.  If any checks fail, rtld
falls back to the traditional check-every-symbol-and-relocation
approach.

The benefit is very fast start times - not much more overhead than
starting a static executable.

The disadvantages are:
- if any library changes, all dependent applications must be relinked to
  maintain the fast start.  In some cases a utility can be used to
  re-validate the checksums in the application if the library hasn't
  grown and is at the same address.
- circular shared library dependencies aren't allowed
- a writable common list of .so load addresses is needed at .so link time.
- having reserved address space for each shared library results in a
  fragmented process address space and may impact on the space available
  to the application.

For more details see the following links
http://h30097.www3.hp.com/docs/base_doc/DOCUMENTATION/V51B_HTML/ARH9VDTE/SHLBCHPX.HTM#using-quickstart
http://h30097.www3.hp.com/docs/base_doc/DOCUMENTATION/V51B_HTML/SUPPDOCS/OBJSPEC/NV140XXX.HTM#nav14-54

I don't believe it is feasible to do much about the i386 PIC overheads
other than moving to a saner processor architecture.  What other
techniques are used to improve shared library startup times in other
operating systems?

Peter



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