Linux内核文件系统-挂载流程分析-阿里云开发者社区

开发者社区> 开发与运维> 正文

Linux内核文件系统-挂载流程分析

简介:

1.根文件系统的挂载

  • mount_root[init/do_mounts.c]
    • create_dev(“/dev/root”, ROOT_DEV) ==> how to do this
      • sys_unlink(“/dev/root”)
      • sys_mknod(“/dev/root”,…)
    • mount_block_root(“/dev/root”, flags)
      • get_fs_names -> copy root_fs_names
      • do_mount_root ==> 调用系统调用sys_mount,sys_chdir(“/root”),为当 前进程current->fs.pwd.dentry设置挂载返回的root dentry
        • sys_mount ==>进入系统调用

2.进入系统调用的挂载,也是用户态挂载文件系统的入口

  • sys_mount[fs/namespace.c]
    • copy_mount_string
    • copy_mount_options
    • do_mount
      • user_path(dirname, &path) -> path_lookupat ==> 获取挂载路径的struct path,查找路径是很复杂的过程:)
      • do_remount
      • do_loopback
      • do_change_type
      • do_move_mount
      • do_new_mount ==> 构建虚拟挂载点vsfmount,检查设置namespace
        • get_fs_type ==> 在file_systems查找传入的文件系统类型
        • vfs_kernel_mount ==> 调用具体文件系统的mount,并将返回的root dentry与分配的vfsmount挂接
          • alloc_vfsmnt ==> 从slob中分配虚拟挂载点struct vfsmount
          • root = mount_fs
            • type->mount ==> 调用具体文件系统的mount,返回root dentry
            • 设置vfsmount结构内容

3.进入具体文件系统类型的mount,此处以ext2为例分析

  • 模块初始化时

    • init_inodecache分配slab作为inode的cache
    • register_filesystem加入模块全局变量file_systems
  • struct file_system_type ext2_fs_type

    • ext2_mount
      • mount_bdev ==> 传入ext2_fill_super,返回root dentry
        • blkdev_get_by_path ==> 通过设备节点路径名构造block_device结构
        • sget ==> 获取或分配super block结构体,并将bdev绑定到sb上
        • fill_super ==> 填充super block
          • sb_bread ==> 读取super block的count块到buffer head,先查找lru缓存
            • __find_get_clock_slow ==> 根据bdev中的inode及inode中的i_mapping信息将page cache读到buffer head里
    • kill_block_super

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章