[gnome-continuous-yocto/gnomeostree-3.28-rocko: 4293/8267] busybox: Guard against interrupted compiles



commit bc72e4dac2ffdd951b4e6bcdb790016aa4538d2c
Author: Richard Purdie <richard purdie linuxfoundation org>
Date:   Mon Jan 23 11:44:29 2017 +0000

    busybox: Guard against interrupted compiles
    
    If busybox is interrupted during do_compile, it can corrupt .config with
    the suid version, or worse. Typically this leads to files disappearing,
    particularly /etc/init.d/* which leads to an empty busybox-hwclock.
    That then results in errors at do_rootfs time due to the missing package.
    
    The fix is to use any 'orig' present to restore stat at the start of
    compile.
    
    (From OE-Core rev: 601abb497531823a73bdec3baf56952086e5b4f4)
    
    Signed-off-by: Richard Purdie <richard purdie linuxfoundation org>

 meta/recipes-core/busybox/busybox.inc |    4 ++++
 1 files changed, 4 insertions(+), 0 deletions(-)
---
diff --git a/meta/recipes-core/busybox/busybox.inc b/meta/recipes-core/busybox/busybox.inc
index 1f4a48c..34f4e25 100644
--- a/meta/recipes-core/busybox/busybox.inc
+++ b/meta/recipes-core/busybox/busybox.inc
@@ -141,6 +141,10 @@ do_compile() {
        unset CFLAGS CPPFLAGS CXXFLAGS LDFLAGS
        if [ "${BUSYBOX_SPLIT_SUID}" = "1" -a x`grep "CONFIG_FEATURE_INDIVIDUAL=y" .config` = x ]; then
        # split the .config into two parts, and make two busybox binaries
+               if [ -e .config.orig ]; then
+                       # Need to guard again an interrupted do_compile - restore any backup
+                       cp .config.orig .config
+               fi
                cp .config .config.orig
                oe_runmake busybox.cfg.suid
                oe_runmake busybox.cfg.nosuid


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]