all this talk of semaphores made me want to use posix semahpores linux side instead of pthread cond variables. I think they match the win32 semantics more closely
parent
6f5e1e5686
commit
b343a1c4ae
|
@ -67,6 +67,7 @@
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
|
#include <semaphore.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
|
@ -78,16 +79,6 @@
|
||||||
#include <fontconfig/fontconfig.h>
|
#include <fontconfig/fontconfig.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct Linux_Semaphore {
|
|
||||||
pthread_mutex_t mutex;
|
|
||||||
pthread_cond_t cond;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Linux_Semaphore_Handle {
|
|
||||||
pthread_mutex_t *mutex_p;
|
|
||||||
pthread_cond_t *cond_p;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Linux_Coroutine {
|
struct Linux_Coroutine {
|
||||||
Coroutine coroutine;
|
Coroutine coroutine;
|
||||||
Linux_Coroutine *next;
|
Linux_Coroutine *next;
|
||||||
|
@ -145,7 +136,7 @@ struct Linux_Vars{
|
||||||
|
|
||||||
Thread_Memory *thread_memory;
|
Thread_Memory *thread_memory;
|
||||||
Thread_Group groups[THREAD_GROUP_COUNT];
|
Thread_Group groups[THREAD_GROUP_COUNT];
|
||||||
Linux_Semaphore thread_locks[THREAD_GROUP_COUNT];
|
sem_t thread_semaphores[THREAD_GROUP_COUNT];
|
||||||
pthread_mutex_t locks[LOCK_COUNT];
|
pthread_mutex_t locks[LOCK_COUNT];
|
||||||
|
|
||||||
Plat_Settings settings;
|
Plat_Settings settings;
|
||||||
|
@ -526,8 +517,6 @@ Sys_Yield_Coroutine_Sig(system_yield_coroutine){
|
||||||
}
|
}
|
||||||
|
|
||||||
Sys_CLI_Call_Sig(system_cli_call){
|
Sys_CLI_Call_Sig(system_cli_call){
|
||||||
// TODO(allen): Implement
|
|
||||||
|
|
||||||
// fprintf(stderr, "cli call: %s, %s\n", path, script_name);
|
// fprintf(stderr, "cli call: %s, %s\n", path, script_name);
|
||||||
|
|
||||||
int pipe_fds[2];
|
int pipe_fds[2];
|
||||||
|
@ -622,12 +611,16 @@ Sys_CLI_End_Update_Sig(system_cli_end_update){
|
||||||
return close_me;
|
return close_me;
|
||||||
}
|
}
|
||||||
|
|
||||||
static_assert(sizeof(Plat_Handle) >= sizeof(Linux_Semaphore_Handle), "Plat_Handle not big enough");
|
static_assert(sizeof(Plat_Handle) >= sizeof(sem_t*), "Plat_Handle not big enough");
|
||||||
|
|
||||||
internal Plat_Handle
|
internal Plat_Handle
|
||||||
LinuxSemToHandle(Linux_Semaphore* sem){
|
LinuxSemToHandle(sem_t* sem){
|
||||||
Linux_Semaphore_Handle h = { &sem->mutex, &sem->cond };
|
return *(Plat_Handle*)&sem;
|
||||||
return *(Plat_Handle*)&h;
|
}
|
||||||
|
|
||||||
|
internal sem_t*
|
||||||
|
LinuxHandleToSem(Plat_Handle h){
|
||||||
|
return *(sem_t**)&h;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void*
|
internal void*
|
||||||
|
@ -680,19 +673,13 @@ ThreadProc(void* arg){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
Linux_Semaphore_Handle* h = (Linux_Semaphore_Handle*)&(queue->semaphore);
|
sem_wait(LinuxHandleToSem(queue->semaphore));
|
||||||
pthread_mutex_lock(h->mutex_p);
|
|
||||||
pthread_cond_wait(h->cond_p, h->mutex_p);
|
|
||||||
pthread_mutex_unlock(h->mutex_p);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Sys_Post_Job_Sig(system_post_job){
|
Sys_Post_Job_Sig(system_post_job){
|
||||||
// TODO(allen): Implement
|
|
||||||
AllowLocal(group_id);
|
|
||||||
AllowLocal(job);
|
|
||||||
|
|
||||||
Work_Queue *queue = exchange_vars.thread.queues + group_id;
|
Work_Queue *queue = exchange_vars.thread.queues + group_id;
|
||||||
|
|
||||||
|
@ -716,10 +703,7 @@ Sys_Post_Job_Sig(system_post_job){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Linux_Semaphore_Handle* h = (Linux_Semaphore_Handle*)&(queue->semaphore);
|
sem_post(LinuxHandleToSem(queue->semaphore));
|
||||||
pthread_mutex_lock(h->mutex_p);
|
|
||||||
pthread_cond_broadcast(h->cond_p);
|
|
||||||
pthread_mutex_unlock(h->mutex_p);
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -929,7 +913,6 @@ out:
|
||||||
internal
|
internal
|
||||||
Sys_Save_File_Sig(system_save_file){
|
Sys_Save_File_Sig(system_save_file){
|
||||||
b32 result = 0;
|
b32 result = 0;
|
||||||
DBG_FN;
|
|
||||||
|
|
||||||
const size_t save_fsz = strlen(filename);
|
const size_t save_fsz = strlen(filename);
|
||||||
const char tmp_end[] = ".4ed.XXXXXX";
|
const char tmp_end[] = ".4ed.XXXXXX";
|
||||||
|
@ -1858,11 +1841,10 @@ main(int argc, char **argv)
|
||||||
Thread_Memory thread_memory[ArrayCount(background)];
|
Thread_Memory thread_memory[ArrayCount(background)];
|
||||||
linuxvars.thread_memory = thread_memory;
|
linuxvars.thread_memory = thread_memory;
|
||||||
|
|
||||||
pthread_mutex_init(&linuxvars.thread_locks[BACKGROUND_THREADS].mutex, NULL);
|
sem_init(&linuxvars.thread_semaphores[BACKGROUND_THREADS], 0, 0);
|
||||||
pthread_cond_init(&linuxvars.thread_locks[BACKGROUND_THREADS].cond, NULL);
|
|
||||||
|
|
||||||
exchange_vars.thread.queues[BACKGROUND_THREADS].semaphore =
|
exchange_vars.thread.queues[BACKGROUND_THREADS].semaphore =
|
||||||
LinuxSemToHandle(&linuxvars.thread_locks[BACKGROUND_THREADS]);
|
LinuxSemToHandle(&linuxvars.thread_semaphores[BACKGROUND_THREADS]);
|
||||||
|
|
||||||
for(i32 i = 0; i < linuxvars.groups[BACKGROUND_THREADS].count; ++i){
|
for(i32 i = 0; i < linuxvars.groups[BACKGROUND_THREADS].count; ++i){
|
||||||
Thread_Context *thread = linuxvars.groups[BACKGROUND_THREADS].threads + i;
|
Thread_Context *thread = linuxvars.groups[BACKGROUND_THREADS].threads + i;
|
||||||
|
|
Loading…
Reference in New Issue