本文主要是介绍Ext2文件系统读数据流程及代码分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
读数据流程关于如何从用户态到Ext2文件系统公共部分(VFS)的流程本文不再详细介绍,这一部分与写流程基本一致,具体可以参考文末的相关文章介绍。如图是从用户态到Ext2文件系统的函数调用图,从图上可以看到对于Ext2文件系统在读数据流程中调用了大量VFS的函数,这主要原因是Ext2是Linux的原生文件系统,其实耦合还是比较大的。我们仔细观察一下,实际起作用的函数是Ext2文件系统的ext2_file_read_iter函数。
图1 读数据整体流程
像写数据一样,读数据也分为Direct读和缓存读两种形式,Direct读是从磁盘直接读取数据,而缓存读则需要先将磁盘数据读到页缓存,然后在将数据拷贝到用户的缓冲区。本文照例只介绍缓存读的场景,对于Direct读请自行阅读代码理解。
对于缓存读的流程,概括起来分为两个主要步骤,一个是查找页缓存(如果没有则分配新的),第二步是根据页缓存的状态从磁盘读取数据并填充页缓存(如果页缓存数据最新则不需要从磁盘读取数据)。
缓存命中
其实上图是一个比较复杂的函数调用关系图,这里处理了缓存没有命中的情况下的读数据的流程。如果缓存命中,整个读数据的流程将非常简单,我们可以简化为图2所示。可以看出此时在VFS的函数do_generic_file_read中即可完成整个数据的读取过程。
这篇关于Ext2文件系统读数据流程及代码分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!