Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 12 May 2007 18:39:23 -0400 (EDT)
From:      Daniel Eischen <deischen@freebsd.org>
To:        Alexander Kabaev <kabaev@gmail.com>
Cc:        freebsd-current@freebsd.org
Subject:   Re: HEADS UP: shared library bump, symbol versioning, libthr change
Message-ID:  <Pine.GSO.4.64.0705121831300.8681@sea.ntplx.net>
In-Reply-To: <Pine.GSO.4.64.0705111330070.1459@sea.ntplx.net>
References:  <Pine.GSO.4.64.0705060923030.1180@sea.ntplx.net>  <20070511083154.0b72ff46@kan.dnsalias.net> <Pine.GSO.4.64.0705110906320.387@sea.ntplx.net> <8e5ef5f70705110951p55e4eb6aqe2ef23b3e77d907a@mail.gmail.com> <Pine.GSO.4.64.0705111330070.1459@sea.ntplx.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Fri, 11 May 2007, Daniel Eischen wrote:

> On Fri, 11 May 2007, Alexander Kabaev wrote:
>
>> Not really. You've wrote it several times before and I kept forgetting to 
>> ask
>> you why do you think libraries getting versioned symbols need to be
>> bumped. There might be a valid reason for this, but it somehow escapes me
>> and I would greatly appreciate you helping me to get this straight. I do 
>> not
>> think breaking binaries linking to symbols to which they had no business to 
>> link
>> in the first place is reason good enough. And testing done by Kris did show
>> us that the percentage of such binaries extremely small, small enough to be
>> treated as a noise.
>
> I think it was because I thought libraries and applications that
> are linked without symbol dependencies would always get the
> latest version of the symbol, not the earliest version of
> the symbol.  But if I recall correctly from prior email from
> you, you should get the earliest version of the symbol in
> lieu of no recorded symbol dependency?

libc and the thread libraries need to be bumped for a couple of
reasons.  I believe the internal jump table (see __thr_jtable
in src/lib/libc/include/libc_private.h) changed sizes between
6.x and 7.x.  The other reason is that libpthread and libthr
used the namespace LIBPTHREAD_1_0 as their namespace, and this
needs to be removed and FBSD_1.0 used instead.  libpthread
currently has to play some ugly games in order to be compatible
with both namespaces.  libthr currently doesn't have those
ugly hacks and it would have to add them if its library version
is not bumped.

-- 
DE



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