UNIX文件系统:多处理器映射与伪文件系统解析
1. UNIX文件系统锁机制的演变
在早期的UNIX系统中,SVR4引入了由 vop_rwlock() 和 vop_rwunlock() 虚拟节点操作实现的读写锁,用于让文件系统在内部管理inode上的锁。当调用 VOP_RWLOCK() 时,文件系统并不知道接下来是读操作还是写操作。这种实现方式在写操作时有一定合理性,但不支持多个读者同时访问。
以下是早期VxFS中 vop_rwlock() 实现的代码片段:
while (ip->i_flag & IRWLOCKED) {
ip->i_flag |= IWANT;
sleep(ip, PINOD);
}
ip->i_flag |= IRWLOCKED
释放inode上的锁时执行以下代码:
ip->i_flag &= ~IRWLOCKED;
if (ip->i_flag & IWANT) {
ip->i_flag &= ~IWANT;
wakeprocs(ip, PRMPT);
}
这里的睡眠代码片段还处理了进程可能被唤醒但另一个进程先获取到锁的情况。在调用 VOP_GETPAGE() 或 VOP_PUTPAGE()
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



