aboutsummaryrefslogtreecommitdiff
path: root/src/worker.h
diff options
context:
space:
mode:
authorDavid Timber <mieabby@gmail.com>2020-01-01 09:50:34 +1100
committerDavid Timber <mieabby@gmail.com>2020-01-01 09:50:34 +1100
commited809a51fdd1c313cd256301ef6f7211e8394cb1 (patch)
tree81a3054ce0d42976f80c973e2b6ebf9c1b8b7476 /src/worker.h
parent6e456edb2757cf9d28d306afb836aa16780fb912 (diff)
checkpoint
Diffstat (limited to 'src/worker.h')
-rw-r--r--src/worker.h64
1 files changed, 64 insertions, 0 deletions
diff --git a/src/worker.h b/src/worker.h
new file mode 100644
index 0000000..8927fb0
--- /dev/null
+++ b/src/worker.h
@@ -0,0 +1,64 @@
+#pragma once
+#include <stddef.h>
+#include <stdint.h>
+#include <stdbool.h>
+#include <time.h>
+#include <poll.h>
+
+
+typedef uint8_t prne_worker_sched_flag_t;
+
+typedef struct prne_worker_sched_req prne_worker_sched_req_t;
+typedef bool(*prne_worker_sched_req_alloc_func_t)(prne_worker_sched_req_t *, const size_t);
+typedef void(*prne_worker_sched_req_free_func_t)(prne_worker_sched_req_t *);
+typedef struct prne_worker_sched_req_mem_func prne_worker_sched_req_mem_func_t;
+typedef struct prne_worker_sched_info prne_worker_sched_info_t;
+typedef struct prne_worker prne_worker_t;
+
+struct prne_worker_sched_req_mem_func {
+ prne_worker_sched_req_alloc_func_t alloc;
+ prne_worker_sched_req_free_func_t free;
+ void *ctx;
+};
+
+struct prne_worker_sched_req {
+ size_t pollfd_arr_size;
+ struct pollfd *pollfd_arr;
+ struct timespec timeout;
+ prne_worker_sched_req_mem_func_t mem_func;
+ prne_worker_sched_flag_t flags;
+ bool pollfd_ready;
+};
+
+struct prne_worker_sched_info {
+ prne_worker_sched_flag_t tick_flags;
+ struct timespec last_tick;
+ struct timespec this_tick;
+ struct timespec tick_diff;
+ double real_tick_diff;
+};
+
+struct prne_worker {
+ intptr_t id;
+ void *ctx;
+
+ void (*free)(void *ctx);
+ void (*fin)(void *ctx);
+ void (*work)(void *ctx, const prne_worker_sched_info_t *sched_info, prne_worker_sched_req_t *sched_req);
+ bool (*has_finalised)(void *ctx);
+};
+
+/* Do nothing. The worker has more work to do and is yielding cpu time to the
+* other workers.
+*/
+static const prne_worker_sched_flag_t PRNE_WORKER_SCHED_FLAG_NONE = 0x00;
+/* Do `poll()`. The worker has to set `shed_req` properly.
+*/
+static const prne_worker_sched_flag_t PRNE_WORKER_SCHED_FLAG_POLL = 0x01;
+/* Do `poll()` with timeout or just sleep. The worker has to set
+* `prne_worker_sched_req_t::timeout` properly.
+*/
+static const prne_worker_sched_flag_t PRNE_WORKER_SCHED_FLAG_TIMEOUT = 0x02;
+
+
+bool prne_init_worker_sched_req (prne_worker_sched_req_t *wsr, prne_worker_sched_req_mem_func_t *mem_func);