Date: Sun, 27 Nov 2005 15:14:23 -0600 From: Mark Kane <mark@mkproductions.org> To: "Michael C. Shultz" <ringworm01@gmail.com> Cc: freebsd-questions@freebsd.org Subject: Re: After upgrading Perl, cannot reinstall modules - Cwd.so: Undefined symbol "perl_get_sv Message-ID: <438A21AF.1090206@mkproductions.org> In-Reply-To: <200511271250.02806.ringworm01@gmail.com> References: <43890854.8060901@mkproductions.org> <200511271239.15344.ringworm01@gmail.com> <438A1CEA.2020000@mkproductions.org> <200511271250.02806.ringworm01@gmail.com>
next in thread | previous in thread | raw e-mail | index | archive | help
This is an OpenPGP/MIME signed message (RFC 2440 and 3156) --------------enig445F15C9FFFA98ACDBA6A6F1 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Michael C. Shultz wrote: > On Sunday 27 November 2005 12:54, Mark Kane wrote: >=20 >>Michael C. Shultz wrote: >> >>>On Sunday 27 November 2005 12:42, Mark Kane wrote: >>> >>>>Michael C. Shultz wrote: >>>> >>>>>On Sunday 27 November 2005 12:29, Mark Kane wrote: >>>>> >>>>>>Michael C. Shultz wrote: >>>>>> >>>>>>>On Saturday 26 November 2005 22:20, Mark Kane wrote: >>>>>>> >>>>>>>>Michael C. Shultz wrote: >>>>>>>> >>>>>>>>>On Saturday 26 November 2005 19:25, Michael C. Shultz wrote: >>>>>>>>> >>>>>>>>>>On Saturday 26 November 2005 18:48, Mark Kane wrote: >>>>>>>>>> >>>>>>>>>>>Michael C. Shultz wrote: >>>>>>>>>>> >>>>>>>>>>>>On Saturday 26 November 2005 17:13, Mark Kane wrote: >>>>>>>>>>>> >>>>>>>>>>>>>Hi everyone. I finally did a big portupgrade on a 4.9-RELEAS= E >>>>>>>>>>>>>system today and I'm having some problems with Perl. >>>>>>>>>>>>> >>>>>>>>>>>>>I got it updated to 5.8.7 (was 5.6.x before), ran "use.perl >>>>>>>>>>>>>port", and ran the perl-after-upgrade script which were all >>>>>>>>>>>>>said in UPDATING. Now it's time to force upgrade/recompile t= he >>>>>>>>>>>>>Perl modules for the new version. >>>>>>>>>>>>> >>>>>>>>>>>>>Unfortunately this is where I get stuck: >>>>>>>>>>>>> >>>>>>>>>>>>>xeon1# portupgrade -f p5-\* >>>>>>>>>>>>> >>>>>>>>>>>>>[snip] >>>>>>>>>>>>> >>>>>>>>>>>>>=3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: >>>>>>>>>>>>>/usr/local/bin/perl5.8.7 - found =3D=3D=3D> p5-HTML-Tagset= -3.10 >>>>>>>>>>>>>depends on file: >>>>>>>>>>>>>/usr/local/bin/perl5.8.7 - found =3D=3D=3D> Configuring for= >>>>>>>>>>>>>p5-HTML-Tagset-3.10 >>>>>>>>>>>>>/usr/libexec/ld-elf.so.1: >>>>>>>>>>>>>/usr/local/lib/perl5/5.8.7/mach/auto/Cwd/Cwd.so: Undefined >>>>>>>>>>>>>symbol "perl_get_sv" >>>>>>>>>>>>>*** Error code 1 >>>>>>>>>>>>>------------------------------------ >>>>>>>>>>>>> >>>>>>>>>>>>>The remaining Perl modules that are supposed to be >>>>>>>>>>>>>upgraded/recompiled either error out with the same message o= r >>>>>>>>>>>>>are skipped because one that it requires errored out. >>>>>>>>>>>>> >>>>>>>>>>>>>I tried Googling for that error, but nothing came up. Other = info >>>>>>>>>>>>>that might be useful: >>>>>>>>>>>>> >>>>>>>>>>>>>xeon1# pkg_which /usr/local/lib/perl5/5.8.7/mach/auto/Cwd/Cw= d.so >>>>>>>>>>>>>perl-5.8.7 >>>>>>>>>>>>>----- >>>>>>>>>>>>>xeon1# pkg_info | grep p5 >>>>>>>>>>>>>p5-Authen-SASL-2.04 Perl5 module for SASL authentication >>>>>>>>>>>>>p5-Compress-Zlib-1.41 Perl5 interface to zlib compression >>>>>>>>>>>>>library p5-DBD-mysql-2.1026_1 MySQL driver for the Perl5 >>>>>>>>>>>>>Database Interface (DBI) p5-DBI-1.38 The perl5 Datab= ase >>>>>>>>>>>>>Interface. Required for DBD::* modules >>>>>>>>>>>>>p5-Digest-1.13 Modules that calculate message digests >>>>>>>>>>>>>p5-Digest-MD5-2.27 Perl5 interface to the MD5 algorithm >>>>>>>>>>>>>p5-HTML-Parser-3.31 Perl5 module for parse HTML tag >>>>>>>>>>>>>p5-HTML-Tagset-3.03 Some useful data table in parsing HTML >>>>>>>>>>>>>p5-MIME-Base64-2.20 Perl5 module for Base64 and Quoted-Print= able >>>>>>>>>>>>>encodings p5-Net-1.16,1 Perl5 modules to access and us= e >>>>>>>>>>>>>network protocols p5-URI-1.25 Perl5 interface to Uni= form >>>>>>>>>>>>>Resource Identifier (URI) refere >>>>>>>>>>>>>p5-libvorbis-0.04 Perl extension for Ogg Vorbis streams >>>>>>>>>>>>>p5-libwww-5.69 Perl5 library for WWW access >>>>>>>>>>>>>----- >>>>>>>>>>>>> >>>>>>>>>>>>>Thanks very much in advance as this is a production server w= hich >>>>>>>>>>>>>uses Perl all the time. >>>>>>>>>>>>> >>>>>>>>>>>>>-Mark >>>>>>>>>>>>>FreeBSD 4.9-RELEASE i386 >>>>>>>>>>>> >>>>>>>>>>>>On a 4.11 system sysutils/portmanager has no problem with per= l5.8 >>>>>>>>>>>>and www/p5-HTML-Tagset, just tested it, not sure if it will r= un >>>>>>>>>>>>on 4.9 but you you may want to give it a try. >>>>>>>>>>>> >>>>>>>>>>>>-Mike >>>>>>>>>>> >>>>>>>>>>>Thanks for the reply. I have never used portmanager, but I did= >>>>>>>>>>>give it a try like you said. Unfortunately it produced the sam= e >>>>>>>>>>>error when building that portupgrade did. I should also point = out >>>>>>>>>>>that I did try just a "make" from the port directory to see if= it >>>>>>>>>>>had something to do with portupgrade, and that failed with the= >>>>>>>>>>>same message about "perl_get_sv" as well. >>>>>>>>>>> >>>>>>>>>>>Here is the output from portmanager. I have omitted other erro= rs >>>>>>>>>>>that were about other Perl modules that were not installed via= >>>>>>>>>>>ports at all. >>>>>>>>>>> >>>>>>>>>>>xeon1# portmanager www/p5-HTML-Tagset >>>>>>>>>>> >>>>>>>>>>>[snip] >>>>>>>>>>> >>>>>>>>>>>-------------------- >>>>>>>>>>>update p5-HTML-Tagset-3.10 >>>>>>>>>>>MGPMrUpdate 0.3.9_2 localProperty.command: #9 of 14 cd >>>>>>>>>>>/usr/ports/www/p5-HTML-Tagset; make >>>>>>>>>>>--------------------------------------------------------------= ---- >>>>>>>>>>>-- -- -- =3D=3D=3D> Vulnerability check disabled, database no= t found >>>>>>>>>>>=3D=3D=3D> Extracting for p5-HTML-Tagset-3.10 >>>>>>>>>>>=3D> MD5 Checksum OK for HTML-Tagset-3.10.tar.gz. >>>>>>>>>>>=3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: >>>>>>>>>>>/usr/local/bin/perl5.8.7 - found =3D=3D=3D> Patching for >>>>>>>>>>>p5-HTML-Tagset-3.10 >>>>>>>>>>>=3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: >>>>>>>>>>>/usr/local/bin/perl5.8.7 - found =3D=3D=3D> p5-HTML-Tagset-3= =2E10 >>>>>>>>>>>depends on file: >>>>>>>>>>>/usr/local/bin/perl5.8.7 - found =3D=3D=3D> Configuring for >>>>>>>>>>>p5-HTML-Tagset-3.10 >>>>>>>>>>>/usr/libexec/ld-elf.so.1: >>>>>>>>>>>/usr/local/lib/perl5/5.8.7/mach/auto/Cwd/Cwd.so: Undefined sym= bol >>>>>>>>>>>"perl_get_sv" >>>>>>>>>>>*** Error code 1 >>>>>>>>>>> >>>>>>>>>>>Stop in /usr/ports/www/p5-HTML-Tagset. >>>>>>>>>>>MGPMrUpdate 0.3.9_2 error: make returned an error, adding >>>>>>>>>>>/www/p5-HTML-Tagset to ignore.db >>>>>>>>>>>reverting bsd.port.mk patch -=3D>cd /usr/ports/Mk; patch -R < >>>>>>>>>>>/usr/local/share/portmanager/patch-bsd.port.mk-0.3.6; >>>>>>>>>>>Hmm... Looks like a unified diff to me... >>>>>>>>>>>The text leading up to this was: >>>>>>>>>>>-------------------------- >>>>>>>>>>> >>>>>>>>>>>|--- /usr/ports/Mk/bsd.port.mk Tue Nov 8 01:02:51 2005 >>>>>>>>>>>|+++ bsd.port.mk Wed Nov 16 02:16:57 2005 >>>>>>>>>>> >>>>>>>>>>>-------------------------- >>>>>>>>>>>Patching file bsd.port.mk using Plan A... >>>>>>>>>>>Hunk #1 succeeded at 2049. >>>>>>>>>>>done >>>>>>>>>>>rCreateInstalledDbVerifyContentsFile 0.3.9_2 error: "@comment >>>>>>>>>>>ORIGIN:" not found in /var/db/pkg/bsdpan-XML-Parser-2.34/+CONT= ENTS >>>>>>>>>>> bsdpan-XML-Parser-2.34 installation is corrupt! >>>>>>>>>>> recomend running "pkg_delete -f >>>>>>>>>>>bsdpan-XML-Parser-2.34" then manually reinstalling this port >>>>>>>>>>>-------------------- >>>>>>>>>>> >>>>>>>>>>>Thanks >>>>>>>>>>> >>>>>>>>>>>-Mark >>>>>>>>>> >>>>>>>>>>I dug a little and think have figured the problem but not posit= ive. >>>>>>>>>>I think your running perl configure from the original perl and = not >>>>>>>>>>the one >>>>>>>>>> >>>>>>>>>> >>>>>>>>>> >>>>>>>>> >>>>>>>>>>from ports. >>>>>>>>> >>>>>>>>>>Assuming you use csh as your shell try in .cshrc to change the >>>>>>>>>>order of the path staement so it looks at /usr /local directori= es >>>>>>>>>>first. >>>>>>>>>> >>>>>>>>>>from: >>>>>>>>>> >>>>>>>>>>set path =3D >>>>>>>>>>(/sbin /bin /usr/sbin /usr/bin /usr/games /usr/local/sbin >>>>>>>>>>/usr/local/bin /usr/X11R6/bin $HOME/bin /home/mike/SCRIPTS >>>>>>>>>>/root/bin ) >>>>>>>>>> >>>>>>>>>>to >>>>>>>>>> >>>>>>>>>>set path =3D >>>>>>>>>>( /usr/local/sbin /usr/local/bin /sbin /bin /usr/sbin /usr/bin >>>>>>>>>>/usr/games /usr/X11R6/bin $HOME/bin /home/mike/SCRIPTS /root/bi= n ) >>>>>>>>>> >>>>>>>>>> >>>>>>>>>>-Mike >>>>>>>>> >>>>>>>>>I am nearly certain your using /usr/bin/perl >>>>>>>>>instead of /usr/local/bin/perl, here is how to test: >>>>>>>>> >>>>>>>>>cd >>>>>>>>>/usr/ports/www/p5-HTML-Tagset/work/HTML-Tagset-3.10 >>>>>>>>> >>>>>>>>>try >>>>>>>>>perl Makefile.PL >>>>>>>>>and I bet you get the error >>>>>>>>>and if you try: >>>>>>>>> >>>>>>>>>/usr/local/bin/perl Makefile.PL >>>>>>>>> >>>>>>>>>I bet it works ok..... >>>>>>>> >>>>>>>>Thanks for your replies. Your explanation makes sense about the >>>>>>>>/usr/bin vs /usr/local/bin, however if I do: /usr/bin/perl --vers= ion, >>>>>>>>I get: >>>>>>>> >>>>>>>>This is perl, v5.8.7 built for i386-freebsd-64int >>>>>>>>(with 1 registered patch, see perl -V for more detail) >>>>>>>> >>>>>>>>If I do: /usr/local/bin/perl --version, I get: >>>>>>>> >>>>>>>>This is perl, v5.8.7 built for i386-freebsd-64int >>>>>>>>(with 1 registered patch, see perl -V for more detail) >>>>>>>> >>>>>>>>Looks like /usr/bin/perl is a link to another file: >>>>>>>> >>>>>>>>xeon1# ls -l /usr/bin/perl >>>>>>>>lrwxr-xr-x 1 root wheel 24 Nov 26 18:32 /usr/bin/perl -> >>>>>>>>/usr/local/bin/perl5.8.7 >>>>>>>> >>>>>>>>Finally, I tried what you said anyway: >>>>>>>> >>>>>>>>xeon1# perl Makefile.PL >>>>>>>>/usr/libexec/ld-elf.so.1: >>>>>>>>/usr/local/lib/perl5/5.8.7/mach/auto/Cwd/Cwd.so: Undefined symbol= >>>>>>>>"perl_get_sv" >>>>>>>>xeon1# /usr/local/bin/perl Makefile.PL >>>>>>>>/usr/libexec/ld-elf.so.1: >>>>>>>>/usr/local/lib/perl5/5.8.7/mach/auto/Cwd/Cwd.so: Undefined symbol= >>>>>>>>"perl_get_sv" >>>>>>>> >>>>>>>>Thanks. >>>>>>>> >>>>>>>>-Mark >>>>>>> >>>>>>>Beats me what is wrong then. This is from running: perldoc >>>>>>>perl58delta.pod >>>>>>> >>>>>>>Perl_get_sv >>>>>>> >>>>>>> You may get errors like =E2=80=99Undefined symbol "Perl_get_s= v"=E2=80=99 or >>>>>>>"can=E2=80=99t resolve symbol =E2=80=99Perl_get_sv=E2=80=99", or t= he symbol may be >>>>>>>"Perl_sv_2pv". This probably means that you are trying to use an o= lder >>>>>>>shared Perl library (or extensions linked with such) with Perl 5.8= =2E0 >>>>>>>executable. Perl used to have such a subroutine, but that is no mo= re >>>>>>>the case. Check your shared library path, and any shared Perl >>>>>>>libraries in those directories. >>>>>>> >>>>>>> Sometimes this problem may also indicate a partial Perl 5.8.0= >>>>>>>installa=E2=80=90 tion, see "Mac OS X dyld undefined symbols" for = an example >>>>>>>and how to deal with it. >>>>>>> >>>>>>> >>>>>>>-Mike >>>>>> >>>>>>Well I tried to find some more info and ended up doing a force >>>>>>reinstall of perl. I also ran "use.perl port" and perl-after-upgrad= e >>>>>>again (which didn't show anything as moved or needed to be done so = I >>>>>>did not continue with -f). >>>>>> >>>>>>Now there is a different error when trying to force upgrade/recompi= le >>>>>>the perl modules: >>>>>> >>>>>>=3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: /usr/local/bin/pe= rl5.8.7 - >>>>>>found =3D=3D=3D> Configuring for p5-HTML-Tagset-3.10 >>>>>>Checking if your kit is complete... >>>>>>Segmentation fault (core dumped) >>>>>>*** Error code 139 >>>>>> >>>>>>Stop in /usr/ports/www/p5-HTML-Tagset. >>>>>> >>>>>>Any ideas? Again, this is a live production server that heavily rel= ies >>>>>>on Perl. >>>>>> >>>>>>Thanks. >>>>>> >>>>>>-Mark >>>>> >>>>>I need to see more context, are you manually trying to install >>>>>p5-HTML-Tagset or are you using portupgrade/portmanager for example.= >>>>> >>>>>-Mike >>>> >>>>I am doing as /usr/ports/UPDATING says to upgrade/reinstall all the P= erl >>>>modules, which is to do: >>>> >>>>portupgrade -f p5-\* >>>> >>>>p5-HTML-Tagset is just the first one that it tries, and it produces t= his: >>>> >>>>---> Upgrading 'p5-HTML-Tagset-3.03' to 'p5-HTML-Tagset-3.10' >>>>(www/p5-HTML-Tagset) >>>>---> Building '/usr/ports/www/p5-HTML-Tagset' >>>>=3D=3D=3D> Cleaning for perl-5.8.7 >>>>=3D=3D=3D> Cleaning for p5-HTML-Tagset-3.10 >>>>=3D=3D=3D> Vulnerability check disabled, database not found >>>>=3D=3D=3D> Extracting for p5-HTML-Tagset-3.10 >>>>=3D> MD5 Checksum OK for HTML-Tagset-3.10.tar.gz. >>>>=3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: /usr/local/bin/perl= 5.8.7 - >>>>found =3D=3D=3D> Patching for p5-HTML-Tagset-3.10 >>>>=3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: /usr/local/bin/perl= 5.8.7 - >>>>found =3D=3D=3D> p5-HTML-Tagset-3.10 depends on file: >>>>/usr/local/bin/perl5.8.7 - found =3D=3D=3D> Configuring for >>>>p5-HTML-Tagset-3.10 >>>>Checking if your kit is complete... >>>>Segmentation fault (core dumped) >>>>*** Error code 139 >>>> >>>>Stop in /usr/ports/www/p5-HTML-Tagset. >>>>** Command failed [exit code 1]: /usr/bin/script -qa >>>>/tmp/portupgrade52316.0 make >>>>** Fix the problem and try again. >>>>-------------------- >>>> >>>>It attempts the other Perl modules as well but fails with the same. H= ere >>>>is the final report: >>>> >>>>-------------------- >>>>** Listing the failed packages (*:skipped / !:failed) >>>> ! www/p5-HTML-Tagset (p5-HTML-Tagset-3.03) (coredump) >>>> ! converters/p5-MIME-Base64 (p5-MIME-Base64-2.20) =20 >>>>(coredump) * security/p5-Digest (p5-Digest-1.13) >>>> ! security/p5-Authen-SASL (p5-Authen-SASL-2.04) (coredump) >>>> ! databases/p5-DBI (p5-DBI-1.38) (coredump) >>>> ! audio/p5-libvorbis (p5-libvorbis-0.04) (coredump) >>>> * net/p5-URI (p5-URI-1.25) >>>> * net/p5-Net (p5-Net-1.16,1) >>>> * www/p5-HTML-Parser (p5-HTML-Parser-3.31) >>>> * databases/p5-DBD-mysql (p5-DBD-mysql-2.1026_1) >>>> ! security/p5-Digest-MD5 (p5-Digest-MD5-2.27) (coredump) >>>> ! archivers/p5-Compress-Zlib (p5-Compress-Zlib-1.41) =20 >>>>(coredump) * www/p5-libwww (p5-libwww-5.69) >>>>---> Packages processed: 0 done, 0 ignored, 6 skipped and 7 failed >>>>-------------------- >>>> >>>>Thanks >>>> >>>>-Mark >>> >>>Are you getting a portupgrade.core? Looks like that is what is >>>coredumping, If so try manually upgrading one or two of these and see >>>what happens. >>> >>>-Mike >> >>Nope, no portupgrade.core. Tried manually, same deal. Even on another o= ne: >> >>=3D=3D=3D> p5-MIME-Base64-3.05 depends on file: /usr/local/bin/perl5.= 8.7 - >>found =3D=3D=3D> Configuring for p5-MIME-Base64-3.05 >>Checking if your kit is complete... >>Segmentation fault (core dumped) >>*** Error code 139 >> >>Stop in /usr/ports/converters/p5-MIME-Base64. >> >>-Mark >=20 >=20 > Well something is core dumping, most likely perl since its not portupgr= ade. Do=20 > a search if it isn't in the current directory, like this to check the w= hole=20 > drive: >=20 > find /. | grep ".core" >=20 > If it's perl that is core dumping I think you should a) go back to usin= g the=20 > one in base or b) upgrade at least to 4.11 >=20 > -Mike Yep. /./usr/ports/archivers/p5-Compress-Zlib/work/Compress-Zlib-1.41/perl5.8.7= =2Ecore /./usr/ports/audio/p5-libvorbis/work/libvorbis-perl-0.05/perl5.8.7.core /./usr/ports/converters/p5-MIME-Base64/work/MIME-Base64-3.05/perl5.8.7.co= re /./usr/ports/databases/p5-DBI/work/DBI-1.48/perl5.8.7.core /./usr/ports/security/p5-Authen-SASL/work/Authen-SASL-2.09/perl5.8.7.core= /./usr/ports/security/p5-Digest-MD5/work/Digest-MD5-2.33/perl5.8.7.core /./usr/ports/www/p5-HTML-Tagset/work/HTML-Tagset-3.10/perl5.8.7.core To go back to using the one in the base system, would I just "use.perl system"? Then the modules should upgrade fine? My end goal when I first started the portupgrade wasn't specifically to upgrade Perl. The system was running on real old software in general (had not been portupgraded ever) and we're rolling out a new version of the software that runs the complete playlist for one of my internet radio stations. That needs the latest versions of other software programs like Icecast, libogg/libvorbis, Lame, etc. As far as I know, it doesn't require the latest Perl, but I am not 100% positive that the old version that was installed with 4.9 would work for the new software either. The main goal was to update those other programs and at the same time it would get Perl as well. I have never had bad problems like this when upgrading Perl on any other machine, so I did not expect this. As for upgrading to 4.11, I am a little nervous about doing this remotely. Aside from there not being an official documented way to do this remotely (everything I have seen in the handbook requires single user mode), I am over 500 miles away from the server so I would not have much recourse if something happened during the upgrade other than paying the datacenter [high prices] for their assistance. -Mark --=20 GnuPG Public Key: http://www.mkproductions.org/mk_pubkey.asc Internet Radio: Party107 (Trance/Electronic) - http://www.party107.com Rock 101.9 The Edge (Rock) - http://www.rock1019.net IRC: MIXXnet IRC Network - irc.mixxnet.net (Nick: MIXX941) --------------enig445F15C9FFFA98ACDBA6A6F1 Content-Type: application/pgp-signature; name="signature.asc" Content-Description: OpenPGP digital signature Content-Disposition: attachment; filename="signature.asc" -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.2 (FreeBSD) iD8DBQFDiiGvlH2ybcmj7I8RArKIAJ4wUNoTCG8Y572q1itI9RpKOH3ELACeII2q kwJ4kR8qa8cLUOZY48d0w0M= =AzF6 -----END PGP SIGNATURE----- --------------enig445F15C9FFFA98ACDBA6A6F1--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?438A21AF.1090206>
