2023-06-20 14:10:28 -07:00
|
|
|
#include "syscall/thread.h"
|
|
|
|
|
2023-06-20 15:50:49 -07:00
|
|
|
#include "capability/capability.h"
|
2023-06-26 15:01:55 -07:00
|
|
|
#include "debug/debug.h"
|
2023-06-20 14:10:28 -07:00
|
|
|
#include "scheduler/scheduler.h"
|
|
|
|
|
2023-06-22 02:17:50 -07:00
|
|
|
glcr::ErrorCode ThreadCreate(ZThreadCreateReq* req) {
|
2023-06-20 14:10:28 -07:00
|
|
|
auto& curr_proc = gScheduler->CurrentProcess();
|
|
|
|
auto cap = curr_proc.GetCapability(req->proc_cap);
|
2023-08-01 18:22:41 -07:00
|
|
|
RET_ERR(ValidateCapability<Process>(cap, kZionPerm_SpawnThread));
|
2023-06-20 14:10:28 -07:00
|
|
|
|
|
|
|
auto parent_proc = cap->obj<Process>();
|
|
|
|
auto thread = parent_proc->CreateThread();
|
2023-08-01 18:22:41 -07:00
|
|
|
*req->thread_cap = curr_proc.AddNewCapability(thread);
|
2023-06-21 18:28:54 -07:00
|
|
|
return glcr::OK;
|
2023-06-20 14:10:28 -07:00
|
|
|
}
|
|
|
|
|
2023-06-22 02:17:50 -07:00
|
|
|
glcr::ErrorCode ThreadStart(ZThreadStartReq* req) {
|
2023-06-20 14:10:28 -07:00
|
|
|
auto& curr_proc = gScheduler->CurrentProcess();
|
|
|
|
auto cap = curr_proc.GetCapability(req->thread_cap);
|
2023-08-01 18:22:41 -07:00
|
|
|
RET_ERR(ValidateCapability<Thread>(cap, kZionPerm_Write));
|
2023-06-20 14:10:28 -07:00
|
|
|
|
|
|
|
auto thread = cap->obj<Thread>();
|
|
|
|
// FIXME: validate entry point is in user space.
|
|
|
|
thread->Start(req->entry, req->arg1, req->arg2);
|
2023-06-21 18:28:54 -07:00
|
|
|
return glcr::OK;
|
2023-06-20 14:10:28 -07:00
|
|
|
}
|
|
|
|
|
2023-06-22 02:17:50 -07:00
|
|
|
glcr::ErrorCode ThreadExit(ZThreadExitReq*) {
|
2023-06-20 14:10:28 -07:00
|
|
|
auto curr_thread = gScheduler->CurrentThread();
|
|
|
|
curr_thread->Exit();
|
|
|
|
panic("Returned from thread exit");
|
2023-06-26 15:01:55 -07:00
|
|
|
UNREACHABLE
|
2023-06-20 14:10:28 -07:00
|
|
|
}
|
2023-06-22 02:17:50 -07:00
|
|
|
|
|
|
|
glcr::ErrorCode ThreadWait(ZThreadWaitReq* req) {
|
|
|
|
auto& curr_proc = gScheduler->CurrentProcess();
|
|
|
|
auto cap = curr_proc.GetCapability(req->thread_cap);
|
2023-08-01 18:22:41 -07:00
|
|
|
RET_ERR(ValidateCapability<Thread>(cap, kZionPerm_Read));
|
2023-06-22 02:17:50 -07:00
|
|
|
auto thread = cap->obj<Thread>();
|
|
|
|
thread->Wait();
|
|
|
|
return glcr::OK;
|
|
|
|
}
|