BarryServer : Git

All the code for all my projects
// BarryServer : Git / Nucleus / blob / 120a213e731827cb653242e5dc4b39229a539cb9 / include / nucleus / task.h

// Related

Nucleus

Barry Signals and small task functions 9d6eb50 (3 years, 2 months ago)
#ifndef _NUCLEUS_TASK_H
#define _NUCLEUS_TASK_H

#include <stdint.h>
#include <sys/types.h>
#include <nucleus/cpu.h>
#include <nucleus/object.h>
#include <nucleus/memory.h>
#include <nucleus/vfs.h>

typedef struct Task Task;
typedef struct Signals Signals;

/* Task priorities */
enum Priority {
	NONE,
	LOWEST,
	LOW,
	NORMAL,
	HIGH,
	HIGHEST,
};

/* Task states */
enum State {
	RUNNING,
	READY,
	TERMINATED,
	WAITING,
};

/* Structure for a Task */
struct Task {
	Object obj;
	pid_t tid, tgid;
	uid_t uid, euid, suid;
	gid_t gid, egid, sgid;
	int status;
	enum Priority priority;
	enum State state;
	uint32_t inCriticalSection;
	uint8_t inSyscall;

	uintptr_t esi, edi, ebx;
	uintptr_t esp, ebp, eip;
	page_dir_t pageDir;

	File *executable;
	VMRegion *stack;
	Task *target;
	ObjectList *wait;

	/* Namespaces */
	FileSystem *fs;
	Files *files;
	VirtualMemory *vm;
	Signals *signals;
};

extern ObjectType taskType;
extern ObjectType signalsType;

extern Task *currentTask[];
#define current currentTask[CPUID]

/* Check if super-user */
static inline int
super_user(void)
{
	return (current->euid == 0);
}

/* Enter a critical section */
static inline void
enter_critical_section(void)
{
	__atomic_add_fetch(&current->inCriticalSection, 1, __ATOMIC_RELAXED);
}
/* Exit a critical section */
static inline void
exit_critical_section(void)
{
	__atomic_sub_fetch(&current->inCriticalSection, 1, __ATOMIC_RELAXED);
}

void init_tasking(void);
void block_task(enum State reason, ObjectList *list);
Task *find_task(pid_t tid);
void schedule(void);
pid_t clone(int flags);
int syscall_handler(int num, uintptr_t args);

#endif