aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorVitaly Novichkov <admin@wohlnet.ru>2019-09-23 02:14:21 +0300
committerVitaly Novichkov <admin@wohlnet.ru>2019-09-23 02:14:21 +0300
commit62a018a1338b807d325d44a512499cf31563ab26 (patch)
tree1d123547ccc047e2cdc3d078a46ad372f47ff6d7 /src
parent795195d9fe76654ff028578a9a95876b1b92dcc1 (diff)
parent241cf3838dcb4a383302cdaa99f13347c7f52f77 (diff)
downloadlibADLMIDI-62a018a1338b807d325d44a512499cf31563ab26.tar.gz
libADLMIDI-62a018a1338b807d325d44a512499cf31563ab26.tar.bz2
libADLMIDI-62a018a1338b807d325d44a512499cf31563ab26.zip
Merge branch 'master' of github.com:Wohlstand/libADLMIDI
Diffstat (limited to 'src')
-rw-r--r--src/adlmidi_opl3.cpp5
-rw-r--r--src/chips/dosbox/dbopl.cpp9
2 files changed, 11 insertions, 3 deletions
diff --git a/src/adlmidi_opl3.cpp b/src/adlmidi_opl3.cpp
index a7bffc3..0df9d4d 100644
--- a/src/adlmidi_opl3.cpp
+++ b/src/adlmidi_opl3.cpp
@@ -29,7 +29,10 @@
#ifdef ADLMIDI_HW_OPL
static const unsigned OPLBase = 0x388;
#else
-# if defined(ADLMIDI_DISABLE_NUKED_EMULATOR) && defined(ADLMIDI_DISABLE_DOSBOX_EMULATOR)
+# if defined(ADLMIDI_DISABLE_NUKED_EMULATOR) && \
+ defined(ADLMIDI_DISABLE_DOSBOX_EMULATOR) && \
+ defined(ADLMIDI_DISABLE_OPAL_EMULATOR) && \
+ defined(ADLMIDI_DISABLE_JAVA_EMULATOR)
# error "No emulators enabled. You must enable at least one emulator to use this library!"
# endif
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 ) {