转载
linux内核响应一个块设备文件读写的层次结构如图(摘自ULK3):
1、VFS,虚拟文件系统。
2、Disk Caches,磁盘高速缓存。
将磁盘上的数据缓存在内存中,加速文件的读写。实际上,在一般情况下,read/write是只跟缓存打交道的。
(存在特殊情况)
read就直接从缓存读数据。如果要读的数据还不在缓存中,则触发一次读盘操作,然后等待磁盘上的数据被更新到磁盘高速缓存中;
write也是直接写到缓存里去,然后就不用管了。后续内核会负责将数据写回磁盘。
为了实现这样的缓存,每个文件的inode内嵌了一个address_space结构,通过inode->i_mapping来访问。
address_space结构中维护了一棵radix树,用于磁盘高速缓存的内存页面就挂在这棵树上。
既然磁盘高速缓存是跟文件的inode关联上的,则打开这个文件的每个进程都共用同一份缓存。
通过要读写的文件pos,可以换算得到要读写的是第几页(pos是以字节为单位,只需要除以每个页的字节数即可)。
inode被载入内存的时候,对应的磁盘高速缓存是空的(radix树上没有页面)。随着文件的读写,磁盘上的数据被载入内存,
相应的内存页被挂到radix树的相应位置上。
如果文件被写&#x