diff options
author | Ruediger Hanke | 2003-07-22 22:30:16 +0000 |
---|---|---|
committer | Ruediger Hanke | 2003-07-22 22:30:16 +0000 |
commit | 5c9ebd053e3dfdbabb9e1e563570b4174b28126e (patch) | |
tree | 3dbda0e1d6812f1c696423491c9eb0b6142b70e7 /backends/midi/morphos.cpp | |
parent | 2becb78d8681ca6bf80ad50c8f669e07237ad36f (diff) | |
download | scummvm-rg350-5c9ebd053e3dfdbabb9e1e563570b4174b28126e.tar.gz scummvm-rg350-5c9ebd053e3dfdbabb9e1e563570b4174b28126e.tar.bz2 scummvm-rg350-5c9ebd053e3dfdbabb9e1e563570b4174b28126e.zip |
Some MorphOS port fixes
svn-id: r9136
Diffstat (limited to 'backends/midi/morphos.cpp')
-rw-r--r-- | backends/midi/morphos.cpp | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/backends/midi/morphos.cpp b/backends/midi/morphos.cpp index 20dd409fca..f84861f039 100644 --- a/backends/midi/morphos.cpp +++ b/backends/midi/morphos.cpp @@ -100,6 +100,11 @@ int MidiDriver_MPU401::midi_driver_thread(void *param) MsgPort *music_timer_port = NULL; timerequest *music_timer_request = NULL; + // Grab the MidiDriver's mutex. When the MidiDriver + // shuts down, it will wait on that mutex until we've + // detected the shutdown and quit looping. + g_system->lock_mutex(mid->_mutex); + ObtainSemaphore(&ScummMusicThreadRunning); if (!OSystem_MorphOS::OpenATimer(&music_timer_port, (IORequest **) &music_timer_request, UNIT_MICROHZ, false)) { @@ -109,26 +114,29 @@ int MidiDriver_MPU401::midi_driver_thread(void *param) else { old_time = g_system->get_msecs(); - for (;;) { + while (mid->_started_thread) { music_timer_request->tr_node.io_Command = TR_ADDREQUEST; music_timer_request->tr_time.tv_secs = 0; music_timer_request->tr_time.tv_micro = 10000; DoIO((struct IORequest *)music_timer_request); - if (CheckSignal(SIGBREAKF_CTRL_C)) + if (!mid->_started_thread || CheckSignal(SIGBREAKF_CTRL_C)) break; cur_time = g_system->get_msecs(); while (old_time < cur_time) { old_time += 10; if (mid->_timer_proc) - (*(mid->_timer_proc)) (mid->_timer_param); + (*(mid->_timer_proc))(mid->_timer_param); } } + CloseDevice((IORequest *) music_timer_request); + DeleteIORequest((IORequest *) music_timer_request); + DeleteMsgPort(music_timer_port); } ReleaseSemaphore(&ScummMusicThreadRunning); - RemTask(NULL); + g_system->unlock_mutex(mid->_mutex); return 0; } |