From 93770cfff52266774910bb9c99bfeae529e28116 Mon Sep 17 00:00:00 2001 From: Fabio Erculiani Date: Tue, 26 Nov 2013 08:28:06 +0100 Subject: [PATCH] 00-rootdev.sh: handle the case where init=/linuxrc and real_init= is not set --- defaults/initrd.d/00-rootdev.sh | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/defaults/initrd.d/00-rootdev.sh b/defaults/initrd.d/00-rootdev.sh index fe0138a..911368f 100755 --- a/defaults/initrd.d/00-rootdev.sh +++ b/defaults/initrd.d/00-rootdev.sh @@ -153,12 +153,20 @@ real_root_init() { if [ -z "${REAL_ROOT}" ] && [ "${FAKE_ROOT}" != "/dev/ram0" ]; then REAL_ROOT="${FAKE_ROOT}" fi + + local default_init="/sbin/init" if [ -z "${REAL_INIT}" ] && [ -z "${FAKE_INIT}" ]; then # if none of REAL_INIT and FAKE_INIT are set, default - # to /sbin/init - REAL_INIT="/sbin/init" - elif [ -z "${REAL_INIT}" ] && [ "${FAKE_INIT}" != "/linuxrc" ]; then - REAL_INIT="${FAKE_INIT}" + # to ${default_init} + REAL_INIT="${default_init}" + elif [ -z "${REAL_INIT}" ]; then + if [ "${FAKE_INIT}" = "/linuxrc" ]; then + # if init=/linuxrc is given, ignore linuxrc + # this is for backward compatibility with very old setups + REAL_INIT="${default_init}" + else + REAL_INIT="${FAKE_INIT}" + fi fi if [ -z "${REAL_ROOTFLAGS}" ]; then REAL_ROOTFLAGS="${FAKE_ROOTFLAGS}"