NetBSD/libexec/ld.elf_so
2002-08-10 01:59:33 +00:00
..
arch Add support for dynamic linking on HP PA-RISC. 2002-07-10 15:12:33 +00:00
debug.c __STDC__ is always defined on NetBSD. 2002-05-26 00:02:06 +00:00
debug.h
headers.c Add support for dynamic linking on HP PA-RISC. 2002-07-10 15:12:33 +00:00
ld.elf_so.1
load.c If /etc/ld.so.conf contains an invalid sysctl name any dynamically 2002-07-18 14:46:11 +00:00
Makefile Build for "armeb". 2002-08-10 01:59:33 +00:00
malloc.c
map_object.c SIMPLEQ rototill: 2002-06-01 23:50:52 +00:00
paths.c
README Add support for dynamic linking on HP PA-RISC. 2002-07-10 15:12:33 +00:00
reloc.c Add support for dynamic linking on HP PA-RISC. 2002-07-10 15:12:33 +00:00
rtld.c Remove extraneous \n's in {err,warn}{,x}. 2002-08-09 10:01:53 +00:00
rtld.h Add support for dynamic linking on HP PA-RISC. 2002-07-10 15:12:33 +00:00
rtldenv.h
search.c
symbol.c SIMPLEQ rototill: 2002-06-01 23:50:52 +00:00
sysident.h
xmalloc.c
xprintf.c __STDC__ is always defined on NetBSD. 2002-05-26 00:02:06 +00:00

$NetBSD: README,v 1.9 2002/07/10 15:12:34 fredette Exp $

BUGS/PROBLEMS:

* rtld.c around line 184:

	#iffdef __alpha__
	/* XXX XXX XXX */
	_rtld_objself.pltgot = NULL;
	#endif

  It's a workaround for a linker bug, and will go away when the linker is
  fixed.

* The method used to relocate ld.so is shoddy and fragile.  Currently it's
  something like:

  alpha, hppa, powerpc:
	(1) assembly code relocates RELATIVE relocations in the GOT
	    (on some ports, all relative relocations; this will probably
	    have to be #ifdef'd in reloc.c), assuming that everything
	    in the GOT is a RELATIVE relocation.  On the hppa, this
	    is actually done in C code.

	(2) alpha, hppa only: C code relocates the rest of the loader,
	    excluding those RELATIVE relocations already done (via an ...
	    iffy heuristic).

  arm, i386, m68k, sparc:
	(1) C code relocates the loader in _rtld_init() carefully so that
	    it does not touch any globals.

  mips:
	(1) loads ld.elf_so at 0, so no relocating is necessary.

  Something better (like that the glibc ELF ld.so does) should be done
  eventually, where a single set of C code is compiled twice, once for
  normal use, and once to be used to relocate the shared linker.  No
  relocations should be processed in assembly language.

* On the Alpha, this code Really needs to be checked to be sure that
  it doesn't make calls that could use FP, while doing lazy binding.

TO DO:

* Support for coexistance of 32-bit and 64-bit ELF on platforms that can
  do that.

* Support for relocating ld.elf_so on mips