summaryrefslogtreecommitdiffstats
path: root/meta/recipes-devtools/perl/files/perl-dynloader.patch
blob: 5472602d3af582bfc1b01b28038b894440a48bef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
From 25a26c52c320e699b37a7ad1f4f045bc8aa4cb00 Mon Sep 17 00:00:00 2001
From: Richard Purdie <richard@openedhand.com>
Date: Sun, 27 May 2007 21:04:11 +0000
Subject: [PATCH] perl: 5.8.7 -> 5.8.8 (from OE)

Upstream-Status: Inappropriate [embedded specific]

Allow the location that .so files are searched for for dynamic
loading to be changed via an environment variable. This is to allow
us to load .so's from the host system while building for the target
system.

Update by Nitin A Kamble <nitin.a.kamble@intel.com> 2011/04/21
---
 dist/XSLoader/XSLoader_pm.PL | 18 ++++++++++++++++++
 1 file changed, 18 insertions(+)

diff --git a/dist/XSLoader/XSLoader_pm.PL b/dist/XSLoader/XSLoader_pm.PL
index ff5ca31..0d50803 100644
--- a/dist/XSLoader/XSLoader_pm.PL
+++ b/dist/XSLoader/XSLoader_pm.PL
@@ -32,6 +32,24 @@ sub load {
     my ($caller, $modlibname) = caller();
     my $module = $caller;
 
+    # OE: Allow env to form dynamic loader to look in a different place
+    # This is so it finds the host .so files, not the targets
+    if (defined $ENV{PERLHOSTLIB})
+    {
+        my $hostlib = $ENV{PERLHOSTLIB};
+        my $hostarchlib = $ENV{PERLHOSTARCHLIB};
+        print STDERR "*** Module name IN: $modlibname\n";
+        my ($p1, $p2, $p3, $p4, $p5, $p6, $p7) = $modlibname =~ m/(^(.*lib\w*\/)?)((perl5\/[0-9\.]*\/)?)(([^\/]*)\/)?(.*)$/;
+        print STDERR "*** p1: $p1  p3: $p3  p5: $p5 p7: $p7\n";
+        if ( $p1 ne "" ) {
+            $modlibname = $hostlib.$p7;
+        }
+        if ( $p6 ne "" ) {
+            $modlibname = $hostarchlib.$p7;
+        }
+        print STDERR "*** Module name OUT: $modlibname\n";
+    }
+
     if (@_) {
         $module = $_[0];
     } else {