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()