|
version 1.35, 2026/05/19 15:53:56
|
version 1.35.2.2, 2026/05/20 03:37:12
|
|
Line 57 SUCH DAMAGE.
|
Line 57 SUCH DAMAGE.
|
| #ifdef EVFILT_LIO |
#ifdef EVFILT_LIO |
| #include <aio.h> |
#include <aio.h> |
| #endif |
#endif |
| |
#ifdef ATOMIC_SUPPORT |
| |
#ifndef __cplusplus |
| |
#include <stdatomic.h> |
| |
#else |
| |
#include <atomic> |
| |
#define _Atomic(X) std::atomic<X> |
| |
#endif |
| |
#endif |
| |
|
| |
#ifdef ATOMIC_SUPPORT |
| |
#ifndef E_ATOMIC_ALIGN |
| |
#define E_ATOMIC_ALIGN alignas(sizeof(int) * 8) |
| |
#endif |
| |
#endif |
| |
|
| /* criteria type */ |
/* criteria type */ |
| #define CRITERIA_ANY 0 |
#define CRITERIA_ANY 0 |
|
Line 165 typedef void *(*sched_task_func_t)(sched_task_t * /* c
|
Line 178 typedef void *(*sched_task_func_t)(sched_task_t * /* c
|
| #define SCHED_TASK_DEFINE(x) void *(x)(sched_task_t*) |
#define SCHED_TASK_DEFINE(x) void *(x)(sched_task_t*) |
| |
|
| /* task lock helpers */ |
/* task lock helpers */ |
| #define TASK_LOCK(x) ((x)->task_lock = 42) | #ifdef ATOMIC_SUPPORT |
| #define TASK_UNLOCK(x) ((x)->task_lock ^= (x)->task_lock) | #define TASK_LOCK(x) atomic_store_explicit((atomic_int*) &(x)->task_lock, 42, memory_order_release) |
| #define TASK_ISLOCKED(x) ((x)->task_lock) | #define TASK_UNLOCK(x) atomic_store_explicit((atomic_int*) &(x)->task_lock, 0, memory_order_release) |
| | #define TASK_ISLOCKED(x) atomic_load_explicit((atomic_int*) &(x)->task_lock, memory_order_acquire) |
| | #else |
| | #define TASK_LOCK(x) ((x)->task_lock = 42) |
| | #define TASK_UNLOCK(x) ((x)->task_lock ^= (x)->task_lock) |
| | #define TASK_ISLOCKED(x) ((x)->task_lock) |
| | #endif |
| |
|
| /* task & queue */ |
/* task & queue */ |
| struct sched_Task { |
struct sched_Task { |
|
Line 175 struct sched_Task {
|
Line 194 struct sched_Task {
|
| #define TASK_ID(x) ((struct sched_Task*) (x)->task_id) |
#define TASK_ID(x) ((struct sched_Task*) (x)->task_id) |
| sched_task_type_t task_type; |
sched_task_type_t task_type; |
| #define TASK_TYPE(x) (x)->task_type |
#define TASK_TYPE(x) (x)->task_type |
| |
#ifdef ATOMIC_SUPPORT |
| |
E_ATOMIC_ALIGN int task_lock; |
| |
#else |
| volatile int task_lock; |
volatile int task_lock; |
| |
#endif |
| |
|
| sched_root_task_t *task_root; |
sched_root_task_t *task_root; |
| #define TASK_ROOT(x) (x)->task_root |
#define TASK_ROOT(x) (x)->task_root |