UBIFS文件系统(二)
本文主要对ubifs文件系统数据回写过程进行描述,即将处于page cache中的数据写入flash的过程。下文以ubifs_data_node为例描述ubifs中数据回写到flash的过程,其他类型node的回写过程与此类似。
ubifs_data_node的数据回写过程由ubifs_jnl_write_data函数实现:将待回写的数据(固定为一个block大小)封装成为一个ubifs_data_node;在journal head中查找足够存储该ubifs_data_node的空闲空间;将ubifs_data_node写入journal head对应的缓冲区wbuf;将ubifs_data_node所属的inode号链入wbuf的ino_list链表中;添加该ubifs_data_node到TNC中。
ubifs_data_node的封装
ubifs保存数据的基本单位是block,并且为了节省数据占用空间,ubifs在将page cache的数据写回到flash之前,会对page cache中的数据进行压缩,因此一个ubifs_data_node实际占用的空间最大为:
len = ubifs_data_node_sz + blocksize * worst_compare_factor
上式中,ubifs_data_node_sz为一个ubifs_data_node结构数据头的大小;blocksize为flash的一个block的大小(最小的写单位min_io_size);worst_compare_factor为最坏情况下的压缩率。在flash查找空闲空间保存ubifs_data_node