WIP on kernel syscalls

This commit is contained in:
2021-05-01 17:09:50 -05:00
parent 7caf49065d
commit c962a83ff0
14 changed files with 142 additions and 31 deletions

View File

@@ -3,6 +3,7 @@
#include "stdio.h"
#include "elf.h"
#include "context.h"
#include "string.h"
#include "types/status.h"
syscall_t syscall_table[32];
@@ -79,13 +80,14 @@ int load_module(struct kernel_t *kernel, struct module_t *module)
}
kernel->resource_table->array[index].type = RESOURCE_PROCESS;
kernel->resource_table->array[index].process.priority = 1;
kernel->resource_table->array[index].process.resource_id = index;
kernel->resource_table->array[index].process.state = module_context;
kernel->resource_table->array[index].process.page_table = current_address_space();
queue_insert(kernel->priority_queue, &kernel->resource_table->array[index].process);
return S_OK;
}
struct process_state_t *next_process(struct kernel_t *kernel, struct process_state_t *prev_state)
struct process_context_t *next_process(struct kernel_t *kernel, struct process_context_t *prev_state)
{
if(prev_state != NULL)
{
@@ -102,6 +104,79 @@ struct process_state_t *next_process(struct kernel_t *kernel, struct process_sta
panic("no processes available to enter!");
}
int terminate_process(struct kernel_t *kernel, size_t process_id)
{
if(kernel == NULL)
{
return S_NULL_POINTER;
}
else if(kernel->resource_table->limit >= process_id)
{
return S_OUT_OF_BOUNDS;
}
else if(kernel->resource_table->array[process_id].type != RESOURCE_PROCESS)
{
return S_INVALID_ARGUMENT;
}
struct process_t *process = &kernel->resource_table->array[process_id].process;
kernel->resource_table->array[process_id].type = RESOURCE_UNAVAILABLE;
if(kernel->active_process == process)
{
kernel->active_process = NULL;
}
queue_remove(kernel->priority_queue, process);
return S_OK;
}
int accept_message(struct kernel_t *kernel, size_t process_id, struct message_t *message)
{
if(kernel == NULL || message == NULL)
{
return S_NULL_POINTER;
}
else if(kernel->resource_table->limit >= process_id)
{
return S_OUT_OF_BOUNDS;
}
else if(kernel->resource_table->array[process_id].type != RESOURCE_PROCESS)
{
return S_INVALID_ARGUMENT;
}
struct process_t *process = &kernel->resource_table->array[process_id].process;
process->state = PROCESS_WAITING;
process->message = message;
if(kernel->active_process == process)
{
kernel->active_process = NULL;
}
queue_remove(kernel->priority_queue, process);
return S_OK;
}
int send_message(struct kernel_t *kernel, size_t process_id, const struct message_t *message)
{
if(kernel == NULL || message == NULL)
{
return S_NULL_POINTER;
}
else if(kernel->resource_table->limit >= process_id)
{
return S_OUT_OF_BOUNDS;
}
else if(kernel->resource_table->array[process_id].type != RESOURCE_PROCESS)
{
return S_INVALID_ARGUMENT;
}
struct process_t *process = &kernel->resource_table->array[process_id].process;
if(process->state != PROCESS_WAITING || process->message == NULL)
{
return S_BUSY;
}
queue_insert(kernel->priority_queue, kernel->active_process);
struct message_t buffer = *message;
}
void panic(const char *message)
{
printf("panic: %s", message);

View File

@@ -81,3 +81,8 @@ size_t munmap(struct kernel_t *kernel, size_t location, size_t length, size_t ar
}
return status;
}
size_t terminate_self(struct kernel_t *kernel, size_t arg1, size_t arg2, size_t arg3)
{
return terminate_process(kernel, kernel->active_process->resource_id);
}

View File

@@ -14,7 +14,7 @@ void *initialize_context(void *task_entry, struct page_stack_t *page_stack)
"mov (%%esp), %0; "
"popf; "
: "=r"(flags));
struct process_state_t *state = (struct process_state_t*)PCB_LOCATION;
struct process_context_t *state = (struct process_context_t*)PCB_LOCATION;
memset(NULL, 0, page_size);
state->cs = 0x1B;
state->eip = (uint32_t)task_entry;