一个solaris的内核问题的解答
作者: Badcoffee
Email: blog.oliver@gmail.com
Blog: http://blog.csdn.net/yayong
2004年11月
回答别人的问题能促使自己学到很多东西。
下面是我回答chinaunix网友的关于solaris内核编程的一个记录,绝对值得收藏,也许某天我会根据这个写一些东西出来:)
问题:solaris 下,map 文件到一虚拟内存地址,然后对该虚拟内存地址进行写操作,该写操作居然绕过了内核的vnode VOP_WRITE操作直接写到物理磁盘上。请问:该io操作怎么写道磁盘上的?我痛苦几周了,哪位高手救命啊!!!
答:你是用mmap(2)吗?
具体参数是甚么?
如果你用了 MAP_SHARED,而且用了 PROT_WRITE
那么,修改内存文件肯定会一起被修改。
以下节选自man page:
The MAP_SHARED and MAP_PRIVATE options describe the disposi-
tion of write references to the underlying object. If
MAP_SHARED is specified, write references will change the
memory object. If MAP_PRIVATE is specified, the initial
write reference will create a private copy of the memory
object page and redirect the mapping to the copy.
再问:如楼上所说,修改内存文件肯定会一起被修改,但我现在想知道内核是怎样实现写入磁盘的。普通的文件的write操作,内核是通过vnode VOP_WRITE写入磁盘的,而map操作没有这样做,而是通过其它途径写入磁盘的。该途径是什么,我研究了solaris 的内核,用了很多种方法,仍然不得其解。有熟悉solaris 内核代码的人吗?本人不胜感激。
再答:mmap影射一个ufs系统的普通文件到内存是
使用vnode的VOP_MAP来作的,
map成功后
读写都是直接访问内存方式,
第一次读会产生page fault, 导致最终调用 vop_getpage, ufs_getpage
写则是vop_putpage, ufs_putpage, 最终该页被标志为dirty,由fflush写回磁盘
因此,使用mmap确实不会用VOP_WRITE
vop_write和vop_read都是在read和write系统调用,即文件IO时才使用