为什么fork的返回值不为0?
我知道子进程制作成功,那么fork返回值为0
但是我尝试过如果返回值(pid) == 0
然后是printf
代码。不幸的是无法打印。
fork(void)
{
int i, pid;
struct proc *np;
struct proc *curproc = myproc();
// Allocate process.
if((np = allocproc()) == 0){
return -1;
}
// Copy process state from proc.
if((np->pgdir = copyuvm(curproc->pgdir, curproc->sz)) == 0){
kfree(np->kstack);
np->kstack = 0;
np->state = UNUSED;
return -1;
}
np->sz = curproc->sz;
np->parent = curproc;
*np->tf = *curproc->tf;
// Clear %eax so that fork returns 0 in the child.
np->tf->eax = 0;
for(i = 0; i < NOFILE; i++)
if(curproc->ofile[i])
np->ofile[i] = filedup(curproc->ofile[i]);
np->cwd = idup(curproc->cwd);
safestrcpy(np->name, curproc->name, sizeof(curproc->name));
pid = np->pid;
acquire(&ptable.lock);
np->state = RUNNABLE;
release(&ptable.lock);
if(pid ==0)
cprintf("child process made%d",pid); // why not print zero ..
else
cprintf("pid value is %d",pid);
return pid;
}
子程序成功执行,即fork()的返回值为0! (我在关于fork()的其他主要代码中进行了测试,例如ex)通过了google代码(foo.c)
但在fork()中未检测到pid为0。 构造子进程时fork()的返回值在哪里?
答案 0 :(得分:0)
系统调用由调用它们的进程上下文执行。这意味着调用它们的进程将收到系统调用函数的返回值。 fork实现与所有其他系统调用具有相同的行为,但有一点特殊,因为尽管只有父进程实际调用了它,但据说有2个进程从中返回。
正在构建子进程的堆栈以模拟先前进行的系统调用,并将其模拟的返回值连同存储在trapframe的eax寄存器(用于保存函数的返回值)中一起使用。
当调度程序选择子进程运行时,运行的第一行代码将是forkret函数和trapret,因为模拟栈是由allocproc函数准备的。