mirror of
https://github.com/Ed94/raddebugger.git
synced 2026-06-13 07:32:23 -07:00
141 lines
3.1 KiB
C
141 lines
3.1 KiB
C
// Copyright (c) 2024 Epic Games Tools
|
|
// Licensed under the MIT license (https://opensource.org/license/mit/)
|
|
|
|
#ifndef TASK_SYSTEM_H
|
|
#define TASK_SYSTEM_H
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Task "Ticket" Type
|
|
//
|
|
// "Tickets" are opaque handles, used to refer to submitted tasks.
|
|
//
|
|
|
|
typedef struct TS_Ticket TS_Ticket;
|
|
struct TS_Ticket
|
|
{
|
|
U64 u64[2];
|
|
};
|
|
|
|
typedef struct TS_TicketNode TS_TicketNode;
|
|
struct TS_TicketNode
|
|
{
|
|
TS_TicketNode *next;
|
|
TS_Ticket v;
|
|
};
|
|
|
|
typedef struct TS_TicketList TS_TicketList;
|
|
struct TS_TicketList
|
|
{
|
|
TS_TicketNode *first;
|
|
TS_TicketNode *last;
|
|
U64 count;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Task Request Types
|
|
|
|
#define TS_TASK_FUNCTION_DEF(name) void *name(Arena *arena, U64 thread_idx, void *p)
|
|
typedef TS_TASK_FUNCTION_DEF(TS_TaskFunctionType);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Task Artifact Cache Types
|
|
|
|
typedef struct TS_TaskArtifact TS_TaskArtifact;
|
|
struct TS_TaskArtifact
|
|
{
|
|
TS_TaskArtifact *next;
|
|
U64 num;
|
|
B64 task_is_done;
|
|
void *result;
|
|
};
|
|
|
|
typedef struct TS_TaskArtifactSlot TS_TaskArtifactSlot;
|
|
struct TS_TaskArtifactSlot
|
|
{
|
|
TS_TaskArtifact *first;
|
|
TS_TaskArtifact *last;
|
|
};
|
|
|
|
typedef struct TS_TaskArtifactStripe TS_TaskArtifactStripe;
|
|
struct TS_TaskArtifactStripe
|
|
{
|
|
Arena *arena;
|
|
OS_Handle cv;
|
|
OS_Handle rw_mutex;
|
|
TS_TaskArtifact *free_artifact;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Per-Thread State
|
|
|
|
typedef struct TS_TaskThread TS_TaskThread;
|
|
struct TS_TaskThread
|
|
{
|
|
Arena *arena;
|
|
OS_Handle thread;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Main Shared State
|
|
|
|
typedef struct TS_Shared TS_Shared;
|
|
struct TS_Shared
|
|
{
|
|
Arena *arena;
|
|
|
|
// rjf: task artifact cache
|
|
U64 artifact_num_gen;
|
|
U64 artifact_slots_count;
|
|
U64 artifact_stripes_count;
|
|
TS_TaskArtifactSlot *artifact_slots;
|
|
TS_TaskArtifactStripe *artifact_stripes;
|
|
|
|
// rjf: task ring buffer
|
|
U64 u2t_ring_size;
|
|
U8 *u2t_ring_base;
|
|
U64 u2t_ring_write_pos;
|
|
U64 u2t_ring_read_pos;
|
|
OS_Handle u2t_ring_mutex;
|
|
OS_Handle u2t_ring_cv;
|
|
|
|
// rjf: task threads
|
|
TS_TaskThread *task_threads;
|
|
U64 task_threads_count;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Globals
|
|
|
|
global TS_Shared *ts_shared = 0;
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Basic Type Functions
|
|
|
|
internal TS_Ticket ts_ticket_zero(void);
|
|
internal void ts_ticket_list_push(Arena *arena, TS_TicketList *list, TS_Ticket ticket);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Top-Level Layer Initialization
|
|
|
|
internal void ts_init(void);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Top-Level Accessors
|
|
|
|
internal U64 ts_thread_count(void);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: High-Level Task Kickoff / Joining
|
|
|
|
internal TS_Ticket ts_kickoff(TS_TaskFunctionType *entry_point, Arena **optional_arena_ptr, void *p);
|
|
internal void *ts_join(TS_Ticket ticket, U64 endt_us);
|
|
#define ts_join_struct(ticket, endt_us, type) (type *)ts_join((ticket), (endt_us))
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Task Threads
|
|
|
|
internal void ts_u2t_dequeue_task(TS_TaskFunctionType **entry_point_out, Arena **arena_out, void **p_out, TS_Ticket *ticket_out);
|
|
internal void ts_task_thread__entry_point(void *p);
|
|
|
|
#endif // TASK_SYSTEM_H
|