mirror of
https://github.com/isledecomp/isle-portable.git
synced 2024-11-26 17:36:12 -05:00
cb8c143ce5
* more mxdiskstreamcontroller methods * further debugging and fixes * add more functions * Update mxdiskstreamprovider.cpp * fix build * implement MxDiskStreamProvider::PerformWork * Update mxdiskstreamprovider.cpp * Update mxdiskstreamprovider.cpp * Update mxdssource.h * remove debug prints * Update mxdiskstreamprovider.cpp * Mostly match MxDiskStreamController::FUN_100c8540 * Mostly match MxDiskStreamProvider::FUN_100d1780 * Mostly match MxDiskStreamProvider::PerformWork * Fixes * Retype some members * Various annotations --------- Co-authored-by: Christian Semmler <mail@csemmler.com>
97 lines
1.9 KiB
C++
97 lines
1.9 KiB
C++
|
|
#include "mxthread.h"
|
|
|
|
#include "decomp.h"
|
|
#include "mxomni.h"
|
|
#include "mxtimer.h"
|
|
|
|
#include <process.h>
|
|
|
|
DECOMP_SIZE_ASSERT(MxThread, 0x1c)
|
|
DECOMP_SIZE_ASSERT(MxTickleThread, 0x20)
|
|
|
|
// FUNCTION: LEGO1 0x100b8bb0
|
|
MxTickleThread::MxTickleThread(MxCore* p_target, MxS32 p_frequencyMS)
|
|
{
|
|
m_target = p_target;
|
|
m_frequencyMS = p_frequencyMS;
|
|
}
|
|
|
|
// Match except for register allocation
|
|
// FUNCTION: LEGO1 0x100b8c90
|
|
MxResult MxTickleThread::Run()
|
|
{
|
|
MxTimer* timer = Timer();
|
|
MxS32 lastTickled = -m_frequencyMS;
|
|
while (IsRunning()) {
|
|
MxLong currentTime = timer->GetTime();
|
|
|
|
if (currentTime < lastTickled) {
|
|
lastTickled = -m_frequencyMS;
|
|
}
|
|
|
|
MxS32 timeRemainingMS = (m_frequencyMS - currentTime) + lastTickled;
|
|
if (timeRemainingMS <= 0) {
|
|
m_target->Tickle();
|
|
timeRemainingMS = 0;
|
|
lastTickled = currentTime;
|
|
}
|
|
Sleep(timeRemainingMS);
|
|
}
|
|
return MxThread::Run();
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100bf510
|
|
MxThread::MxThread()
|
|
{
|
|
m_hThread = NULL;
|
|
m_running = TRUE;
|
|
m_threadId = 0;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100bf5a0
|
|
MxThread::~MxThread()
|
|
{
|
|
if (m_hThread)
|
|
CloseHandle((HANDLE) m_hThread);
|
|
}
|
|
|
|
typedef unsigned(__stdcall* ThreadFunc)(void*);
|
|
|
|
// FUNCTION: LEGO1 0x100bf610
|
|
MxResult MxThread::Start(MxS32 p_stack, MxS32 p_flag)
|
|
{
|
|
MxResult result = FAILURE;
|
|
if (m_semaphore.Init(0, 1) == SUCCESS) {
|
|
if (m_hThread =
|
|
_beginthreadex(NULL, p_stack << 2, (ThreadFunc) &MxThread::ThreadProc, this, p_flag, &m_threadId))
|
|
result = SUCCESS;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100bf660
|
|
void MxThread::Sleep(MxS32 p_milliseconds)
|
|
{
|
|
::Sleep(p_milliseconds);
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100bf670
|
|
void MxThread::Terminate()
|
|
{
|
|
m_running = FALSE;
|
|
m_semaphore.Wait(INFINITE);
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100bf680
|
|
unsigned MxThread::ThreadProc(void* p_thread)
|
|
{
|
|
return static_cast<MxThread*>(p_thread)->Run();
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100bf690
|
|
MxResult MxThread::Run()
|
|
{
|
|
m_semaphore.Release(1);
|
|
return SUCCESS;
|
|
}
|