2006-09-06 20:19:11 +02:00
|
|
|
#include "types.h"
|
|
|
|
#include "stat.h"
|
|
|
|
#include "param.h"
|
|
|
|
#include "mmu.h"
|
|
|
|
#include "proc.h"
|
|
|
|
#include "defs.h"
|
|
|
|
#include "x86.h"
|
|
|
|
#include "traps.h"
|
|
|
|
#include "syscall.h"
|
|
|
|
#include "spinlock.h"
|
|
|
|
#include "buf.h"
|
|
|
|
#include "fs.h"
|
|
|
|
#include "fsvar.h"
|
|
|
|
#include "elf.h"
|
2006-09-06 20:40:28 +02:00
|
|
|
#include "file.h"
|
2006-09-06 20:19:11 +02:00
|
|
|
#include "fcntl.h"
|
|
|
|
|
|
|
|
int
|
|
|
|
sys_fork(void)
|
|
|
|
{
|
|
|
|
struct proc *np;
|
|
|
|
|
2007-08-10 18:37:27 +02:00
|
|
|
if((np = copyproc(cp)) == 0)
|
2006-09-06 20:19:11 +02:00
|
|
|
return -1;
|
|
|
|
np->state = RUNNABLE;
|
|
|
|
return np->pid;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
sys_exit(void)
|
|
|
|
{
|
|
|
|
proc_exit();
|
|
|
|
return 0; // not reached
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
sys_wait(void)
|
|
|
|
{
|
|
|
|
return proc_wait();
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
sys_kill(void)
|
|
|
|
{
|
|
|
|
int pid;
|
|
|
|
|
2006-09-07 16:13:26 +02:00
|
|
|
if(argint(0, &pid) < 0)
|
2006-09-06 20:19:11 +02:00
|
|
|
return -1;
|
|
|
|
return proc_kill(pid);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
sys_getpid(void)
|
|
|
|
{
|
2007-08-10 18:37:27 +02:00
|
|
|
return cp->pid;
|
2006-09-06 20:19:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
sys_sbrk(void)
|
|
|
|
{
|
2006-09-07 16:13:26 +02:00
|
|
|
int addr;
|
2006-09-06 20:19:11 +02:00
|
|
|
int n;
|
|
|
|
|
2006-09-07 16:13:26 +02:00
|
|
|
if(argint(0, &n) < 0)
|
2006-09-06 20:19:11 +02:00
|
|
|
return -1;
|
2006-09-07 16:13:26 +02:00
|
|
|
if((addr = growproc(n)) < 0)
|
2006-09-06 20:19:11 +02:00
|
|
|
return -1;
|
|
|
|
setupsegs(cp);
|
|
|
|
return addr;
|
|
|
|
}
|
2007-08-24 22:04:53 +02:00
|
|
|
|
|
|
|
int
|
|
|
|
sys_yield(void)
|
|
|
|
{
|
|
|
|
yield();
|
|
|
|
return 0;
|
|
|
|
}
|