solaris的内核问题有什么?
一个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时才使用