From aab3c1306ff99d593966a192ad7c4678b605b8bd Mon Sep 17 00:00:00 2001 From: Laurentiu Palcu Date: Thu, 20 Dec 2012 15:15:38 +0200 Subject: [PATCH] qemu.bbclass: add qemu_run_binary() function [YOCTO #3602] (From OE-Core rev: 2cfbe0bd9d02ab8c054e5bc879a2181c6a7e3719) Signed-off-by: Laurentiu Palcu Signed-off-by: Saul Wold Signed-off-by: Richard Purdie --- meta/classes/qemu.bbclass | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/meta/classes/qemu.bbclass b/meta/classes/qemu.bbclass index aead8e2809..13af3390aa 100644 --- a/meta/classes/qemu.bbclass +++ b/meta/classes/qemu.bbclass @@ -13,3 +13,20 @@ def qemu_target_binary(data): target_arch = "ppc64" return "qemu-" + target_arch +# +# Next function will return a string containing the command that is needed to +# to run a certain binary through qemu. For example, in order to make a certain +# postinstall scriptlet run at do_rootfs time and running the postinstall is +# architecture dependent, we can run it through qemu. For example, in the +# postinstall scriptlet, we could use the following: +# +# ${@qemu_run_binary(d, '$D', '/usr/bin/test_app')} [test_app arguments] +# +def qemu_run_binary(data, rootfs_path, binary): + dynamic_loader = rootfs_path + '$(readelf -l ' + rootfs_path + \ + binary + '| grep "Requesting program interpreter"|sed -e \'s/^.*\[.*: \(.*\)\]/\\1/\')' + library_path = rootfs_path + data.getVar("base_libdir", True) + ":" + \ + rootfs_path + data.getVar("libdir", True) + + return qemu_target_binary(data) + " " + dynamic_loader + " --library-path " + library_path \ + + " " + rootfs_path + binary