Fixed 2 more fork issues

Added setting of spsr for the new task.
Added newly created task into mm0's global task list.
This commit is contained in:
Bahadir Balban
2008-08-27 22:27:53 +03:00
parent dad1d2d792
commit 4ffdb45550
7 changed files with 34 additions and 7 deletions

View File

@@ -17,6 +17,16 @@
#include INC_API(syscall.h)
#include INC_ARCH(exception.h)
void print_syscall_context(struct ktcb *t)
{
syscall_context_t *r = t->syscall_regs;
printk("Thread id: %d registers: 0x%x, 0x%x, 0x%x, 0x%x, "
"0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x\n",
t->tid, r->spsr, r->r0, r->r1, r->r2, r->r3, r->r4,
r->r5, r->r6, r->r7, r->r8, r->sp_usr, r->lr_usr);
}
int sys_exchange_registers(syscall_context_t *regs)
{
struct ktcb *task;

View File

@@ -6,6 +6,7 @@
#include <l4/generic/scheduler.h>
#include INC_API(syscall.h)
#include <l4/api/thread.h>
#include <l4/api/syscall.h>
#include <l4/api/errno.h>
#include <l4/generic/tcb.h>
#include <l4/lib/idpool.h>
@@ -61,6 +62,7 @@ int thread_start(struct task_ids *ids)
return -EINVAL;
}
extern unsigned int return_from_syscall;
/*
@@ -107,12 +109,14 @@ int arch_setup_new_thread(struct ktcb *new, struct ktcb *orig)
new->syscall_regs->r0 = 0;
/*
* Set up the stack pointer and program counter so that next time
* the new thread schedules, it executes the end part of the system
* call exception where the previous context is restored.
* Set up the stack pointer, saved program status register and program
* counter so that next time the new thread schedules, it executes the
* end part of the system call exception where the previous context is
* restored.
*/
new->context.sp = (unsigned long)new + syscall_context_offset;
new->context.pc = (unsigned long)return_from_syscall;
new->context.sp = (unsigned long)new->syscall_regs;
new->context.pc = (unsigned long)&return_from_syscall;
new->context.spsr = (unsigned long)orig->context.spsr;
/* Copy other relevant fields from original ktcb */
new->pagerid = orig->pagerid;