Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 09 Dec 2014 08:53:13 -0800
From:      "Chris H" <bsd-lists@bsdforge.com>
To:        ports@FreeBSD.org, perl@FreeBSD.org, Mathieu Arnold <mat@FreeBSD.org>
Subject:   Re: Next Perl update, and plans beyo =?UTF-8?B?bmTigKY=?=
Message-ID:  <7c516f31c076f6e921cda93641ccb236@ultimatedns.net>
In-Reply-To: <20141209163038.GA49302@prod2.absolight.net>
References:  <20141209163038.GA49302@prod2.absolight.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, 9 Dec 2014 17:30:39 +0100 Mathieu Arnold <mat@FreeBSD.org> wrote

> Hello there,
> 
> In a few days, I'll be changing the way Perl works wrt compiled modules
> it produces.  The current patch[1] is on our code review tool.
> 
> Right now, we have:
> 
> $ readelf -d /usr/local/lib/perl5/5.18/mach/CORE/libperl.so|grep SONAME
>  0x000000000000000e (SONAME)             Library soname: [libperl.so.5.18]
> $
> 
> That is, libperl.so has a name, and it is versionned, and the version
> will change if you have 5.16 or 5.20.  If your libperl.so does not have
> a SONAME, you don't have an up-to-date Perl.
> 
> Which is good, because if some app is linked with libperl.so, it has:
> # readelf -d /usr/local/bin/vim|grep perl
>  0x0000000000000001 (NEEDED)             Shared library: [libperl.so.5.18]
>  0x000000000000000f (RPATH)              Library rpath:
> [/usr/local/lib:/usr/local/lib/perl5/5.18/mach/CORE]  0x000000000000001d
> (RUNPATH)            Library runpath:
> [/usr/local/lib:/usr/local/lib/perl5/5.18/mach/CORE] 
>
> So if you change your Perl version, pkg will know it has to upgrade vim
> too because a NEEDED shlib changed.
> 
> Now, for Perl modules, it's not like that, it reads like this:
> 
> $ readelf -d
> /usr/local/lib/perl5/site_perl/mach/5.18/auto/DateTime/DateTime.so|grep perl
> $
> 
> So what the patch[1] does, is force linking with libperl.so.x.yy.  After
> the patch, a compiled Perl module will look like this:
> 
> $ readelf -d
> /usr/local/lib/perl5/site_perl/mach/5.18/auto/DateTime/DateTime.so | grep
> perl  0x0000000000000001 (NEEDED)             Shared library:
> [libperl.so.5.18]  0x000000000000000f (RPATH)              Library rpath:
> [/usr/local/lib/perl5/5.18/mach/CORE]  0x000000000000001d (RUNPATH)          
>  Library runpath: [/usr/local/lib/perl5/5.18/mach/CORE] $
Apologies if I seem a bit obtuse. But as I read this, it appears
that Perl modules go from being text based (DateTime.pm) to becoming
compiled?
I *must* be missing something obvious.

--Chris

> 
> So pkg will detect it needs to be reinstalled when the Perl version
> change.
> 
> 
> As for the plans beyond that I was talking about in the subject, there
> will be a Perl 5.22 released next May, (and 5.24 the May after that,)
> when that happens, I'll change the default Perl to be 5.20, and
> deprecate 5.18 which won't, then, be supported.  Sometime at the end of
> the summer, like sometime September, I'll change the default Perl to
> 5.22 and try to keep it that way, that is, a new Perl goes in in May,
> and gets to be the default in September.
> 
> 
> 1: <https://reviews.freebsd.org/D1241>;
> 
> -- 
> Mathieu Arnold





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