2015-07-01 08:02:44 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2015 Andrew Kelley
|
|
|
|
*
|
|
|
|
* This file is part of libsoundio, which is MIT licensed.
|
|
|
|
* See http://opensource.org/licenses/MIT
|
|
|
|
*/
|
|
|
|
|
2015-07-30 19:07:58 +00:00
|
|
|
#ifndef SOUNDIO_OS_H
|
|
|
|
#define SOUNDIO_OS_H
|
2015-07-01 08:02:44 +00:00
|
|
|
|
|
|
|
#include <stdbool.h>
|
2015-07-06 23:02:20 +00:00
|
|
|
#include <stddef.h>
|
2015-07-01 08:02:44 +00:00
|
|
|
|
2015-07-02 09:45:02 +00:00
|
|
|
// safe to call from any thread(s) multiple times, but
|
|
|
|
// must be called at least once before calling any other os functions
|
2015-07-21 03:13:35 +00:00
|
|
|
// soundio_create calls this function.
|
2015-07-30 07:46:13 +00:00
|
|
|
int soundio_os_init(void);
|
2015-07-02 09:45:02 +00:00
|
|
|
|
2015-07-01 08:02:44 +00:00
|
|
|
double soundio_os_get_time(void);
|
|
|
|
|
|
|
|
struct SoundIoOsThread;
|
|
|
|
int soundio_os_thread_create(
|
|
|
|
void (*run)(void *arg), void *arg,
|
2015-08-26 19:54:13 +00:00
|
|
|
void (*emit_rtprio_warning)(void),
|
|
|
|
struct SoundIoOsThread ** out_thread);
|
2015-07-01 08:02:44 +00:00
|
|
|
|
|
|
|
void soundio_os_thread_destroy(struct SoundIoOsThread *thread);
|
|
|
|
|
|
|
|
|
|
|
|
struct SoundIoOsMutex;
|
|
|
|
struct SoundIoOsMutex *soundio_os_mutex_create(void);
|
|
|
|
void soundio_os_mutex_destroy(struct SoundIoOsMutex *mutex);
|
|
|
|
void soundio_os_mutex_lock(struct SoundIoOsMutex *mutex);
|
|
|
|
void soundio_os_mutex_unlock(struct SoundIoOsMutex *mutex);
|
|
|
|
|
|
|
|
struct SoundIoOsCond;
|
2015-07-03 02:15:09 +00:00
|
|
|
struct SoundIoOsCond *soundio_os_cond_create(void);
|
2015-07-01 08:02:44 +00:00
|
|
|
void soundio_os_cond_destroy(struct SoundIoOsCond *cond);
|
|
|
|
|
2015-07-02 09:45:02 +00:00
|
|
|
// locked_mutex is optional. On systems that use mutexes for conditions, if you
|
|
|
|
// pass NULL, a mutex will be created and locked/unlocked for you. On systems
|
|
|
|
// that do not use mutexes for conditions, no mutex handling is necessary. If
|
|
|
|
// you already have a locked mutex available, pass it; this will be better on
|
|
|
|
// systems that use mutexes for conditions.
|
|
|
|
void soundio_os_cond_signal(struct SoundIoOsCond *cond,
|
|
|
|
struct SoundIoOsMutex *locked_mutex);
|
2015-07-01 08:02:44 +00:00
|
|
|
void soundio_os_cond_timed_wait(struct SoundIoOsCond *cond,
|
2015-07-02 09:45:02 +00:00
|
|
|
struct SoundIoOsMutex *locked_mutex, double seconds);
|
2015-07-01 09:37:51 +00:00
|
|
|
void soundio_os_cond_wait(struct SoundIoOsCond *cond,
|
2015-07-02 09:45:02 +00:00
|
|
|
struct SoundIoOsMutex *locked_mutex);
|
2015-07-01 08:02:44 +00:00
|
|
|
|
2015-07-06 23:02:20 +00:00
|
|
|
|
|
|
|
int soundio_os_page_size(void);
|
|
|
|
|
2015-07-27 22:29:10 +00:00
|
|
|
// You may rely on the size of this struct as part of the API and ABI.
|
2015-07-21 18:11:32 +00:00
|
|
|
struct SoundIoOsMirroredMemory {
|
|
|
|
size_t capacity;
|
|
|
|
char *address;
|
2015-07-27 22:29:10 +00:00
|
|
|
void *priv;
|
2015-07-21 18:11:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// returned capacity might be increased from capacity to be a multiple of the
|
|
|
|
// system page size
|
2015-07-27 22:29:10 +00:00
|
|
|
int soundio_os_init_mirrored_memory(struct SoundIoOsMirroredMemory *mem, size_t capacity);
|
|
|
|
void soundio_os_deinit_mirrored_memory(struct SoundIoOsMirroredMemory *mem);
|
2015-07-06 23:02:20 +00:00
|
|
|
|
2015-07-01 08:02:44 +00:00
|
|
|
#endif
|