Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 09 Sep 1999 18:36:52 +0400
From:      Dmitrij Tejblum <tejblum@arc.hq.cti.ru>
To:        Marcel Moolenaar <marcel@scc.nl>
Cc:        hackers@FreeBSD.ORG
Subject:   Re: 32+ signals and library versions 
Message-ID:  <199909091436.SAA04752@arc.hq.cti.ru>
In-Reply-To: Your message of "Thu, 09 Sep 1999 14:59:37 %2B0200." <37D7AF39.ECC65D14@scc.nl> 

next in thread | previous in thread | raw e-mail | index | archive | help
> Dmitrij Tejblum wrote:
> > 
> > Marcel Moolenaar wrote:
> > > > I suggest to try to avoid the version bump. NetBSD-like way to do it:
> > > > Give new implementations another names in object files, so that they
> > > > don't conflict with old implementations, and preserve old
> > > > implementations in the library too. To make the compiler generate calls
> > > > to new implementations, one can add appropriate #define s in .h files.
> > > > For GCC, __asm__ attribute also can be used.
> >
> > No, when new functions are added into the library, and binaries linked
> > with the old library will continue to work with new library, version bump
> > is not required.
> > 
> > This is a standard rule. It was also recently discussed on -committers
> > on Aug 20 in the thread
> > Re: cvs commit: src/include histedit.h src/lib/libedit Makefile editline.3 el.c el.h
> 
> In that discussion it has been said that datatype changes require a version
> change. Now you're telling me that we should implement datatype changes as
> new functions which consequently don't require a version change. So now the
> policy is "version bump avoidance at all cost"?

I am not setting any policy - I am not core. I am just suggesting it 
(strongly :-)

Then, I believe that the cost here is relatively low compared to the 
benefit. libc is used by all programs, and version bumps would have 
quite severe impact. OTOH, you touch only half-dozen of functions, and 
they are not that popular, so why the change should affect all programs?

Other OSes started to avoid version bumps. Linux promises to not bump 
the libc version since glibc2. NetBSD avoid version bumps too. (Linux 
use "symbol versioning", that isn't supported by our rtld.)

> > >  How else
> > > do I know wich version x library has the new implementations (besides the
> > > larger one :-)?
> > 
> > Linker knows it. If some function ("new implementation") is missing, linker print
> > an error message. This is all you need.
> 
> I strongly disagree. Spitting "unresolved references" is *not* a way to
> tell the user that he doesn't have the right libraries.

I strongly disagree. This is much better than version bump. After all, 
we can add suggestion to upgrade libraries to the "unresolved references"
message. Then, if an user don't have right libraries, it is his mistake.
It should not impact another people. 

Also, we are not discussing _this_. A lot of functions were added to libc
without a version bump, and it is a standard accepted practice (Just from 
top of my head: strlcpy, strlcat, mkstemps, strsignal, fseeko, ftello,
poll, nanosleep, pread, pwrite, kld*, ... ouch, there is a lot of 
other functions).

My suggestion have more serious disadvantages. For one, it add more 
work to you (the person who change an interface). But it save some work 
to everyone who will ever upgrade FreeBSD or deal with a 3rd party 
software. Then, say, dlsym(,"setjmp") will give probably incorrect result.
But "you cannot have everything" and noone, I hope, will use such dlsym. 

Dima




To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-hackers" in the body of the message




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