From 4db1a51fa4cb6412c76a37329d23a00478c9f9ef Mon Sep 17 00:00:00 2001 From: StapleButter Date: Tue, 19 Sep 2017 15:39:41 +0200 Subject: [PATCH] add Platform thread/semaphore support, using SDL --- src/libui_sdl/Platform.cpp | 54 ++++++++++++++++---------------------- 1 file changed, 23 insertions(+), 31 deletions(-) diff --git a/src/libui_sdl/Platform.cpp b/src/libui_sdl/Platform.cpp index fbf06237..7313ae44 100644 --- a/src/libui_sdl/Platform.cpp +++ b/src/libui_sdl/Platform.cpp @@ -19,6 +19,7 @@ #include #include #include +#include #include "../Platform.h" #include "../Config.h" @@ -47,27 +48,19 @@ namespace Platform { -/*class Thread : public wxThread +typedef struct { -public: - Thread(void (*func)()) - : wxThread(wxTHREAD_JOINABLE) - { - this->Func = func; - } - - ~Thread() {} - -protected: - virtual ExitCode Entry() - { - Func(); - return (ExitCode)0; - } - -private: + SDL_Thread* ID; void (*Func)(); -};*/ + +} ThreadData; + +int ThreadEntry(void* data) +{ + ThreadData* thread = (ThreadData*)data; + thread->Func(); + return 0; +} /*socket_t MPSocket; @@ -79,47 +72,46 @@ u8 PacketBuffer[2048]; void* Thread_Create(void (*func)()) { - /*Thread* ret = new Thread(func); - ret->Run(); - return (void*)ret;*/ - return NULL; + ThreadData* data = new ThreadData; + data->Func = func; + data->ID = SDL_CreateThread(ThreadEntry, "melonDS core thread", data); + return data; } void Thread_Free(void* thread) { - //delete (Thread*)thread; + delete (ThreadData*)thread; } void Thread_Wait(void* thread) { - //((Thread*)thread)->Wait(); + SDL_WaitThread((SDL_Thread*)((ThreadData*)thread)->ID, NULL); } void* Semaphore_Create() { - //return (void*)new wxSemaphore(); - return NULL; + return SDL_CreateSemaphore(0); } void Semaphore_Free(void* sema) { - //delete (wxSemaphore*)sema; + SDL_DestroySemaphore((SDL_sem*)sema); } void Semaphore_Reset(void* sema) { - //while (((wxSemaphore*)sema)->TryWait() == wxSEMA_NO_ERROR); + while (SDL_SemTryWait((SDL_sem*)sema) == 0); } void Semaphore_Wait(void* sema) { - //((wxSemaphore*)sema)->Wait(); + SDL_SemWait((SDL_sem*)sema); } void Semaphore_Post(void* sema) { - //((wxSemaphore*)sema)->Post(); + SDL_SemPost((SDL_sem*)sema); }