Luna/kernel/src/thread/Task.cpp

85 lines
1.6 KiB
C++
Raw Normal View History

#define MODULE "sched"
#include "thread/Task.h"
#include "log/Log.h"
#include "memory/VMM.h"
#include "std/string.h"
void Task::restore_context(Context* context)
{
memcpy(context, &regs, sizeof(Context));
}
void Task::save_context(Context* context)
{
memcpy(&regs, context, sizeof(Context));
}
void Task::save_floating()
{
floating_saved = true;
asm volatile("fxsave (%0)" : : "r"((char*)floating_region));
}
void Task::restore_floating()
{
if (!floating_saved) return;
asm volatile("fxrstor (%0)" : : "r"((char*)floating_region));
}
bool Task::is_user_task()
{
return user_task;
2022-10-15 08:45:12 +00:00
}
int Task::alloc_fd()
{
int fd;
for (fd = 0; fd < TASK_MAX_FDS; fd++)
{
if (!files[fd].is_open()) break;
}
if (fd == TASK_MAX_FDS) { return -1; }
return fd;
}
int Task::alloc_fd_greater_than_or_equal(int base_fd)
{
int fd;
if (base_fd >= TASK_MAX_FDS) return -1;
for (fd = base_fd; fd < TASK_MAX_FDS; fd++)
{
if (!files[fd].is_open()) break;
}
if (fd == TASK_MAX_FDS) { return -1; }
2022-10-15 08:45:12 +00:00
return fd;
}
void Task::switch_to_address_space()
{
VMM::switch_to_user_address_space(address_space);
VMM::apply_address_space();
}
bool Task::has_died()
{
return state == Exited;
}
void Task::resume_read()
{
VMM::switch_back_to_kernel_address_space();
VMM::apply_address_space();
VMM::switch_to_previous_user_address_space();
regs.rax = files[blocking_read_info.fd].read(blocking_read_info.size, blocking_read_info.buf);
VMM::apply_address_space();
}
bool Task::is_still_blocking()
{
return VFS::would_block(files[blocking_read_info.fd].node());
}