Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 27 Nov 2003 10:53:29 -0800
From:      Marcel Moolenaar <marcel@xcllnt.net>
To:        Terry Lambert <tlambert2@mindspring.com>
Cc:        current@freebsd.org
Subject:   Re: rtld + static linking
Message-ID:  <20031127185329.GA14849@dhcp01.pn.xcllnt.net>
In-Reply-To: <3FC5E2DA.EC4B0345@mindspring.com>
References:  <Pine.LNX.4.44.0311230707560.13829-100000@a.mx.ict1.everquick.net> <3FC40572.142D4334@mindspring.com> <20031126024927.GA7743@dhcp01.pn.xcllnt.net> <3FC49986.14E86B70@mindspring.com> <20031126173004.GB10589@dhcp01.pn.xcllnt.net> <3FC5E2DA.EC4B0345@mindspring.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, Nov 27, 2003 at 03:41:14AM -0800, Terry Lambert wrote:

> > If you can get gcc and binutils to add the necessary support, then
> > we can talk further. Until then it's academic.
> 
> I think there are political reasons for not doing this.  The
> number one reason would be that you could load GPL'ed code as
> a module into a non-GPL'ed program, and then use it without
> neding to change your own license to GPL.

The use of dlopen() does not circumvent that you're creating a
modified version. The GPL-incompatible code and the GPL code do
not communicate at arms length. Hence, the GPL-incompatible code
is to be relicensed if the modified work is to be distributed.i
Alternatively, ask the license holder for an exception or see if
the library can be relicensed under the LGPL.

>From a GPL licensing point of view dlopen() is no different than
static linking.

> > > I'll also point out that the ELF specification does not define static
> > > linking *at all*.
> > 
> > I think that's because it doesn't need any special mention.
> 
> Well, it specifically mentions being able to do something like
> linking libc to libresolv, so that you implicitly get the resolver
> library when you explicitly link in the C library. That doesn't
> work with static linking of ELF binaries, so I think we can either
> say static linking is completely broken and needs to be fixed before
> it is allowed to be used, or static linking is undefined by the ELF
> standard.

Recording dependencies in ELF files is specific to dynamic linking.
In fact, there's nothing that you need to add to ELF headers or
sections to make static linking work. It's irrelevant to an ELF
specification. That's why it's not mentioned. Dynamic linking needs
special headers and/or sections in the ELF file to make it work.

I don't think you can infer from the ELF specification that static
linking is undefined.

-- 
 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?20031127185329.GA14849>