Removed set_current_proc()
[akaros.git] / kern / arch / sparc / process.c
index 0fd5656..e7ccceb 100644 (file)
@@ -1,7 +1,7 @@
 #include <arch/arch.h>
 #include <arch/trap.h>
-#include <arch/frontend.h>
 #include <process.h>
+#include <frontend.h>
 #include <pmap.h>
 #include <smp.h>
 
 #pragma nosharc
 #endif
 
-// architecture-specific process initialization code
 void
-proc_init_arch(struct proc *SAFE p)
+proc_init_trapframe(trapframe_t *tf, uint32_t vcoreid,
+                    uint32_t entryp, uint32_t stack_top)
 {
-       pid_t parent_id = p->ppid, id = p->pid;
-       int32_t errno;
-       if(frontend_syscall(parent_id,RAMP_SYSCALL_proc_init,id,0,0,0,&errno))
-               panic("Front-end server couldn't initialize new process!");
-}
-
-// architecture-specific process termination code
-void
-proc_free_arch(struct proc *SAFE p)
-{
-       int32_t errno;
-       if(frontend_syscall(0,RAMP_SYSCALL_proc_free,p->pid,0,0,0,&errno))
-               panic("Front-end server couldn't free process!");
-}
-
-void
-proc_set_program_counter(trapframe_t *tf, uintptr_t pc)
-{
-       tf->pc = pc;
-       tf->npc = pc+4;
-}
-
-void
-proc_init_trapframe(trapframe_t *tf, uint32_t vcoreid)
-{
-       extern char trap_table;
-
        memset(tf,0,sizeof(*tf));
-       tf->gpr[14] = USTACKTOP-96;
+
        tf->psr = PSR_S; // but PS = 0
+       tf->gpr[14] = stack_top-96;
 
-       // unused
-       //tf->wim = 0;
-       //tf->tbr = (uint32_t)&trap_table;
+       tf->pc = entryp;
+       tf->npc = entryp+4;
 
-       proc_set_tfcoreid(tf,vcoreid);
+       tf->gpr[6] = vcoreid;
 }
 
-void proc_set_tfcoreid(trapframe_t *tf, uint32_t id)
+void proc_secure_trapframe(struct trapframe *tf)
 {
-       tf->gpr[6] = id;
+       // only take the condition codes from the user.  we set S=1, PS=0
+       tf->psr = (tf->psr & PSR_ICC) | PSR_S;
 }
 
-/* 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)
+/* Called when we are currently running an address space on our core and want to
+ * abandon it.  We need a known good pgdir before releasing the old one.  We
+ * decref, since current no longer tracks the proc (and current no longer
+ * protects the cr3). */
+void __abandon_core(void)
 {
-       tf->gpr[8] = value;
+       struct per_cpu_info *pcpui = &per_cpu_info[core_id()];
+       lcr3(boot_cr3);
+       kref_put(&pcpui->cur_proc->kref);
+       pcpui->cur_proc = 0;
 }