Modify context_switch parameters
This commit is contained in:
parent
b8c77c5758
commit
eb5f73251c
|
@ -52,21 +52,24 @@ void software_irq_dispatch(struct trapframe* tf)
|
||||||
assert(p_intr_driver != NULL);
|
assert(p_intr_driver != NULL);
|
||||||
|
|
||||||
// get current task
|
// get current task
|
||||||
|
struct CPU* cpu = cur_cpu();
|
||||||
struct Thread* cur_task = cur_cpu()->task;
|
struct Thread* cur_task = cur_cpu()->task;
|
||||||
/// @todo: Handle dead task
|
/// @todo: Handle dead task
|
||||||
|
|
||||||
int syscall_num = -1;
|
int syscall_num = -1;
|
||||||
if (cur_task && cur_task->state != DEAD) {
|
if (cur_task && cur_task->state != DEAD) {
|
||||||
cur_task->thread_context.trapframe = tf;
|
cur_task->thread_context.trapframe = tf;
|
||||||
// call syscall
|
// call syscall
|
||||||
|
|
||||||
int ret = arch_syscall(cur_task->thread_context.trapframe, &syscall_num);
|
int ret = arch_syscall(cur_task->thread_context.trapframe, &syscall_num);
|
||||||
arch_set_return(tf, ret);
|
arch_set_return(tf, ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((cur_cpu()->task == NULL && cur_task != NULL) || cur_task->state != RUNNING) {
|
if ((cur_cpu()->task == NULL && cur_task != NULL) || cur_task->state != RUNNING) {
|
||||||
cur_cpu()->task = NULL;
|
cur_cpu()->task = NULL;
|
||||||
|
#ifndef __riscv
|
||||||
context_switch(&cur_task->thread_context.context, cur_cpu()->scheduler);
|
context_switch(&cur_task->thread_context.context, cur_cpu()->scheduler);
|
||||||
|
#else
|
||||||
|
context_switch(&cur_task->thread_context.context, &cpu->scheduler);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
if (syscall_num == SYSCALL_EXIT) {
|
if (syscall_num == SYSCALL_EXIT) {
|
||||||
panic("Exit reaches");
|
panic("Exit reaches");
|
||||||
|
|
Loading…
Reference in New Issue