f2fs get_node_path 函数过程分析

2024-04-06 00:32

本文主要是介绍f2fs get_node_path 函数过程分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

f2fs中比较有趣的一个函数get_node_path(), 想要理解这个函数,需要对f2fs node及node中能够索引的地址理解清楚,先看一下f2fs inode的结构:

  4KB * (923 + 2 * 1018 + 2 * 1018 * 1018 + 1018 * 1018 * 1018) := 3.94TB.

   Inode block (4KB)
     |- data (923)
     |- direct node (2)
     |          `- data (1018)
     |- indirect node (2)
     |            `- direct node (1018)
     |                       `- data (1018)
     `- double indirect node (1)
                         `- indirect node (1018)
                          `- direct node (1018)
                                             `- data (1018)

f2fs node有三种类型,inode, direct node和indirect node. inode block为4KB, 除去一些文件相关的meta data, 最多预留923个data block索引,2个direct node 索引,2个indirect node索引和一个double indirect node索引。

每个direct node包含1018个data block索引,同样,每个indirect node 包含1018个direct node, 以此类推,一个indoe最多能表示的文件大小为3.94TB。下面看一下get_node_path()这个函数。

static int get_node_path(struct f2fs_inode_info *fi, long block,int offset[4], unsigned int noffset[4])
{const long direct_index = ADDRS_PER_INODE(fi);const long direct_blks = ADDRS_PER_BLOCK;const long dptrs_per_blk = NIDS_PER_BLOCK;const long indirect_blks = ADDRS_PER_BLOCK * NIDS_PER_BLOCK;const long dindirect_blks = indirect_blks * NIDS_PER_BLOCK;int n = 0;int level = 0; noffset[0] = 0;

四个参数,f2fs_node_info,  block:索引data的 block index, 两个传出参数,offset[4]:node block中的索引偏移,noffset[4]:一共多少个offset索引block。

level表示一共多少级,如果block index在inode能表示的范围内,则level为0,如果block index在direct node表示的范围内,则 level为1, 如果用indirect node表示,则level为2,最后一种情况下为3,共4级。

结合代码,看一下查看的情况:

static int get_node_path(struct f2fs_inode_info *fi, long block,int offset[4], unsigned int noffset[4])
{const long direct_index = ADDRS_PER_INODE(fi);const long direct_blks = ADDRS_PER_BLOCK;const long dptrs_per_blk = NIDS_PER_BLOCK;const long indirect_blks = ADDRS_PER_BLOCK * NIDS_PER_BLOCK;const long dindirect_blks = indirect_blks * NIDS_PER_BLOCK;int n = 0;int level = 0;noffset[0] = 0;if (block < direct_index) {offset[n] = block;goto got;}block -= direct_index;//1018if (block < direct_blks) {offset[n++] = NODE_DIR1_BLOCK;noffset[n] = 1;offset[n] = block;level = 1;goto got;}

block查找情况如下图所示:

在这里,假设inode中包含的direct index, 即data block直接索引为873个(根据不同平台,不同设置indoe中能表示的最多data block index不同),结合代码,可以看出查找的过程。

1) 如果传进来的data_block_index=0,  data_block_index < 872,  则offset[0]=data_block_index, 即0号data block可以通过inode中的data block index得到,并且其offset为0, 通过inode得到的level也为0, 返回。

2) 如果传进来的data_block_index=873, data_block_index<873不成立, 则data_block_index-=873, 此时data_block_index =0, 之后判断data_block_index < 1018, 说明可以通过第一个direct block得到, 此时offset[0]=924, 设置第一个direct block在inode中的索引地址,offset[1] = 0, 说明在第一个direct block中的索引为0, noffset[1]=1, 说明此时offset block为1个。

其它情况依次类推。

这篇关于f2fs get_node_path 函数过程分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878558

相关文章

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N