[PATCH 2/6] wineoss: Add the leading 0xf0 to the sysex data.
Huw Davies
huw at codeweavers.com
Thu Apr 28 02:20:53 CDT 2022
Signed-off-by: Huw Davies <huw at codeweavers.com>
---
dlls/wineoss.drv/midi.c | 14 +++++---------
1 file changed, 5 insertions(+), 9 deletions(-)
diff --git a/dlls/wineoss.drv/midi.c b/dlls/wineoss.drv/midi.c
index 4da7a606248..d8cf3346a9c 100644
--- a/dlls/wineoss.drv/midi.c
+++ b/dlls/wineoss.drv/midi.c
@@ -228,10 +228,12 @@ static void midReceiveChar(WORD wDevID, unsigned char value, DWORD dwTime)
return;
}
- if (MidiInDev[wDevID].state & 2) { /* system exclusive */
+ if (value == 0xf0 || MidiInDev[wDevID].state & 2) { /* system exclusive */
LPMIDIHDR lpMidiHdr;
BOOL sbfb = FALSE;
+ MidiInDev[wDevID].state |= 2;
+ MidiInDev[wDevID].incLen = 0;
in_buffer_lock();
if ((lpMidiHdr = MidiInDev[wDevID].lpQueueHdr) != NULL) {
LPBYTE lpData = (LPBYTE) lpMidiHdr->lpData;
@@ -300,14 +302,8 @@ static void midReceiveChar(WORD wDevID, unsigned char value, DWORD dwTime)
}
break;
case MIDI_SYSTEM_PREFIX:
- if (MidiInDev[wDevID].incoming[0] == 0xF0) {
- MidiInDev[wDevID].state |= 2;
- MidiInDev[wDevID].incLen = 0;
- } else {
- if (MidiInDev[wDevID].incLen == 1) {
- toSend = (MidiInDev[wDevID].incoming[0] << 0);
- }
- }
+ if (MidiInDev[wDevID].incLen == 1)
+ toSend = (MidiInDev[wDevID].incoming[0] << 0);
break;
default:
WARN("This shouldn't happen (%02X)\n", MidiInDev[wDevID].incoming[0]);
--
2.25.1
More information about the wine-devel
mailing list