summaryrefslogtreecommitdiff
path: root/meta/classes
diff options
context:
space:
mode:
authorLaurentiu Palcu <laurentiu.palcu@intel.com>2012-09-18 18:39:49 +0300
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-12-06 12:30:33 +0000
commit0d239328b1c6b9e4afadad75972d359181fbe1a5 (patch)
tree120ebf5401bc1ef08aeb5d66783f3b60f02a11bc /meta/classes
parenta17bf5d840b5777918f324d26e085498dec86b76 (diff)
downloadopenembedded-core-0d239328b1c6b9e4afadad75972d359181fbe1a5.tar.gz
openembedded-core-0d239328b1c6b9e4afadad75972d359181fbe1a5.tar.bz2
openembedded-core-0d239328b1c6b9e4afadad75972d359181fbe1a5.zip
image.bbclass: run postinst scripts once, at rootfs time
This patch will allow the repeating postinst scriptlets to be run only once, on host, at do_rootfs time. This will lower the time for rootfs generation and, also, instead of running some time consuming scriptlets at target's first boot, we will do on the host. Signed-off-by: Laurentiu Palcu <laurentiu.palcu@intel.com> Signed-off-by: Saul Wold <sgw@linux.intel.com>
Diffstat (limited to 'meta/classes')
-rw-r--r--meta/classes/image.bbclass20
1 files changed, 17 insertions, 3 deletions
diff --git a/meta/classes/image.bbclass b/meta/classes/image.bbclass
index 7b24e4e285..719d871bca 100644
--- a/meta/classes/image.bbclass
+++ b/meta/classes/image.bbclass
@@ -156,7 +156,7 @@ inherit ${IMAGE_CLASSES}
IMAGE_POSTPROCESS_COMMAND ?= ""
MACHINE_POSTPROCESS_COMMAND ?= ""
-ROOTFS_POSTPROCESS_COMMAND ?= ""
+ROOTFS_POSTPROCESS_COMMAND_prepend = "run_intercept_scriptlets; "
# some default locales
IMAGE_LINGUAS ?= "de-de fr-fr en-gb"
@@ -166,15 +166,29 @@ LINGUAS_INSTALL ?= "${@" ".join(map(lambda s: "locale-base-%s" % s, d.getVar('IM
PSEUDO_PASSWD = "${IMAGE_ROOTFS}"
do_rootfs[nostamp] = "1"
-do_rootfs[dirs] = "${TOPDIR}"
+do_rootfs[dirs] = "${TOPDIR} ${WORKDIR}/intercept_scripts"
do_rootfs[lockfiles] += "${IMAGE_ROOTFS}.lock"
-do_rootfs[cleandirs] += "${S}"
+do_rootfs[cleandirs] += "${S} ${WORKDIR}/intercept_scripts"
do_build[nostamp] = "1"
# Must call real_do_rootfs() from inside here, rather than as a separate
# task, so that we have a single fakeroot context for the whole process.
do_rootfs[umask] = "022"
+
+run_intercept_scriptlets () {
+ if [ -d ${WORKDIR}/intercept_scripts ]; then
+ cd ${WORKDIR}/intercept_scripts
+ echo "Running intercept scripts:"
+ for script in *; do
+ if [ "$script" = "*" ]; then break; fi
+ echo "> Executing $script"
+ chmod +x $script
+ ./$script
+ done
+ fi
+}
+
fakeroot do_rootfs () {
#set -x
# When use the rpm incremental image generation, don't remove the rootfs