mirror of
https://github.com/isledecomp/isle-portable.git
synced 2026-01-19 22:01:14 +00:00
Add potentially unnecessary threading stuff
This commit is contained in:
parent
e149776c3e
commit
0787b2ebf8
@ -5,7 +5,11 @@
|
|||||||
#include "mxsemaphore.h"
|
#include "mxsemaphore.h"
|
||||||
#include "mxtypes.h"
|
#include "mxtypes.h"
|
||||||
|
|
||||||
|
#ifdef PS2
|
||||||
|
#include <kernel.h>
|
||||||
|
#else
|
||||||
#include <SDL3/SDL_thread.h>
|
#include <SDL3/SDL_thread.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
class MxCore;
|
class MxCore;
|
||||||
|
|
||||||
@ -41,9 +45,13 @@ class MxThread {
|
|||||||
virtual ~MxThread();
|
virtual ~MxThread();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
#ifdef PS2
|
||||||
|
static int ThreadProc(void* p_thread);
|
||||||
|
int m_thread;
|
||||||
|
#else
|
||||||
static int SDLCALL ThreadProc(void* p_thread);
|
static int SDLCALL ThreadProc(void* p_thread);
|
||||||
|
|
||||||
SDL_Thread* m_thread;
|
SDL_Thread* m_thread;
|
||||||
|
#endif
|
||||||
MxBool m_running; // 0x0c
|
MxBool m_running; // 0x0c
|
||||||
MxSemaphore m_semaphore; // 0x10
|
MxSemaphore m_semaphore; // 0x10
|
||||||
|
|
||||||
|
|||||||
@ -3,6 +3,9 @@
|
|||||||
#include "decomp.h"
|
#include "decomp.h"
|
||||||
|
|
||||||
#include <SDL3/SDL_timer.h>
|
#include <SDL3/SDL_timer.h>
|
||||||
|
#ifdef PS2
|
||||||
|
#include <kernel.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
DECOMP_SIZE_ASSERT(MxThread, 0x1c)
|
DECOMP_SIZE_ASSERT(MxThread, 0x1c)
|
||||||
|
|
||||||
@ -10,7 +13,11 @@ DECOMP_SIZE_ASSERT(MxThread, 0x1c)
|
|||||||
// FUNCTION: BETA10 0x10147540
|
// FUNCTION: BETA10 0x10147540
|
||||||
MxThread::MxThread()
|
MxThread::MxThread()
|
||||||
{
|
{
|
||||||
|
#ifdef PS2
|
||||||
|
m_thread = 0;
|
||||||
|
#else
|
||||||
m_thread = NULL;
|
m_thread = NULL;
|
||||||
|
#endif
|
||||||
m_running = TRUE;
|
m_running = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -19,7 +26,13 @@ MxThread::MxThread()
|
|||||||
MxThread::~MxThread()
|
MxThread::~MxThread()
|
||||||
{
|
{
|
||||||
if (m_thread) {
|
if (m_thread) {
|
||||||
|
#ifdef PS2
|
||||||
|
ReleaseWaitThread(m_thread);
|
||||||
|
DeleteThread(m_thread);
|
||||||
|
m_thread = 0;
|
||||||
|
#else
|
||||||
SDL_WaitThread(m_thread, NULL);
|
SDL_WaitThread(m_thread, NULL);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -30,6 +43,23 @@ MxResult MxThread::Start(MxS32 p_stackSize, MxS32 p_flag)
|
|||||||
MxResult result = FAILURE;
|
MxResult result = FAILURE;
|
||||||
|
|
||||||
if (m_semaphore.Init(0, 1) != SUCCESS) {
|
if (m_semaphore.Init(0, 1) != SUCCESS) {
|
||||||
|
#ifdef PS2
|
||||||
|
ee_thread_t thread;
|
||||||
|
thread.func = (void*)&(MxThread::ThreadProc);
|
||||||
|
thread .stack_size = p_stackSize * 4;
|
||||||
|
thread.initial_priority = 0x18;
|
||||||
|
int thid = CreateThread(&thread);
|
||||||
|
|
||||||
|
if (thid >= 0) {
|
||||||
|
MxThread* self = this;
|
||||||
|
int start = StartThread(thid, &self);
|
||||||
|
if (start >= 0) {
|
||||||
|
result = SUCCESS;
|
||||||
|
m_thread = thid; // store thread ID if needed
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -45,6 +75,7 @@ MxResult MxThread::Start(MxS32 p_stackSize, MxS32 p_flag)
|
|||||||
|
|
||||||
SDL_DestroyProperties(props);
|
SDL_DestroyProperties(props);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
result = SUCCESS;
|
result = SUCCESS;
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user