• openwrt 切换overlay文件系统为根文件系统


    http://blog.chinaunix.net/uid-27057175-id-4584360

    openwrt的overlayfs 通过/etc/preinit调用 /sbin/mount_root来完成rootfs的切换挂载和overlay

    所以研究下openwrt工程中mount_root的实现。源码目录 trunk/build_dir/target-arm_cortex-a9+vfpv3_uClibc-0.9.33.2_eabi/fstools-2014-06-22/mount_root.c
    通过CMakeList.txt 的依赖关系,得知mount_root的最终实现是overlay.c的mount_overlay()

    代码程:

    1.overlay_mount_fs()
    2.mount_extroot();
    3.mount_move("/tmp", "", "/overlay")
    4.fopivot("/overlay", "/rom")
      4.1 find_filesystem("overlay") 
      4.2 mount_f("overlayfs:/overlay", "/mnt", "overlayfs", MS_NOATIME, "lowerdir=/,upperdir=/overlay")
      4.3 pivot("/mnt", "/rom")

    翻译为脚本:

    1.
    mkdir /tmp/overlay
    mount -n -t jffs2 /dev/mtdblock3 -o rw,noatime,mode=0755 /tmp/overlay
    2.检查无 /tmp/overlay/sbin/block,ret=-1
    3.mount("/tmp/overlay", "/overlay", 0, MS_NOATIME | MS_MOVE, 0);
    等效
      mount -n -t NULL /tmp/overlay -o noatime,--move /overlay
    mount -n /tmp/overlay -o noatime,--move /overlay
    4.
        4.1 /proc/filesystem 下确认是否支持overlay
        4.2 
            mount -n -t overlayfs overlayfs:/overlay -o rw,noatime,lowerdir=/,upperdir=/overlay /mnt
        4.3 
            mount -n /proc -o noatime,--move /mnt/proc
            pivot_root /mnt /mnt/rom
            mount -n /rom/dev -o noatime,--move /dev
            mount -n /rom/tmp -o noatime,--move /tmp
            mount -n /rom/sys -o noatime,--move /sys
            mount -n /rom/overlay -o noatime,--move /overlay

    提炼一下,核心的mount jffs2分区并实现overlayfs的脚本就是:

    mount -n -t jffs2 /dev/mtdblock3 -o rw,noatime,mode=0755 /overlay
    mount -n -t overlayfs overlayfs:/overlay -o rw,noatime,lowerdir=/,upperdir=/overlay /mnt
    mount -n /proc -o noatime,--move /mnt/proc
    pivot_root /mnt /mnt/rom 
    mount -n /rom/dev -o noatime,--move /dev
    mount -n /rom/tmp -o noatime,--move /tmp
    mount -n /rom/sys -o noatime,--move /sys
    mount -n /rom/overlay -o noatime,--move /overlay
    exit 0

    不想用openwrt的init,把上面的脚本放到 /etc/preinit开头。

    ==========================================================
    broadcom的SDK中SPI flash驱动有个bug,flash分区mount的jffs2,写上大文件,多写几次就会出现校验错误,
    [   11.190000] Node totlen on flash *** != totlen from node ref ***
    复位后jffs2分区里面内容丢失,文件节点全部破坏掉了。
    [   37.290000] jffs2_scan_inode_node(): CRC failed on node at 0x005400f4: Read 0x4b9b488a, calculated 0x1f5aad85
    [   37.300000] jffs2_scan_eraseblock(): Magic bitmask 0x1985 not found at 0x0054084c: 0x1881 instead
    [   37.310000] jffs2_scan_eraseblock(): Magic bitmask 0x1985 not found at 0x00540850: 0x0201 instead
    本以为是overlayfs的补丁给打坏了,跟到最后应该是flash擦除有问题。博通重新给了一份spiflash驱动才算解决。
    为啥他们不像ATHEROS使用内核的m25p80?

  • 相关阅读:
    maskrcnn_benchmark代码分析(2)
    NoSQL现状
    CAP理论
    svn revert
    在SpringMVC中使用Jackson并格式化时间
    找了一个api管理工具
    SpringBoot读取application.properties文件
    MySQL性能优化的21个最佳实践 和 mysql使用索引
    Cannot subclass final class class com.sun.proxy.$Proxy
    AOP拦截器 表达式写法
  • 原文地址:https://www.cnblogs.com/newjiang/p/11711719.html
Copyright © 2020-2023  润新知