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

相关文章

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

找不到Anaconda prompt终端的原因分析及解决方案

《找不到Anacondaprompt终端的原因分析及解决方案》因为anaconda还没有初始化,在安装anaconda的过程中,有一行是否要添加anaconda到菜单目录中,由于没有勾选,导致没有菜... 目录问题原因问http://www.chinasem.cn题解决安装了 Anaconda 却找不到 An

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda