aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVitaly Novichkov <Wohlstand@users.noreply.github.com>2019-07-01 19:41:19 +0300
committerGitHub <noreply@github.com>2019-07-01 19:41:19 +0300
commitb4e56f82478d3f865af24132767e0cb8924098df (patch)
treeb87ab0d395af346aa4fa2003849c3cc9b4ab0cba
parent84bd1e141a67745d6c06e179d62f5b17cef99e31 (diff)
parent35c7fd9d8320a9d97723591eb6ee48974f6be528 (diff)
downloadlibADLMIDI-b4e56f82478d3f865af24132767e0cb8924098df.tar.gz
libADLMIDI-b4e56f82478d3f865af24132767e0cb8924098df.tar.bz2
libADLMIDI-b4e56f82478d3f865af24132767e0cb8924098df.zip
Merge pull request #224 from jpcima/multi-thread
dosbox: thread-safe global initialization
-rw-r--r--src/chips/dosbox/dbopl.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/chips/dosbox/dbopl.cpp b/src/chips/dosbox/dbopl.cpp
index d1ab82f..5b4bf53 100644
--- a/src/chips/dosbox/dbopl.cpp
+++ b/src/chips/dosbox/dbopl.cpp
@@ -1507,11 +1507,15 @@ void Chip::Setup( Bit32u rate ) {
}
}
-static bool doneTables = false;
+static volatile bool doneTables = false;
+static Mutex mutexTables;
+
void InitTables( void ) {
if ( doneTables )
return;
- doneTables = true;
+ MutexHolder lock( mutexTables );
+ if ( doneTables )
+ return;
#if ( DBOPL_WAVE == WAVE_HANDLER ) || ( DBOPL_WAVE == WAVE_TABLELOG )
//Exponential volume table, same as the real adlib
for ( int i = 0; i < 256; i++ ) {
@@ -1661,6 +1665,7 @@ void InitTables( void ) {
}
}
#endif
+ doneTables = true;
}
Bit32u Handler::WriteAddr( Bit32u port, Bit8u val ) {