Skip to content
Snippets Groups Projects
syscall.c 1.59 KiB
Newer Older
rtm's avatar
rtm committed
#include "types.h"
#include "param.h"
#include "mmu.h"
#include "proc.h"
#include "defs.h"
#include "x86.h"
#include "traps.h"
#include "syscall.h"

/*
 * User code makes a system call with INT T_SYSCALL.
 * System call number in %eax.
 * Arguments on the stack.
 *
 * Return value? Error indication? Errno?
 */

void
sys_fork()
{
  newproc();
}

void
sys_exit()
{
rtm's avatar
rtm committed
  struct proc *p;
rtm's avatar
rtm committed
  struct proc *cp = curproc[cpu()];
rtm's avatar
rtm committed

rtm's avatar
rtm committed
  cp->state = ZOMBIE;
rtm's avatar
rtm committed

  // wake up parent
  for(p = proc; p < &proc[NPROC]; p++)
rtm's avatar
rtm committed
    if(p->pid == cp->ppid)
rtm's avatar
rtm committed
      wakeup(p);

  // abandon children
  for(p = proc; p < &proc[NPROC]; p++)
rtm's avatar
rtm committed
    if(p->ppid == cp->pid)
rtm's avatar
rtm committed
      p->pid = 1;

rtm's avatar
rtm committed
  swtch();
}

rtm's avatar
rtm committed
void
sys_wait()
{
  struct proc *p;
rtm's avatar
rtm committed
  struct proc *cp = curproc[cpu()];
rtm's avatar
rtm committed
  int any;

rtm's avatar
rtm committed
  cprintf("waid pid %d ppid %d\n", cp->pid, cp->ppid);
rtm's avatar
rtm committed

  while(1){
    any = 0;
    for(p = proc; p < &proc[NPROC]; p++){
rtm's avatar
rtm committed
      if(p->state == ZOMBIE && p->ppid == cp->pid){
rtm's avatar
rtm committed
        kfree(p->mem, p->sz);
        kfree(p->kstack, KSTACKSIZE);
        p->state = UNUSED;
rtm's avatar
rtm committed
        cprintf("%x collected %x\n", cp, p);
rtm's avatar
rtm committed
        return;
      }
rtm's avatar
rtm committed
      if(p->state != UNUSED && p->ppid == cp->pid)
rtm's avatar
rtm committed
        any = 1;
    }
    if(any == 0){
rtm's avatar
rtm committed
      cprintf("%x nothing to wait for\n", cp);
rtm's avatar
rtm committed
      return;
    }
rtm's avatar
rtm committed
    sleep(cp);
rtm's avatar
rtm committed
  }
}

rtm's avatar
rtm committed
void
syscall()
{
rtm's avatar
rtm committed
  struct proc *cp = curproc[cpu()];
  int num = cp->tf->tf_regs.reg_eax;
rtm's avatar
rtm committed
  cprintf("%x sys %d\n", cp, num);
rtm's avatar
rtm committed
  switch(num){
  case SYS_fork:
    sys_fork();
    break;
  case SYS_exit:
    sys_exit();
    break;
rtm's avatar
rtm committed
  case SYS_wait:
    sys_wait();
    break;
rtm's avatar
rtm committed
  default:
    cprintf("unknown sys call %d\n", num);
    // XXX fault
    break;
  }
}