mirror of
				https://github.com/isledecomp/isle.git
				synced 2025-10-25 01:14:19 +00:00 
			
		
		
		
	Beta match MxAutoLock and MxCriticalSection (#1638)
				
					
				
			Co-authored-by: jonschz <jonschz@users.noreply.github.com>
This commit is contained in:
		| @@ -98,7 +98,7 @@ void LegoLoadCacheSoundPresenter::DoneTickle() | |||||||
| // FUNCTION: LEGO1 0x10018700
 | // FUNCTION: LEGO1 0x10018700
 | ||||||
| MxResult LegoLoadCacheSoundPresenter::PutData() | MxResult LegoLoadCacheSoundPresenter::PutData() | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_currentTickleState == e_done) { | 	if (m_currentTickleState == e_done) { | ||||||
| 		m_cacheSound = SoundManager()->GetCacheSoundManager()->ManageSoundEntry(m_cacheSound); | 		m_cacheSound = SoundManager()->GetCacheSoundManager()->ManageSoundEntry(m_cacheSound); | ||||||
|   | |||||||
| @@ -46,7 +46,7 @@ MxResult LegoSoundManager::Create(MxU32 p_frequencyMS, MxBool p_createThread) | |||||||
| 	MxResult result = FAILURE; | 	MxResult result = FAILURE; | ||||||
| 
 | 
 | ||||||
| 	if (MxSoundManager::Create(10, FALSE) == SUCCESS) { | 	if (MxSoundManager::Create(10, FALSE) == SUCCESS) { | ||||||
| 		m_criticalSection.Enter(); | 		ENTER(m_criticalSection); | ||||||
| 		locked = TRUE; | 		locked = TRUE; | ||||||
| 
 | 
 | ||||||
| 		if (MxOmni::IsSound3D()) { | 		if (MxOmni::IsSound3D()) { | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ void LegoHideAnimPresenter::Init() | |||||||
| // FUNCTION: LEGO1 0x1006da60
 | // FUNCTION: LEGO1 0x1006da60
 | ||||||
| void LegoHideAnimPresenter::Destroy(MxBool p_fromDestructor) | void LegoHideAnimPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_boundaryMap) { | 	if (m_boundaryMap) { | ||||||
| 		delete[] m_boundaryMap; | 		delete[] m_boundaryMap; | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ void LegoLocomotionAnimPresenter::Init() | |||||||
| // FUNCTION: LEGO1 0x1006d0e0
 | // FUNCTION: LEGO1 0x1006d0e0
 | ||||||
| void LegoLocomotionAnimPresenter::Destroy(MxBool p_fromDestructor) | void LegoLocomotionAnimPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_unk0xc4) { | 	if (m_unk0xc4) { | ||||||
| 		delete[] m_unk0xc4; | 		delete[] m_unk0xc4; | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ void LegoModelPresenter::configureLegoModelPresenter(MxS32 p_modelPresenterConfi | |||||||
| // FUNCTION: LEGO1 0x1007f670
 | // FUNCTION: LEGO1 0x1007f670
 | ||||||
| void LegoModelPresenter::Destroy(MxBool p_fromDestructor) | void LegoModelPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	m_roi = NULL; | 	m_roi = NULL; | ||||||
| 	m_addedToView = FALSE; | 	m_addedToView = FALSE; | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ void LegoPalettePresenter::Init() | |||||||
| // FUNCTION: LEGO1 0x1007a0e0
 | // FUNCTION: LEGO1 0x1007a0e0
 | ||||||
| void LegoPalettePresenter::Destroy(MxBool p_fromDestructor) | void LegoPalettePresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	if (m_palette) { | 	if (m_palette) { | ||||||
| 		delete m_palette; | 		delete m_palette; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ MxResult LegoPartPresenter::AddToManager() | |||||||
| // FUNCTION: LEGO1 0x1007c9d0
 | // FUNCTION: LEGO1 0x1007c9d0
 | ||||||
| void LegoPartPresenter::Destroy(MxBool p_fromDestructor) | void LegoPartPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	VideoManager()->UnregisterPresenter(*this); | 	VideoManager()->UnregisterPresenter(*this); | ||||||
| 
 | 
 | ||||||
| 	if (m_parts) { | 	if (m_parts) { | ||||||
|   | |||||||
| @@ -3,15 +3,27 @@ | |||||||
| 
 | 
 | ||||||
| class MxCriticalSection; | class MxCriticalSection; | ||||||
| 
 | 
 | ||||||
|  | #ifdef BETA10 | ||||||
|  | #define AUTOLOCK(CS) MxAutoLock lock(&CS, __FILE__, __LINE__) | ||||||
|  | #else | ||||||
| #define AUTOLOCK(CS) MxAutoLock lock(&CS) | #define AUTOLOCK(CS) MxAutoLock lock(&CS) | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
| class MxAutoLock { | class MxAutoLock { | ||||||
| public: | public: | ||||||
|  | #ifdef BETA10 | ||||||
|  | 	MxAutoLock(MxCriticalSection* p_criticalSection, const char* filename, int line); | ||||||
|  | #else | ||||||
| 	MxAutoLock(MxCriticalSection* p_criticalSection); | 	MxAutoLock(MxCriticalSection* p_criticalSection); | ||||||
|  | #endif | ||||||
| 	~MxAutoLock(); | 	~MxAutoLock(); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
| 	MxCriticalSection* m_criticalSection; // 0x00
 | 	MxCriticalSection* m_criticalSection; // 0x00
 | ||||||
|  | 
 | ||||||
|  | #ifdef BETA10 | ||||||
|  | 	unsigned long m_currentThreadId; // 0x04
 | ||||||
|  | #endif | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #endif // MXAUTOLOCK_H
 | #endif // MXAUTOLOCK_H
 | ||||||
|   | |||||||
| @@ -11,7 +11,11 @@ public: | |||||||
| 
 | 
 | ||||||
| 	static void SetDoMutex(); | 	static void SetDoMutex(); | ||||||
| 
 | 
 | ||||||
|  | #ifdef BETA10 | ||||||
|  | 	void Enter(unsigned long p_threadId, const char* filename, int line); | ||||||
|  | #else | ||||||
| 	void Enter(); | 	void Enter(); | ||||||
|  | #endif | ||||||
| 	void Leave(); | 	void Leave(); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
| @@ -19,4 +23,11 @@ private: | |||||||
| 	HANDLE m_mutex;                     // 0x18
 | 	HANDLE m_mutex;                     // 0x18
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | #ifdef BETA10 | ||||||
|  | // TODO: Not quite correct yet, the second argument becomes a relocated value
 | ||||||
|  | #define ENTER(criticalSection) criticalSection.Enter(-1, NULL, 0) | ||||||
|  | #else | ||||||
|  | #define ENTER(criticalSection) criticalSection.Enter() | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| #endif // MXCRITICALSECTION_H
 | #endif // MXCRITICALSECTION_H
 | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ void MxAudioManager::Init() | |||||||
| // FUNCTION: LEGO1 0x100b8e00
 | // FUNCTION: LEGO1 0x100b8e00
 | ||||||
| void MxAudioManager::Destroy(MxBool p_fromDestructor) | void MxAudioManager::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	g_count--; | 	g_count--; | ||||||
| 	Init(); | 	Init(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| @@ -43,7 +43,7 @@ MxResult MxAudioManager::Create() | |||||||
| 	MxBool success = FALSE; | 	MxBool success = FALSE; | ||||||
| 
 | 
 | ||||||
| 	if (MxMediaManager::Create() == SUCCESS) { | 	if (MxMediaManager::Create() == SUCCESS) { | ||||||
| 		m_criticalSection.Enter(); | 		ENTER(m_criticalSection); | ||||||
| 		success = TRUE; | 		success = TRUE; | ||||||
| 		result = SUCCESS; | 		result = SUCCESS; | ||||||
| 		g_count++; | 		g_count++; | ||||||
| @@ -69,7 +69,7 @@ void MxAudioManager::Destroy() | |||||||
| // FUNCTION: LEGO1 0x100b8ea0
 | // FUNCTION: LEGO1 0x100b8ea0
 | ||||||
| void MxAudioManager::SetVolume(MxS32 p_volume) | void MxAudioManager::SetVolume(MxS32 p_volume) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	m_volume = p_volume; | 	m_volume = p_volume; | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -39,7 +39,7 @@ void MxLoopingMIDIPresenter::DoneTickle() | |||||||
| // FUNCTION: LEGO1 0x100c2b00
 | // FUNCTION: LEGO1 0x100c2b00
 | ||||||
| MxResult MxLoopingMIDIPresenter::PutData() | MxResult MxLoopingMIDIPresenter::PutData() | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_currentTickleState == e_streaming && m_chunk && !MusicManager()->GetMIDIInitialized()) { | 	if (m_currentTickleState == e_streaming && m_chunk && !MusicManager()->GetMIDIInitialized()) { | ||||||
| 		SetVolume(((MxDSSound*) m_action)->GetVolume()); | 		SetVolume(((MxDSSound*) m_action)->GetVolume()); | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ void MxMIDIPresenter::Destroy(MxBool p_fromDestructor) | |||||||
| 		MusicManager()->DeinitializeMIDI(); | 		MusicManager()->DeinitializeMIDI(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_subscriber && m_chunk) { | 	if (m_subscriber && m_chunk) { | ||||||
| 		m_subscriber->FreeDataChunk(m_chunk); | 		m_subscriber->FreeDataChunk(m_chunk); | ||||||
| @@ -98,7 +98,7 @@ void MxMIDIPresenter::Destroy() | |||||||
| // FUNCTION: LEGO1 0x100c2970
 | // FUNCTION: LEGO1 0x100c2970
 | ||||||
| MxResult MxMIDIPresenter::PutData() | MxResult MxMIDIPresenter::PutData() | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_currentTickleState == e_streaming && m_chunk && !MusicManager()->GetMIDIInitialized()) { | 	if (m_currentTickleState == e_streaming && m_chunk && !MusicManager()->GetMIDIInitialized()) { | ||||||
| 		SetVolume(((MxDSSound*) m_action)->GetVolume()); | 		SetVolume(((MxDSSound*) m_action)->GetVolume()); | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ void MxMusicManager::Destroy(MxBool p_fromDestructor) | |||||||
| 		TickleManager()->UnregisterClient(this); | 		TickleManager()->UnregisterClient(this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	DeinitializeMIDI(); | 	DeinitializeMIDI(); | ||||||
| 	Init(); | 	Init(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| @@ -146,7 +146,7 @@ MxResult MxMusicManager::Create(MxU32 p_frequencyMS, MxBool p_createThread) | |||||||
| 
 | 
 | ||||||
| 	if (MxAudioManager::Create() == SUCCESS) { | 	if (MxAudioManager::Create() == SUCCESS) { | ||||||
| 		if (p_createThread) { | 		if (p_createThread) { | ||||||
| 			m_criticalSection.Enter(); | 			ENTER(m_criticalSection); | ||||||
| 			locked = TRUE; | 			locked = TRUE; | ||||||
| 			m_thread = new MxTickleThread(this, p_frequencyMS); | 			m_thread = new MxTickleThread(this, p_frequencyMS); | ||||||
| 
 | 
 | ||||||
| @@ -183,7 +183,7 @@ void MxMusicManager::Destroy() | |||||||
| void MxMusicManager::SetVolume(MxS32 p_volume) | void MxMusicManager::SetVolume(MxS32 p_volume) | ||||||
| { | { | ||||||
| 	MxAudioManager::SetVolume(p_volume); | 	MxAudioManager::SetVolume(p_volume); | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	SetMIDIVolume(); | 	SetMIDIVolume(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| } | } | ||||||
| @@ -191,7 +191,7 @@ void MxMusicManager::SetVolume(MxS32 p_volume) | |||||||
| // FUNCTION: LEGO1 0x100c0970
 | // FUNCTION: LEGO1 0x100c0970
 | ||||||
| void MxMusicManager::SetMultiplier(MxS32 p_multiplier) | void MxMusicManager::SetMultiplier(MxS32 p_multiplier) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	m_multiplier = p_multiplier; | 	m_multiplier = p_multiplier; | ||||||
| 	SetMIDIVolume(); | 	SetMIDIVolume(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| @@ -209,7 +209,7 @@ MxResult MxMusicManager::InitializeMIDI(MxU8* p_data, MxS32 p_loopCount) | |||||||
| { | { | ||||||
| 	MxResult result = FAILURE; | 	MxResult result = FAILURE; | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (!m_midiInitialized) { | 	if (!m_midiInitialized) { | ||||||
| 		MxU32 total = midiOutGetNumDevs(); | 		MxU32 total = midiOutGetNumDevs(); | ||||||
| @@ -278,7 +278,7 @@ done: | |||||||
| // FUNCTION: LEGO1 0x100c0b20
 | // FUNCTION: LEGO1 0x100c0b20
 | ||||||
| void MxMusicManager::DeinitializeMIDI() | void MxMusicManager::DeinitializeMIDI() | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_midiInitialized) { | 	if (m_midiInitialized) { | ||||||
| 		m_midiInitialized = FALSE; | 		m_midiInitialized = FALSE; | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ void MxMusicPresenter::Destroy(MxBool p_fromDestructor) | |||||||
| 		MusicManager()->UnregisterPresenter(*this); | 		MusicManager()->UnregisterPresenter(*this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	Init(); | 	Init(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -52,7 +52,7 @@ void MxSoundManager::Destroy(MxBool p_fromDestructor) | |||||||
| 		TickleManager()->UnregisterClient(this); | 		TickleManager()->UnregisterClient(this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_dsBuffer) { | 	if (m_dsBuffer) { | ||||||
| 		m_dsBuffer->Release(); | 		m_dsBuffer->Release(); | ||||||
| @@ -77,7 +77,7 @@ MxResult MxSoundManager::Create(MxU32 p_frequencyMS, MxBool p_createThread) | |||||||
| 		goto done; | 		goto done; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	locked = TRUE; | 	locked = TRUE; | ||||||
| 
 | 
 | ||||||
| 	if (DirectSoundCreate(NULL, &m_directSound, NULL) != DS_OK) { | 	if (DirectSoundCreate(NULL, &m_directSound, NULL) != DS_OK) { | ||||||
| @@ -166,7 +166,7 @@ void MxSoundManager::SetVolume(MxS32 p_volume) | |||||||
| { | { | ||||||
| 	MxAudioManager::SetVolume(p_volume); | 	MxAudioManager::SetVolume(p_volume); | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	MxPresenter* presenter; | 	MxPresenter* presenter; | ||||||
| 	MxPresenterListCursor cursor(m_presenters); | 	MxPresenterListCursor cursor(m_presenters); | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ void MxSoundPresenter::Destroy(MxBool p_fromDestructor) | |||||||
| 		MSoundManager()->UnregisterPresenter(*this); | 		MSoundManager()->UnregisterPresenter(*this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	MxMediaPresenter::Init(); | 	MxMediaPresenter::Init(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -294,7 +294,7 @@ void MxWavePresenter::EndAction() | |||||||
| // FUNCTION: LEGO1 0x100b2300
 | // FUNCTION: LEGO1 0x100b2300
 | ||||||
| void MxWavePresenter::SetVolume(MxS32 p_volume) | void MxWavePresenter::SetVolume(MxS32 p_volume) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	m_volume = p_volume; | 	m_volume = p_volume; | ||||||
| 	if (m_dsBuffer != NULL) { | 	if (m_dsBuffer != NULL) { | ||||||
|   | |||||||
| @@ -48,7 +48,7 @@ MxResult MxEventManager::Create(MxU32 p_frequencyMS, MxBool p_createThread) | |||||||
| 	MxResult result = MxMediaManager::Create(); | 	MxResult result = MxMediaManager::Create(); | ||||||
| 	if (result == SUCCESS) { | 	if (result == SUCCESS) { | ||||||
| 		if (p_createThread) { | 		if (p_createThread) { | ||||||
| 			this->m_criticalSection.Enter(); | 			ENTER(this->m_criticalSection); | ||||||
| 			locked = TRUE; | 			locked = TRUE; | ||||||
| 			this->m_thread = new MxTickleThread(this, p_frequencyMS); | 			this->m_thread = new MxTickleThread(this, p_frequencyMS); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -50,7 +50,7 @@ void MxEventPresenter::Destroy() | |||||||
| 		EventManager()->UnregisterPresenter(*this); | 		EventManager()->UnregisterPresenter(*this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_data) { | 	if (m_data) { | ||||||
| 		delete[] m_data; | 		delete[] m_data; | ||||||
|   | |||||||
| @@ -2,8 +2,19 @@ | |||||||
| 
 | 
 | ||||||
| #include "mxcriticalsection.h" | #include "mxcriticalsection.h" | ||||||
| 
 | 
 | ||||||
| // FUNCTION: LEGO1 0x100b8ed0
 | #ifdef BETA10 | ||||||
| // FUNCTION: BETA10 0x101386f0
 | // FUNCTION: BETA10 0x101386f0
 | ||||||
|  | MxAutoLock::MxAutoLock(MxCriticalSection* p_criticalSection, const char* filename, int line) | ||||||
|  | { | ||||||
|  | 	m_criticalSection = p_criticalSection; | ||||||
|  | 	m_currentThreadId = GetCurrentThreadId(); | ||||||
|  | 
 | ||||||
|  | 	if (m_criticalSection != NULL) { | ||||||
|  | 		m_criticalSection->Enter(m_currentThreadId, filename, line); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | #else | ||||||
|  | // FUNCTION: LEGO1 0x100b8ed0
 | ||||||
| MxAutoLock::MxAutoLock(MxCriticalSection* p_criticalSection) | MxAutoLock::MxAutoLock(MxCriticalSection* p_criticalSection) | ||||||
| { | { | ||||||
| 	m_criticalSection = p_criticalSection; | 	m_criticalSection = p_criticalSection; | ||||||
| @@ -12,6 +23,7 @@ MxAutoLock::MxAutoLock(MxCriticalSection* p_criticalSection) | |||||||
| 		m_criticalSection->Enter(); | 		m_criticalSection->Enter(); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
| // FUNCTION: LEGO1 0x100b8ef0
 | // FUNCTION: LEGO1 0x100b8ef0
 | ||||||
| // FUNCTION: BETA10 0x10138744
 | // FUNCTION: BETA10 0x10138744
 | ||||||
|   | |||||||
| @@ -35,8 +35,35 @@ MxCriticalSection::~MxCriticalSection() | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // FUNCTION: LEGO1 0x100b6d80
 | #ifdef BETA10 | ||||||
| // FUNCTION: BETA10 0x1013c725
 | // FUNCTION: BETA10 0x1013c725
 | ||||||
|  | void MxCriticalSection::Enter(unsigned long p_threadId, const char* filename, int line) | ||||||
|  | { | ||||||
|  | 	DWORD result; | ||||||
|  | 	FILE* file; | ||||||
|  | 
 | ||||||
|  | 	if (m_mutex != NULL) { | ||||||
|  | 		result = WaitForSingleObject(m_mutex, 5000); | ||||||
|  | 		if (result == WAIT_FAILED) { | ||||||
|  | 			file = fopen("C:\\DEADLOCK.TXT", "a"); | ||||||
|  | 			if (file != NULL) { | ||||||
|  | 				fprintf(file, "mutex timeout occurred!\n"); | ||||||
|  | 				fprintf(file, "file: %s, line: %d\n", filename, line); | ||||||
|  | 				fclose(file); | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			abort(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	else { | ||||||
|  | 		EnterCriticalSection(&m_criticalSection); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	// There is way more structure in here, and the MxCriticalSection class is much larger in BETA10.
 | ||||||
|  | 	// The LEGO1 compilation is very unlikely to profit from a further decompilation here.
 | ||||||
|  | } | ||||||
|  | #else | ||||||
|  | // FUNCTION: LEGO1 0x100b6d80
 | ||||||
| void MxCriticalSection::Enter() | void MxCriticalSection::Enter() | ||||||
| { | { | ||||||
| 	DWORD result; | 	DWORD result; | ||||||
| @@ -58,8 +85,10 @@ void MxCriticalSection::Enter() | |||||||
| 		EnterCriticalSection(&m_criticalSection); | 		EnterCriticalSection(&m_criticalSection); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
| // FUNCTION: LEGO1 0x100b6de0
 | // FUNCTION: LEGO1 0x100b6de0
 | ||||||
|  | // FUNCTION: BETA10 0x1013c7ef
 | ||||||
| void MxCriticalSection::Leave() | void MxCriticalSection::Leave() | ||||||
| { | { | ||||||
| 	if (m_mutex != NULL) { | 	if (m_mutex != NULL) { | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ void MxLoopingFlcPresenter::Init() | |||||||
| // FUNCTION: LEGO1 0x100b4430
 | // FUNCTION: LEGO1 0x100b4430
 | ||||||
| void MxLoopingFlcPresenter::Destroy(MxBool p_fromDestructor) | void MxLoopingFlcPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	Init(); | 	Init(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| 
 | 
 | ||||||
| @@ -117,7 +117,7 @@ MxResult MxLoopingFlcPresenter::AddToManager() | |||||||
| 	MxBool locked = FALSE; | 	MxBool locked = FALSE; | ||||||
| 
 | 
 | ||||||
| 	if (MxFlcPresenter::AddToManager() == SUCCESS) { | 	if (MxFlcPresenter::AddToManager() == SUCCESS) { | ||||||
| 		m_criticalSection.Enter(); | 		ENTER(m_criticalSection); | ||||||
| 		locked = TRUE; | 		locked = TRUE; | ||||||
| 		result = SUCCESS; | 		result = SUCCESS; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ void MxLoopingSmkPresenter::Init() | |||||||
| // FUNCTION: LEGO1 0x100b49d0
 | // FUNCTION: LEGO1 0x100b49d0
 | ||||||
| void MxLoopingSmkPresenter::Destroy(MxBool p_fromDestructor) | void MxLoopingSmkPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	Init(); | 	Init(); | ||||||
| 	m_criticalSection.Leave(); | 	m_criticalSection.Leave(); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -32,7 +32,7 @@ void MxSmkPresenter::Init() | |||||||
| // FUNCTION: LEGO1 0x100b3900
 | // FUNCTION: LEGO1 0x100b3900
 | ||||||
| void MxSmkPresenter::Destroy(MxBool p_fromDestructor) | void MxSmkPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	MxSmk::Destroy(&m_mxSmk); | 	MxSmk::Destroy(&m_mxSmk); | ||||||
| 	Init(); | 	Init(); | ||||||
|   | |||||||
| @@ -17,7 +17,7 @@ DECOMP_SIZE_ASSERT(MxStillPresenter, 0x6c); | |||||||
| // FUNCTION: LEGO1 0x100b9c70
 | // FUNCTION: LEGO1 0x100b9c70
 | ||||||
| void MxStillPresenter::Destroy(MxBool p_fromDestructor) | void MxStillPresenter::Destroy(MxBool p_fromDestructor) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_bitmapInfo) { | 	if (m_bitmapInfo) { | ||||||
| 		delete[] ((MxU8*) m_bitmapInfo); | 		delete[] ((MxU8*) m_bitmapInfo); | ||||||
|   | |||||||
| @@ -52,7 +52,7 @@ void MxVideoManager::Destroy(MxBool p_fromDestructor) | |||||||
| 		TickleManager()->UnregisterClient(this); | 		TickleManager()->UnregisterClient(this); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_displaySurface) { | 	if (m_displaySurface) { | ||||||
| 		delete m_displaySurface; | 		delete m_displaySurface; | ||||||
| @@ -152,7 +152,7 @@ MxResult MxVideoManager::VTable0x28( | |||||||
| 		goto done; | 		goto done; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	locked = TRUE; | 	locked = TRUE; | ||||||
| 
 | 
 | ||||||
| 	m_videoParam = p_videoParam; | 	m_videoParam = p_videoParam; | ||||||
| @@ -225,7 +225,7 @@ MxResult MxVideoManager::Create(MxVideoParam& p_videoParam, MxU32 p_frequencyMS, | |||||||
| 		goto done; | 		goto done; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 	locked = TRUE; | 	locked = TRUE; | ||||||
| 
 | 
 | ||||||
| 	m_videoParam = p_videoParam; | 	m_videoParam = p_videoParam; | ||||||
| @@ -300,7 +300,7 @@ void MxVideoManager::Destroy() | |||||||
| // FUNCTION: LEGO1 0x100bea60
 | // FUNCTION: LEGO1 0x100bea60
 | ||||||
| void MxVideoManager::InvalidateRect(MxRect32& p_rect) | void MxVideoManager::InvalidateRect(MxRect32& p_rect) | ||||||
| { | { | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (m_region) { | 	if (m_region) { | ||||||
| 		m_region->AddRect(p_rect); | 		m_region->AddRect(p_rect); | ||||||
| @@ -340,7 +340,7 @@ MxResult MxVideoManager::RealizePalette(MxPalette* p_palette) | |||||||
| { | { | ||||||
| 	PALETTEENTRY paletteEntries[256]; | 	PALETTEENTRY paletteEntries[256]; | ||||||
| 
 | 
 | ||||||
| 	m_criticalSection.Enter(); | 	ENTER(m_criticalSection); | ||||||
| 
 | 
 | ||||||
| 	if (p_palette && m_videoParam.GetPalette()) { | 	if (p_palette && m_videoParam.GetPalette()) { | ||||||
| 		p_palette->GetEntries(paletteEntries); | 		p_palette->GetEntries(paletteEntries); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 jonschz
					jonschz