我正在学习关于osdev的知识,并查找xv6代码,尤其是控制台代码。基本上,我不明白控制台是如何启动进程的。
在控制台.c中有一个函数:
void consoleintr(int (*getc)(void)) {
....
while((c = getc()) >= 0) {
switch(c) {
....
default:
....
if(c == '\n' || c == C('D') || input.rightmost == input.r + INPUT_BUF) {
wakeup(&input.r);
}
}
}因此,当行结束(或缓冲区长度超过最大值)时,它启动唤醒(&input.r)
然后,在proc.c中出现了这种情况。
// Wake up all processes sleeping on chan.
// The ptable lock must be held.
static void wakeup1(void *chan)
{
struct proc *p;
for(p = ptable.proc; p < &ptable.proc[NPROC]; p++)
if(p->state == SLEEPING && p->chan == chan)
p->state = RUNNABLE;
}
// Wake up all processes sleeping on chan.
void wakeup(void *chan)
{
acquire(&ptable.lock);
wakeup1(chan);
release(&ptable.lock);
}这里发生了什么事?为什么它要比较控制台缓冲区的地址和proc的chan?这是什么chan?
发布于 2018-04-26 08:01:43
它适用于等待(睡眠)控制台输入的进程。见这里:
235 int
236 consoleread(struct inode *ip, char *dst, int n)
...
251 sleep(&input.r, &cons.lock);您提到的代码唤醒了这个休眠过程,因为数据来自控制台,现在可以进行处理。chan -是一个频道。你可以等待(睡觉)不同的事情。此通道用于控制台输入数据。
https://stackoverflow.com/questions/50009018
复制相似问题