diff options
author | Joshua Lock <josh@linux.intel.com> | 2010-02-11 16:11:01 +0000 |
---|---|---|
committer | Joshua Lock <josh@linux.intel.com> | 2010-02-11 16:21:09 +0000 |
commit | 6e1cc7ca104b78ebb34a15eb4a41e33c7186d2fd (patch) | |
tree | 0f47b358ce2f5e26c43777c79409274eeb218a17 | |
parent | a0795895e317fddb212dc531e2ac8943f433c562 (diff) | |
download | openembedded-core-6e1cc7ca104b78ebb34a15eb4a41e33c7186d2fd.tar.gz openembedded-core-6e1cc7ca104b78ebb34a15eb4a41e33c7186d2fd.tar.bz2 openembedded-core-6e1cc7ca104b78ebb34a15eb4a41e33c7186d2fd.tar.xz openembedded-core-6e1cc7ca104b78ebb34a15eb4a41e33c7186d2fd.zip |
relocatable.bbclass: remove hard-coded rpaths from native binaries
The relocatable path will pre-process built binaries in SYSROOT_DESTDIR and
replace any harcoded dynamic link rpaths with relative paths.
Add an inherit of class in native.bbclass to make our native packages
relocatable and tweak the chrpath recipe so that the native package can make
itself relocatable with the just built chrpath binary.
Signed-off-by: Joshua Lock <josh@linux.intel.com>
-rw-r--r-- | meta/classes/native.bbclass | 3 | ||||
-rw-r--r-- | meta/classes/relocatable.bbclass | 24 | ||||
-rw-r--r-- | meta/packages/chrpath/chrpath_0.13.bb | 5 |
3 files changed, 32 insertions, 0 deletions
diff --git a/meta/classes/native.bbclass b/meta/classes/native.bbclass index 01f886294..9d678fd80 100644 --- a/meta/classes/native.bbclass +++ b/meta/classes/native.bbclass @@ -1,3 +1,6 @@ +# We want native packages to be relocatable +inherit relocatable + # Native packages are built indirectly via dependency, # no need for them to be a direct target of 'world' EXCLUDE_FROM_WORLD = "1" diff --git a/meta/classes/relocatable.bbclass b/meta/classes/relocatable.bbclass new file mode 100644 index 000000000..81fe8c518 --- /dev/null +++ b/meta/classes/relocatable.bbclass @@ -0,0 +1,24 @@ +SYSROOT_PREPROCESS_FUNCS += "relocatable_binaries_preprocess" + +CHRPATH_BIN ?= "chrpath" + +def rpath_replace (paths, d): + chrpath = bb.data.expand('${CHRPATH_BIN}', d) + + for path in paths: + for root, dirs, files in os.walk(path): + for f in files: + if 'usr' in path: + os.system("%s -r $ORIGIN/../lib:$ORIGIN/../../lib %s/%s" % (chrpath, path,f)) + else: + os.system("%s -r $ORIGIN/../lib %s/%s" % (chrpath, path, f)) + +python relocatable_binaries_preprocess() { + paths = [] + target = bb.data.expand("${SYSROOT_DESTDIR}${TMPDIR}/sysroots/${TARGET_ARCH}-${TARGET_OS}", d) + + paths.append(target + "/bin") + paths.append(target + "/usr/bin") + + rpath_replace(paths, d) +} diff --git a/meta/packages/chrpath/chrpath_0.13.bb b/meta/packages/chrpath/chrpath_0.13.bb index e843de687..012897d57 100644 --- a/meta/packages/chrpath/chrpath_0.13.bb +++ b/meta/packages/chrpath/chrpath_0.13.bb @@ -2,6 +2,7 @@ DESCRIPTION = "chrpath allows you to change the rpath (where the application \ looks for libraries) in an application. It does not (yet) allow you to add an \ rpath if there isn't one already." LICENSE = "GPL" +PR = "r1" SRC_URI = "${DEBIAN_MIRROR}/main/c/chrpath/chrpath_${PV}.orig.tar.gz" @@ -9,4 +10,8 @@ inherit autotools S = "${WORKDIR}/chrpath-${PV}" +# We don't have a staged chrpath-native for ensuring our binary is relocatable +# so must use the one we've just built +CHRPATH_BIN = "${S}/chrpath" + BBCLASSEXTEND = "native" |