[PATCH RESEND] Don't remove /sys in initramfs

From: Juerg Billeter (juerg_at_paldo.org)
Date: 11/05/04

  • Next message: Bill Davidsen: "Re: mmap going to wrong physical address"
    To: linux-kernel@vger.kernel.org
    Date:	Fri, 05 Nov 2004 16:26:57 +0100
    
    

    Using the "resume" kernel parameter together with an initramfs revealed
    a bug that causes removal of the /sys directory in the initramfs' tmpfs,
    making the system unbootable.

    The source of the problem is that the try_name() function removes
    the /sys directory unconditionally, instead of removing it only when it
    has been created by try_name().

    The attached patch only removes /sys if it has been created before.

    Please CC me, I'm not on lkml.

            Juerg

    --
    Signed-off-by: Juerg Billeter <juerg@paldo.org>
    diff -upNr linux-2.6.10-rc1-bk15.orig/init/do_mounts.c linux-2.6.10-rc1-bk15/init/do_mounts.c
    --- linux-2.6.10-rc1-bk15.orig/init/do_mounts.c 2004-10-18 23:53:51.000000000 +0200
    +++ linux-2.6.10-rc1-bk15/init/do_mounts.c      2004-11-05 16:24:17.816549948 +0100
    @@ -142,7 +142,7 @@ dev_t __init name_to_dev_t(char *name)
            int part;
     #ifdef CONFIG_SYSFS
    -       sys_mkdir("/sys", 0700);
    +       int mkdir_err = sys_mkdir("/sys", 0700);
            if (sys_mount("sysfs", "/sys", "sysfs", 0, NULL) < 0)
                    goto out;
     #endif
    @@ -197,7 +197,8 @@ done:
     #ifdef CONFIG_SYSFS
            sys_umount("/sys", 0);
     out:
    -       sys_rmdir("/sys");
    +       if (!mkdir_err)
    +               sys_rmdir("/sys");
     #endif
            return res;
     fail:
    -
    To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
    the body of a message to majordomo@vger.kernel.org
    More majordomo info at  http://vger.kernel.org/majordomo-info.html
    Please read the FAQ at  http://www.tux.org/lkml/
    

  • Next message: Bill Davidsen: "Re: mmap going to wrong physical address"

    Relevant Pages