summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--build/conf/local.conf.sample4
-rw-r--r--meta/classes/image-prelink.bbclass38
-rw-r--r--meta/conf/distro/poky.conf4
3 files changed, 45 insertions, 1 deletions
diff --git a/build/conf/local.conf.sample b/build/conf/local.conf.sample
index 37c34d8f5e..66acaa49a7 100644
--- a/build/conf/local.conf.sample
+++ b/build/conf/local.conf.sample
@@ -75,6 +75,10 @@ EXTRA_IMAGE_FEATURES_mx31ads = "tools-testapps debug-tweaks"
75#PACKAGE_CLASSES ?= "package_deb package_ipk" 75#PACKAGE_CLASSES ?= "package_deb package_ipk"
76PACKAGE_CLASSES ?= "package_ipk" 76PACKAGE_CLASSES ?= "package_ipk"
77 77
78# A list of additional classes to use when building the system
79# include 'image-prelink' in order to prelink the filesystem image
80USER_CLASSES ?= "image-prelink"
81
78# POKYMODE controls the characteristics of the generated packages/images by 82# POKYMODE controls the characteristics of the generated packages/images by
79# telling poky which type of toolchain to use. 83# telling poky which type of toolchain to use.
80# 84#
diff --git a/meta/classes/image-prelink.bbclass b/meta/classes/image-prelink.bbclass
new file mode 100644
index 0000000000..faf18142e6
--- /dev/null
+++ b/meta/classes/image-prelink.bbclass
@@ -0,0 +1,38 @@
1do_rootfs[depends] += "prelink-native:do_populate_sysroot"
2
3IMAGE_PREPROCESS_COMMAND += "prelink_image; "
4
5prelink_image () {
6# export PSEUDO_DEBUG=4
7# /bin/env | /bin/grep PSEUDO
8# echo "LD_LIBRARY_PATH=$LD_LIBRARY_PATH"
9# echo "LD_PRELOAD=$LD_PRELOAD"
10
11 pre_prelink_size=`du -ks ${IMAGE_ROOTFS} | awk '{size = $1 ; print size }'`
12 echo "Size before prelinking $pre_prelink_size."
13
14 # We need a prelink conf on the filesystem, add one if it's missing
15 if [ ! -e ${IMAGE_ROOTFS}/etc/prelink.conf ]; then
16 cp ${STAGING_DIR_NATIVE}/etc/prelink.conf \
17 ${IMAGE_ROOTFS}/etc/prelink.conf
18 dummy_prelink_conf=true;
19 else
20 dummy_prelink_conf=false;
21 fi
22
23 # prelink!
24 ${STAGING_DIR_NATIVE}/usr/sbin/prelink --root ${IMAGE_ROOTFS} -amR
25
26 # Remove the prelink.conf if we had to add it.
27 if [ $dummy_prelink_conf ]; then
28 rm -f ${IMAGE_ROOTFS}/etc/prelink.conf
29 fi
30
31 # Cleanup temporary file, it's not needed...
32 rm -f ${IMAGE_ROOTFS}/etc/prelink.cache
33
34 pre_prelink_size=`du -ks ${IMAGE_ROOTFS} | awk '{size = $1 ; print size }'`
35 echo "Size after prelinking $pre_prelink_size."
36}
37
38EXPORT_FUNCTIONS prelink_image
diff --git a/meta/conf/distro/poky.conf b/meta/conf/distro/poky.conf
index 1ee7ccf511..df07d04a90 100644
--- a/meta/conf/distro/poky.conf
+++ b/meta/conf/distro/poky.conf
@@ -7,9 +7,11 @@ DISTRO_VERSION = "3.3+snapshot-${DATE}"
7 7
8MAINTAINER = "Poky <poky@openedhand.com>" 8MAINTAINER = "Poky <poky@openedhand.com>"
9 9
10USER_CLASSES ?= ""
11
10PACKAGE_CLASSES ?= "package_ipk" 12PACKAGE_CLASSES ?= "package_ipk"
11INHERIT_INSANE ?= "insane" 13INHERIT_INSANE ?= "insane"
12INHERIT += "${PACKAGE_CLASSES} debian poky devshell ${INHERIT_INSANE} packaged-staging" 14INHERIT += "${PACKAGE_CLASSES} ${USER_CLASSES} debian poky devshell ${INHERIT_INSANE} packaged-staging"
13# For some reason, this doesn't work 15# For some reason, this doesn't work
14# TARGET_OS ?= "linux" 16# TARGET_OS ?= "linux"
15# TARGET_VENDOR ?= "-poky" 17# TARGET_VENDOR ?= "-poky"