aboutsummaryrefslogtreecommitdiff
path: root/sound/mididrv.cpp
diff options
context:
space:
mode:
authorRuediger Hanke2002-08-22 12:09:06 +0000
committerRuediger Hanke2002-08-22 12:09:06 +0000
commit3b090517279b66254f5fba7bc6a3299405763295 (patch)
treeaa8f0ddd5fb5c5ee5cc8d5c35064aa8eb6273267 /sound/mididrv.cpp
parent31f6833f87da3af3c480d0b6e605c3565efef1d0 (diff)
downloadscummvm-rg350-3b090517279b66254f5fba7bc6a3299405763295.tar.gz
scummvm-rg350-3b090517279b66254f5fba7bc6a3299405763295.tar.bz2
scummvm-rg350-3b090517279b66254f5fba7bc6a3299405763295.zip
Changed MorphOS MIDI code so that data sent from different threads are no longer a problem. Ensure Midi driver is closed, otherwise no other MIDI application will run after ScummVM has exited.
svn-id: r4801
Diffstat (limited to 'sound/mididrv.cpp')
-rw-r--r--sound/mididrv.cpp12
1 files changed, 6 insertions, 6 deletions
diff --git a/sound/mididrv.cpp b/sound/mididrv.cpp
index c261395c39..c7825673a5 100644
--- a/sound/mididrv.cpp
+++ b/sound/mididrv.cpp
@@ -292,8 +292,9 @@ MidiDriver *MidiDriver_WIN_create()
#include <clib/alib_protos.h>
#include <proto/exec.h>
+#include <proto/amidi.h>
-extern struct IOMidiRequest *ScummMidiRequest;
+#include "morphos_sound.h"
/* MorphOS MIDI driver */
class MidiDriver_AMIDI:public MidiDriver {
@@ -319,11 +320,13 @@ void MidiDriver_AMIDI::set_stream_callback(void *param, StreamCallback *sc)
int MidiDriver_AMIDI::open(int mode)
{
_mode = mode;
+ init_morphos_music(0);
return 0;
}
void MidiDriver_AMIDI::close()
{
+ exit_morphos_music();
_mode = 0;
}
@@ -333,11 +336,8 @@ void MidiDriver_AMIDI::send(uint32 b)
error("MidiDriver_AMIDI:send called but driver is not in simple mode");
if (ScummMidiRequest) {
- ULONG midi_data = b; // you never know about an int's size ;-)
- ScummMidiRequest->amr_Std.io_Command = CMD_WRITE;
- ScummMidiRequest->amr_Std.io_Data = &midi_data;
- ScummMidiRequest->amr_Std.io_Length = 4;
- DoIO((struct IORequest *)ScummMidiRequest);
+ ULONG midi_data = READ_LE_UINT32(&b);
+ SendShortMidiMsg(ScummMidiRequest, midi_data);
}
}