123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- //+build freebsd
- package unix
- import "core:c"
- pthread_t :: distinct u64
- // pthread_t :: struct #align(16) { x: u64 }
- PTHREAD_COND_T_SIZE :: 8
- PTHREAD_MUTEXATTR_T_SIZE :: 8
- PTHREAD_CONDATTR_T_SIZE :: 8
- PTHREAD_RWLOCKATTR_T_SIZE :: 8
- PTHREAD_BARRIERATTR_T_SIZE :: 8
- // WARNING: The sizes of these things are different yet again
- // on non-X86!
- when size_of(int) == 8 {
- PTHREAD_ATTR_T_SIZE :: 8
- PTHREAD_MUTEX_T_SIZE :: 8
- PTHREAD_RWLOCK_T_SIZE :: 8
- PTHREAD_BARRIER_T_SIZE :: 8
- } else when size_of(int) == 4 { // TODO
- PTHREAD_ATTR_T_SIZE :: 32
- PTHREAD_MUTEX_T_SIZE :: 32
- PTHREAD_RWLOCK_T_SIZE :: 44
- PTHREAD_BARRIER_T_SIZE :: 20
- }
- pthread_cond_t :: struct #align(16) {
- _: [PTHREAD_COND_T_SIZE] c.char,
- }
- pthread_mutex_t :: struct #align(16) {
- _: [PTHREAD_MUTEX_T_SIZE] c.char,
- }
- pthread_rwlock_t :: struct #align(16) {
- _: [PTHREAD_RWLOCK_T_SIZE] c.char,
- }
- pthread_barrier_t :: struct #align(16) {
- _: [PTHREAD_BARRIER_T_SIZE] c.char,
- }
- pthread_attr_t :: struct #align(16) {
- _: [PTHREAD_ATTR_T_SIZE] c.char,
- }
- pthread_condattr_t :: struct #align(16) {
- _: [PTHREAD_CONDATTR_T_SIZE] c.char,
- }
- pthread_mutexattr_t :: struct #align(16) {
- _: [PTHREAD_MUTEXATTR_T_SIZE] c.char,
- }
- pthread_rwlockattr_t :: struct #align(16) {
- _: [PTHREAD_RWLOCKATTR_T_SIZE] c.char,
- }
- pthread_barrierattr_t :: struct #align(16) {
- _: [PTHREAD_BARRIERATTR_T_SIZE] c.char,
- }
- PTHREAD_MUTEX_ERRORCHECK :: 1
- PTHREAD_MUTEX_RECURSIVE :: 2
- PTHREAD_MUTEX_NORMAL :: 3
- PTHREAD_CREATE_JOINABLE :: 0
- PTHREAD_CREATE_DETACHED :: 1
- PTHREAD_INHERIT_SCHED :: 4
- PTHREAD_EXPLICIT_SCHED :: 0
- PTHREAD_PROCESS_PRIVATE :: 0
- PTHREAD_PROCESS_SHARED :: 1
- SCHED_FIFO :: 1
- SCHED_OTHER :: 2
- SCHED_RR :: 3 // Round robin.
- sched_param :: struct {
- sched_priority: c.int,
- }
- _usem :: struct {
- _has_waiters: u32,
- _count: u32,
- _flags: u32,
- }
- _usem2 :: struct {
- _count: u32,
- _flags: u32,
- }
- sem_t :: struct {
- _magic: u32,
- _kern: _usem2,
- _padding: u32,
- }
- PTHREAD_CANCEL_ENABLE :: 0
- PTHREAD_CANCEL_DISABLE :: 1
- PTHREAD_CANCEL_DEFERRED :: 0
- PTHREAD_CANCEL_ASYNCHRONOUS :: 2
- foreign import "system:pthread"
- @(default_calling_convention="c")
- foreign pthread {
- // create named semaphore.
- // used in process-shared semaphores.
- sem_open :: proc(name: cstring, flags: c.int) -> ^sem_t ---
- sem_init :: proc(sem: ^sem_t, pshared: c.int, initial_value: c.uint) -> c.int ---
- sem_destroy :: proc(sem: ^sem_t) -> c.int ---
- sem_post :: proc(sem: ^sem_t) -> c.int ---
- sem_wait :: proc(sem: ^sem_t) -> c.int ---
- sem_trywait :: proc(sem: ^sem_t) -> c.int ---
- // sem_timedwait :: proc(sem: ^sem_t, timeout: time.TimeSpec) -> c.int ---
- // NOTE: unclear whether pthread_yield is well-supported on Linux systems,
- // see https://linux.die.net/man/3/pthread_yield
- pthread_yield :: proc() ---
- pthread_setcancelstate :: proc (state: c.int, old_state: ^c.int) -> c.int ---
- pthread_setcanceltype :: proc (type: c.int, old_type: ^c.int) -> c.int ---
- pthread_cancel :: proc (thread: pthread_t) -> c.int ---
- }
|