xv6-riscv-kernel/kernel/sysproc.c

92 lines
1.1 KiB
C
Raw Normal View History

#include "types.h"
2019-05-31 15:45:59 +02:00
#include "riscv.h"
2007-08-28 01:26:33 +02:00
#include "defs.h"
#include "param.h"
#include "memlayout.h"
#include "spinlock.h"
#include "proc.h"
2024-05-24 11:26:40 +02:00
u64
2019-05-31 15:45:59 +02:00
sys_exit(void)
{
int n;
argint(0, &n);
exit(n);
2024-06-15 16:55:06 +02:00
return 0; // not reached
}
2024-05-24 11:26:40 +02:00
u64
2019-05-31 15:45:59 +02:00
sys_getpid(void)
{
2019-05-31 15:45:59 +02:00
return myproc()->pid;
}
2024-05-24 11:26:40 +02:00
u64
2019-05-31 15:45:59 +02:00
sys_fork(void)
{
return fork();
}
2024-05-24 11:26:40 +02:00
u64
sys_wait(void)
{
2024-05-24 11:26:40 +02:00
u64 p;
argaddr(0, &p);
return wait(p);
}
2024-05-24 11:26:40 +02:00
u64
sys_sbrk(void)
{
2024-05-24 11:26:40 +02:00
u64 addr;
int n;
argint(0, &n);
addr = myproc()->sz;
2009-05-31 02:31:20 +02:00
if(growproc(n) < 0)
return -1;
return addr;
}
2024-05-24 11:26:40 +02:00
u64
2007-08-27 15:34:35 +02:00
sys_sleep(void)
{
int n;
2024-05-24 11:26:40 +02:00
u32 ticks0;
argint(0, &n);
2007-08-27 15:34:35 +02:00
acquire(&tickslock);
ticks0 = ticks;
2024-06-15 16:55:06 +02:00
while(ticks - ticks0 < n) {
if(killed(myproc())) {
2007-08-27 15:34:35 +02:00
release(&tickslock);
return -1;
}
sleep(&ticks, &tickslock);
}
release(&tickslock);
return 0;
}
2024-05-24 11:26:40 +02:00
u64
2019-06-04 17:31:50 +02:00
sys_kill(void)
{
int pid;
argint(0, &pid);
2019-06-04 17:31:50 +02:00
return kill(pid);
}
// return how many clock tick interrupts have occurred
2011-08-16 02:11:13 +02:00
// since start.
2024-05-24 11:26:40 +02:00
u64
sys_uptime(void)
{
2024-05-24 11:26:40 +02:00
u32 xticks;
acquire(&tickslock);
xticks = ticks;
release(&tickslock);
return xticks;
}