2022-09-20 17:58:04 +00:00
|
|
|
#pragma once
|
2022-10-10 18:21:39 +00:00
|
|
|
#include "fs/FileDescriptor.h"
|
2022-09-20 17:58:04 +00:00
|
|
|
#include "interrupts/Context.h"
|
2022-10-13 19:14:39 +00:00
|
|
|
#include "memory/AddressSpace.h"
|
2022-10-17 16:43:35 +00:00
|
|
|
#include "memory/UserHeap.h"
|
2022-10-07 15:54:05 +00:00
|
|
|
#include "sys/elf/Image.h"
|
2022-09-20 17:58:04 +00:00
|
|
|
|
2022-10-15 12:20:29 +00:00
|
|
|
#define TASK_MAX_FDS 32
|
2022-10-10 18:21:39 +00:00
|
|
|
|
2022-10-27 15:05:42 +00:00
|
|
|
enum class BlockReason
|
|
|
|
{
|
|
|
|
None,
|
|
|
|
Reading,
|
|
|
|
Waiting,
|
|
|
|
};
|
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
struct Task
|
|
|
|
{
|
2022-09-21 19:06:00 +00:00
|
|
|
enum TaskState
|
|
|
|
{
|
|
|
|
Idle,
|
|
|
|
Running,
|
|
|
|
Sleeping,
|
2022-10-18 19:30:52 +00:00
|
|
|
Dying,
|
2022-10-21 19:26:19 +00:00
|
|
|
Blocking,
|
2022-09-21 19:06:00 +00:00
|
|
|
Exited
|
|
|
|
};
|
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
uint64_t id;
|
2022-10-18 15:18:37 +00:00
|
|
|
uint64_t ppid;
|
2022-09-20 17:58:04 +00:00
|
|
|
Context regs;
|
|
|
|
|
|
|
|
int64_t task_sleep = 0;
|
2022-10-08 15:56:40 +00:00
|
|
|
|
|
|
|
int64_t exit_status;
|
|
|
|
|
2022-09-20 17:58:04 +00:00
|
|
|
int64_t task_time = 0;
|
|
|
|
|
|
|
|
Task* next_task = nullptr;
|
2022-09-21 19:06:00 +00:00
|
|
|
Task* prev_task = nullptr;
|
|
|
|
|
|
|
|
uint64_t allocated_stack = 0;
|
|
|
|
|
|
|
|
TaskState state;
|
2022-09-25 15:49:51 +00:00
|
|
|
|
|
|
|
uint64_t cpu_time = 0;
|
2022-10-02 16:53:54 +00:00
|
|
|
|
|
|
|
char floating_region[512] __attribute__((aligned(16)));
|
|
|
|
bool floating_saved = false;
|
|
|
|
|
2022-10-12 15:07:39 +00:00
|
|
|
bool user_task = true;
|
|
|
|
|
2022-10-02 16:53:54 +00:00
|
|
|
bool is_user_task();
|
2022-10-07 15:54:05 +00:00
|
|
|
|
|
|
|
ELFImage* image = nullptr;
|
2022-10-10 18:21:39 +00:00
|
|
|
|
|
|
|
Descriptor files[TASK_MAX_FDS];
|
2022-10-13 19:14:39 +00:00
|
|
|
|
|
|
|
AddressSpace address_space;
|
2022-10-15 08:45:12 +00:00
|
|
|
|
2022-10-17 16:43:35 +00:00
|
|
|
UserHeap allocator;
|
|
|
|
|
2022-10-15 08:45:12 +00:00
|
|
|
int alloc_fd();
|
2022-09-20 17:58:04 +00:00
|
|
|
|
2022-10-17 15:00:07 +00:00
|
|
|
int alloc_fd_greater_than_or_equal(int base_fd);
|
2022-10-02 16:53:54 +00:00
|
|
|
|
2022-10-17 15:00:07 +00:00
|
|
|
void save_context(Context* context);
|
|
|
|
void restore_context(Context* context);
|
|
|
|
|
|
|
|
void save_floating();
|
|
|
|
void restore_floating();
|
2022-10-17 15:07:25 +00:00
|
|
|
|
|
|
|
void switch_to_address_space();
|
|
|
|
|
|
|
|
bool has_died();
|
2022-10-17 17:12:47 +00:00
|
|
|
|
|
|
|
char name[128];
|
2022-10-21 19:26:19 +00:00
|
|
|
|
2022-10-27 15:05:42 +00:00
|
|
|
BlockReason block_reason;
|
|
|
|
|
|
|
|
union {
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
size_t size;
|
|
|
|
int fd;
|
|
|
|
char* buf;
|
|
|
|
} blocking_read_info;
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
int64_t wait_pid;
|
|
|
|
int* wstatus;
|
|
|
|
} blocking_wait_info;
|
|
|
|
};
|
2022-10-21 19:26:19 +00:00
|
|
|
|
2022-10-27 15:05:42 +00:00
|
|
|
void resume();
|
2022-10-21 19:26:19 +00:00
|
|
|
|
|
|
|
bool is_still_blocking();
|
2022-10-25 16:35:17 +00:00
|
|
|
|
|
|
|
Descriptor* descriptor_from_fd(int fd, int& error);
|
2022-10-27 15:05:42 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
void resume_read();
|
|
|
|
void resume_wait();
|
|
|
|
|
|
|
|
bool is_read_still_blocking();
|
|
|
|
bool is_wait_still_blocking();
|
2022-10-17 15:00:07 +00:00
|
|
|
};
|