Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 17 Apr 2003 17:30:41 -0700
From:      Terry Lambert <tlambert2@mindspring.com>
To:        John Polstra <jdp@polstra.com>
Cc:        current@freebsd.org
Subject:   Re: HEADS UP: new NSS
Message-ID:  <3E9F4731.2627885E@mindspring.com>
References:  <20030417141133.GA4155@madman.celabo.org> <20030417144449.GA4530@madman.celabo.org> <200304171535.h3HFZEFs094589@strings.polstra.com> <200304171944.h3HJi1jK095151@strings.polstra.com>

next in thread | previous in thread | raw e-mail | index | archive | help
John Polstra wrote:
> In article <20030418014500.B94094@iclub.nsu.ru>,
> Max Khon  <fjoe@iclub.nsu.ru> wrote:
> > we need either allow dlopen(3) to be used in statically linked programs
> > or move to dynamically linked /.
> 
> Moving to a fully dynamically linked system sounds easier to me.
> But in the past there has been strong opposition to the idea every
> time it has been proposed.

FWIW, I have some static "libdlopen" patches, but you have to
modify the internal compiler glue to use them.  The problem is
that you can't have multiple init sections, only multiple inits,
and that that only really works with C++, if you want to put
them in your code.

The main modification is to stuff the dlopen stuff into the
__CTOR_LIST__, and then make __ctors() pass an argument to the
constructor.  That's because __do_dynamic_link() needs an
argument (it calls it "argv", but it's really "all the data
you need to fill out "crt_ldso").

If you look in /usr/src/lib/csu/i386/crt0.c, and in the code
in /usr/src/lib/csu/i386/c++rt0.c, you'll see what I mean.

The actual modifications aren't hard; but you will have to
give up resolving symbols in your own binary, as the price
(i.e. the .init on the .so you load will have to call a
"well known callback"; this is pretty easy: add a parameter
to the passing of the dlopen() call into the .so you are
loading of a function to call to register to get symbols;
or you could just use statically linked PIC binaries with
symbols attached, and open them as .so's, even though they
are not named that way).

-- Terry



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3E9F4731.2627885E>