move /dev/shm to /tmp/shm
authorDaniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
Sat, 11 Jul 2015 01:58:38 +0000 (18:58 -0700)
committerJohn Crispin <blogic@openwrt.org>
Tue, 15 Sep 2015 19:30:11 +0000 (21:30 +0200)
Since the /dev filesystem is tiny, /dev/shm needs to live somewhere
else.

Signed-off-by: Daniel Gimpelevich <daniel@gimpelevich.san-francisco.ca.us>
initd/early.c
plug/coldplug.c

index 3f9cf6989825189d59afe09217d3bcaf1c260c76..89c8104625aa80a8c874a78eeae8d553415173db 100644 (file)
@@ -66,16 +66,20 @@ early_mounts(void)
        mount("sysfs", "/sys", "sysfs", MS_NOATIME, 0);
        mount("none", "/sys/fs/cgroup", "cgroup", 0, 0);
        mount("tmpfs", "/dev", "tmpfs", MS_NOATIME, "mode=0755,size=512K");
-       mkdir("/dev/shm", 01777);
+       symlink("/tmp/shm", "/dev/shm");
        mkdir("/dev/pts", 0755);
        mount("devpts", "/dev/pts", "devpts", MS_NOATIME, "mode=600");
        early_dev();
 
        early_console("/dev/console");
-       if (mount_zram_on_tmp())
+       if (mount_zram_on_tmp()) {
                mount("tmpfs", "/tmp", "tmpfs", MS_NOSUID | MS_NODEV | MS_NOATIME, NULL);
-       else
-               mkdev("*", 0600);
+               mkdir("/tmp/shm", 01777);
+       } else {
+               mkdir("/tmp/shm", 01777);
+               mount("tmpfs", "/tmp/shm", "tmpfs", MS_NOSUID | MS_NODEV | MS_NOATIME,
+                               "mode=01777");
+       }
        mkdir("/tmp/run", 0777);
        mkdir("/tmp/lock", 0777);
        mkdir("/tmp/state", 0777);
index d3a607d63098962673c4ba2b6866f64eb63b4a09..bfd3513ce4f45496eb1da637f9df5526ff32e7f6 100644 (file)
@@ -45,7 +45,7 @@ void procd_coldplug(void)
        umount2("/dev/pts", MNT_DETACH);
        umount2("/dev/", MNT_DETACH);
        mount("tmpfs", "/dev", "tmpfs", 0, "mode=0755,size=512K");
-       mkdir("/dev/shm", 01777);
+       symlink("/tmp/shm", "/dev/shm");
        mkdir("/dev/pts", 0755);
        umask(oldumask);
        mount("devpts", "/dev/pts", "devpts", 0, 0);