Linux0.11内核中的wait_on_buffer和wait_on_inode函数是非常有代表性的延迟性函数处理过程,网上关于这两个函数的讨论
也很多,最主要的一个问题是为什么要在判断b_lock之前关中断,这个问题也困扰了我很长时间,查了不少帖子,学到不少东西,但总是
觉得有些细节没有弄清楚,因此借着自己实践开发一个小OS的过程,研究了一下wait_on_buffer,还是学到不少东西的。贴出来,分享
给大家,欢迎讨论~
Linux0.11版函数定义:
static inline void wait_on_buffer(struct buffer_head * bh)
{
cli();
while (bh->b_lock)
sleep_on(&bh->b_wait);
sti();
}
分析如下:
1. 首先可以明确,wait_on_buffer是工作在内核态的函数。更进一步应当理解为两种可能性:
或者是当前某个用户态的进程请求数据进而引发的,那么可以认为是当前进程进入了内核态;又或者是内核本身的某个任务
引发的操作。不管怎样wait_on_buffer背后是代表这某个进程或者任务的。
2. wait_on_buffer中通过cli和sti起到一个保护临界区的作用,为什么这么说?
原因首先还在于wait_on_buffer是工作在内核态的环境下,此时cli就意味着关闭了所有的可屏蔽中断,如时钟中断和硬盘</