磁盤驅動就是實現磁盤空間和內存空間數據上的交互,在上一篇中我們討論了內存端的Page Segment Block Sector相關的概念,本文以3.14內核為例,討論這部分內存是如何被組織管理的。我們知道,為了解決CPU和內存的速度不匹配,計算機系統引入了Cache緩存機制,這種硬件Cache的速度接近CPU內部寄存器的速度,可以提高系統效率,同樣的思路也適用于解決內存和磁盤的速度不匹配問題,此外,磁盤多是機械式的,從壽命的角度考慮也不適合頻繁讀寫,所以內核就將一部分內存作為緩存,提高磁盤訪問速度的同時延長磁盤壽命,這種緩存就是磁盤高速緩存。包括頁高速緩存(Page Cache,對完整數據頁進行操作的磁盤高速緩存) + 目錄項高速緩存(Dentry Cache,描述文件系統路徑名的目錄項對象) + 索引節(jié)點高速緩存(Buffer Cache,存放的是描述磁盤索引節(jié)點的索引節(jié)點對象),本文主要討論頁高速緩存,有了頁高速緩存,內核的代碼和數據結構不必從磁盤讀,也不必寫入磁盤。頁高速緩存可以看作特定文件系統層的一部分。
SYSCALL_DEFINE3(read, unsigned int, fd, char __user *, buf, size_t, count)
└── vfs_read(f.file, buf, count, &pos);
└──file->f_op->read(file, buf, count, pos);
└──do_sync_read(file, buf, count, pos);
└──filp->f_op->aio_read(&kiocb, &iov, 1, kiocb.ki_pos);
├──generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov, unsigned long nr_segs, loff_t pos)
└──filemap_write_and_wait_range(mapping, pos, pos + iov_length(iov, nr_segs) - 1);
-----------------------------------Page Cache----------------------------------------------------
int mpage_readpage(struct page *page, get_block_t get_block)