xv6-riscv-kernel/sysproc.c

86 lines
1 KiB
C
Raw Normal View History

#include "types.h"
2009-05-31 02:31:20 +02:00
#include "x86.h"
2007-08-28 01:26:33 +02:00
#include "defs.h"
#include "param.h"
#include "mmu.h"
#include "proc.h"
int
sys_fork(void)
{
2007-11-28 21:47:22 +01:00
int pid;
struct proc *np;
2007-08-10 18:37:27 +02:00
if((np = copyproc(cp)) == 0)
return -1;
2007-11-28 21:47:22 +01:00
pid = np->pid;
2009-05-31 02:31:20 +02:00
// Clear %eax so that fork returns 0 in the child.
np->tf->eax = 0;
np->state = RUNNABLE;
2007-11-28 21:47:22 +01:00
return pid;
}
int
sys_exit(void)
{
exit();
return 0; // not reached
}
int
sys_wait(void)
{
return wait();
}
int
sys_kill(void)
{
int pid;
2006-09-07 16:13:26 +02:00
if(argint(0, &pid) < 0)
return -1;
return kill(pid);
}
int
sys_getpid(void)
{
2007-08-10 18:37:27 +02:00
return cp->pid;
}
int
sys_sbrk(void)
{
2006-09-07 16:13:26 +02:00
int addr;
int n;
2006-09-07 16:13:26 +02:00
if(argint(0, &n) < 0)
return -1;
2009-05-31 02:31:20 +02:00
addr = cp->sz;
if(growproc(n) < 0)
return -1;
return addr;
}
int
2007-08-27 15:34:35 +02:00
sys_sleep(void)
{
2007-08-27 15:34:35 +02:00
int n, ticks0;
if(argint(0, &n) < 0)
return -1;
acquire(&tickslock);
ticks0 = ticks;
while(ticks - ticks0 < n){
if(cp->killed){
release(&tickslock);
return -1;
}
sleep(&ticks, &tickslock);
}
release(&tickslock);
return 0;
}