Fixing syscalls to new seterrno and setretval.
[akaros.git] / kern / arch / sparc / process.c
index 7728424..65dc46d 100644 (file)
@@ -21,23 +21,17 @@ proc_init_trapframe(trapframe_t *tf, uint32_t vcoreid,
 
        tf->psr = PSR_S; // but PS = 0
        tf->gpr[14] = stack_top-96;
-       tf->asr13 = vcoreid;
 
        tf->pc = entryp;
        tf->npc = entryp+4;
-}
 
-void proc_secure_trapframe(struct trapframe *tf)
-{
-       tf->psr = PSR_S; // but PS = 0
+       tf->gpr[6] = vcoreid;
 }
 
-/* For cases that we won't return from a syscall via the normal path, and need
- * to set the syscall return value in the registers manually.  Like in a syscall
- * moving to RUNNING_M */
-void proc_set_syscall_retval(trapframe_t *SAFE tf, intreg_t value)
+void proc_secure_trapframe(struct trapframe *tf)
 {
-       tf->gpr[8] = value;
+       // only take the condition codes from the user.  we set S=1, PS=0
+       tf->psr = (tf->psr & PSR_ICC) | PSR_S;
 }
 
 /* Called when we are currently running an address space on our core and want to
@@ -47,6 +41,6 @@ void proc_set_syscall_retval(trapframe_t *SAFE tf, intreg_t value)
 void __abandon_core(void)
 {
        lcr3(boot_cr3);
-       proc_decref(current, 1);
+       kref_put(&current->kref);
        set_current_proc(NULL);
 }