Subject: pkg/35831: perl should not blindly believe /proc/self/exe
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: None <apb@cequrux.com>
List: pkgsrc-bugs
Date: 02/24/2007 19:20:00
>Number:         35831
>Category:       pkg
>Synopsis:       perl should not blindly believe /proc/self/exe
>Confidential:   no
>Severity:       serious
>Priority:       high
>Responsible:    pkg-manager
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Sat Feb 24 19:20:00 +0000 2007
>Originator:     Alan Barrett
>Release:        NetBSD 4.99.12
>Organization:
Not much
>Environment:
System: NetBSD 4.99.12
Architecture: i386
Machine: i386
>Description:
perl-5.8.8 (from pkgsrc/lang/perl5) tries to determine at
configure time whether /proc/self/exe is a symlink to the
running program.  At run time, it does not adequately sanity
check the result from readlink("/proc/self/exe").  This
can lead to perl's $^X variable containing "/" instead of a valid
path to the perl interpreter.

>How-To-Repeat:

$ pkg_info -e perl\*
perl-5.8.8nb4
$ type perl
perl is /usr/pkg/bin/perl
$ mount | grep procfs
procfs on /proc type procfs (local)
$ sudo mount -t null /usr/pkg /mnt
$ /mnt/bin/perl -e 'print $^X, "\n"' # should print /mnt/bin/perl
/
$ sudo umount /mnt

>Fix:

Apply the following patch (in addition to the patch that's
already in pkgsrc/lang/perl5/patches/patch-ah):

--- perl.c.orig	2006-01-31 12:34:47.000000000 +0000
+++ perl.c
@@ -4615,8 +4615,10 @@ S_procself_val(pTHX_ SV *sv, char *arg0)
        to the executable (or returning an error from the readlink).  Any valid
        path has a '/' in it somewhere, so use that to validate the result.
        See http://www.freebsd.org/cgi/query-pr.cgi?pr=35703
+
+       NetBSD's implementation sometimes returns "/"; reject that too.
     */
-    if (len > 0 && memchr(buf, '/', len)) {
+    if (len > 1 && memchr(buf, '/', len)) {
 	sv_setpvn(sv,buf,len);
     }
     else {