summaryrefslogtreecommitdiff
path: root/meta/recipes-devtools/mklibs
diff options
context:
space:
mode:
authorDexuan Cui <dexuan.cui@intel.com>2011-02-16 17:16:39 +0800
committerSaul Wold <sgw@linux.intel.com>2011-02-22 07:21:24 -0800
commite2dbad7b7db7b62dee4bb5b6c28a5ab4dde08358 (patch)
tree8c03c268505fec7b8d4f37bb0d4240aeffb8087f /meta/recipes-devtools/mklibs
parent9a28ad6b0291e0d4c4aae6ba25a9f7752d5c2e11 (diff)
downloadopenembedded-core-e2dbad7b7db7b62dee4bb5b6c28a5ab4dde08358.tar.gz
openembedded-core-e2dbad7b7db7b62dee4bb5b6c28a5ab4dde08358.tar.bz2
openembedded-core-e2dbad7b7db7b62dee4bb5b6c28a5ab4dde08358.tar.xz
openembedded-core-e2dbad7b7db7b62dee4bb5b6c28a5ab4dde08358.zip
mklibs-native: fix the build on Ubuntu 9.04 by defining STT_GNU_IFUNC
mklibs-native needs elf.h (that is supplied by libc6-dev). since STAGING_INCDIR_NATIVE doesn't contain elf.h (we don't have eglibc-native), so the host's /usr/include/elf.h is used. Unluckily, the libc6-dev in Ubuntu 9.04 is so old that the elf.h doesn't define STT_GNU_IFUNC, so we have to define it ourselves. Fixes [BUGID #726] Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
Diffstat (limited to 'meta/recipes-devtools/mklibs')
-rw-r--r--meta/recipes-devtools/mklibs/files/fix_STT_GNU_IFUNC.patch23
-rw-r--r--meta/recipes-devtools/mklibs/mklibs-native_0.1.31.bb3
2 files changed, 25 insertions, 1 deletions
diff --git a/meta/recipes-devtools/mklibs/files/fix_STT_GNU_IFUNC.patch b/meta/recipes-devtools/mklibs/files/fix_STT_GNU_IFUNC.patch
new file mode 100644
index 000000000..88baddeda
--- /dev/null
+++ b/meta/recipes-devtools/mklibs/files/fix_STT_GNU_IFUNC.patch
@@ -0,0 +1,23 @@
+The libc6-dev in Ubuntu 9.04 is so old that the elf.h doesn't
+define STT_GNU_IFUNC, so we have to define it ourselves.
+-- Dexuan Cui (dexuan.cui@intel.com) Feb 16, 2011.
+
+diff --git a/src/mklibs-readelf/main.cpp b/src/mklibs-readelf/main.cpp
+index 2444c39..56d93f8 100644
+--- a/src/mklibs-readelf/main.cpp
++++ b/src/mklibs-readelf/main.cpp
+@@ -6,6 +6,14 @@
+ #include <vector>
+
+ #include <elf.h>
++/*
++ * The /usr/include/elf.h in some distributions(like Ubuntu 9.04) doesn't
++ * define the macro. We need to define it here.
++ */
++#ifndef STT_GNU_IFUNC
++#define STT_GNU_IFUNC 10 /* Symbol is indirect code object */
++#endif
++
+ #include <getopt.h>
+
+ #include "elf.hpp"
diff --git a/meta/recipes-devtools/mklibs/mklibs-native_0.1.31.bb b/meta/recipes-devtools/mklibs/mklibs-native_0.1.31.bb
index 2044d125e..7f4afc09f 100644
--- a/meta/recipes-devtools/mklibs/mklibs-native_0.1.31.bb
+++ b/meta/recipes-devtools/mklibs/mklibs-native_0.1.31.bb
@@ -5,10 +5,11 @@ LICENSE = "GPLv2+"
LIC_FILES_CHKSUM = "file://debian/copyright;md5=98d31037b13d896e33890738ef01af64"
DEPENDS = "python-native"
-PR = "r0"
+PR = "r1"
SRC_URI = "http://ftp.de.debian.org/debian/pool/main/m/mklibs/${BPN}_${PV}.tar.gz \
file://ac_init_fix.patch\
+ file://fix_STT_GNU_IFUNC.patch\
"
SRC_URI[md5sum] = "f4df0307ccbdf60070e42277513f27ed"