Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 28 May 2008 11:39:21 -0400 (EDT)
From:      Daniel Eischen <deischen@freebsd.org>
To:        Alexander Kabaev <kabaev@gmail.com>
Cc:        cvs-src@freebsd.org, src-committers@freebsd.org, Xin LI <delphij@freebsd.org>, cvs-all@freebsd.org
Subject:   Re: cvs commit: src/include string.h src/lib/libc/string Makefile.inc memchr.3 memrchr.c src/sys/sys param.h
Message-ID:  <Pine.GSO.4.64.0805281114320.7240@sea.ntplx.net>
In-Reply-To: <20080528091745.465f37b4@kan.dnsalias.net>
References:  <200805272004.m4RK4SZt029194@repoman.freebsd.org> <20080528091745.465f37b4@kan.dnsalias.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, 28 May 2008, Alexander Kabaev wrote:

> On Tue, 27 May 2008 20:04:28 +0000 (UTC)
> Xin LI <delphij@FreeBSD.org> wrote:
>
>> delphij     2008-05-27 20:04:27 UTC
>>
>>   FreeBSD src repository
>>
>>   Modified files:        (Branch: RELENG_6)
>>     include              string.h
>>     lib/libc/string      Makefile.inc memchr.3
>>     sys/sys              param.h
>>   Added files:           (Branch: RELENG_6)
>>     lib/libc/string      memrchr.c
>>   Log:
>>   MFC: Add memrchr(3).
>>
>>   Obtained from:  OpenBSD
>>
>>   Revision    Changes    Path
>>   1.21.2.2    +1 -0      src/include/string.h
>>   1.34.8.2    +2 -1      src/lib/libc/string/Makefile.inc
>>   1.7.14.3    +28 -3     src/lib/libc/string/memchr.3
>>   1.1.4.1     +40 -0     src/lib/libc/string/memrchr.c (new)
>> http://cvsweb.FreeBSD.org/src/lib/libc/string/memrchr.c?rev=1.1.4.1&content-type=text/plain
>>   1.244.2.37  +1 -1      src/sys/sys/param.h
>>
>> http://cvsweb.FreeBSD.org/src/include/string.h.diff?r1=1.21.2.1&r2=1.21.2.2
>> http://cvsweb.FreeBSD.org/src/lib/libc/string/Makefile.inc.diff?r1=1.34.8.1&r2=1.34.8.2
>> http://cvsweb.FreeBSD.org/src/lib/libc/string/memchr.3.diff?r1=1.7.14.2&r2=1.7.14.3
>> http://cvsweb.FreeBSD.org/src/sys/sys/param.h.diff?r1=1.244.2.36&r2=1.244.2.37
>
>
> There are two levels of symbol versions checking:
>
> 1. Up-front checking of version name.
> When binary starts, rtld checks that all versions it was compiled
> against are provided by the dynamically loaded libraries. I.e. if
> libc.so.7:FBSD_1.1 is recorded as a requirement in binary and given
> libc.so.7 does not have that version, the binary execution is
> terminated right on the spot.
>
> The assumption here is that if version FOO is claimed to be provided by
> the library then _all_ symbols@FOO binary might need are present. This
> is the level of symbol versions checking Solaris provides. Linux goes a
> bit further:
>
> 2. Per-symbol versions.
>
> In addition to the above, ld encodes required version of each undefined
> symbol in a binary and uses (name, version) pair to resolve undefined
> references as opposed to using only the symbol name. This allows for
> several versions of the same symbol to exist within the binary, i.e.
> something like read@FOO1 and read@FOO2 are now possible.
>
> Your changes broke assumption in 1. To do it 100% correctly, we probably
> need to introduce a side version for memchr, something like
> memrchr@@FBSD_1.0a in stable branch and provide a compatibility
> alias memrchr@FBSD_1.0a for it in -current at the same time.
>
> libc.so.7 from RELENG_7 will  have:
>
> memrchr@@FBSD_1.0a
>
> libc.so.7 from -current then will  have:
>
> memrchr@@FBSD_1.1
> memrchr@FBSD_1.0a -> memrchr@@FBSD_1.1

Interesting, as long as "a" = ".1", so that you have FBSD_1.0.1 as
the side version.

See my prior email - I thought we agreed that we just MFC the version
(in this case, FBSD_1.1) from -current.  If you introduce a new
version, a binary built on 7.x may not run on -current from before
the side version was added.  For instance, if we were to add
memfoo() in -current now, then we release 8.0 with memfoo@@FBSD_1.1,
then after the release we MFC memfoo() to RELENG_7 in the way
you describe, then anything built in RELENG_7 using memfoo() will
not work in 8.0 release (because 8.0 didn't have the side version
memfoo@@FBSD_1.0a/1.0.1).

Typically before a release there are a flurry of MFCs, so you can
have a few months or more elapse before the addition of new or
ABI-changed symbols.  If we just use the same version as -current,
then things will just work, at least from when the symbol was
changed/added in -current.

But regardless, I think this means that once we release 8.0, we
cannot MFC any new or changed symbols (from 8.0+) back to
7.x.  If someone upgrades from 7.x to 8.0, then 8.0 has to
have all the symbols that 7.x will have or else binary
compatibility will be broken.

-- 
DE



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