[PATCH v2 2/6] wineoss: Add the leading 0xf0 to the sysex data.

Andrew Eikum aeikum at codeweavers.com
Thu Apr 28 08:50:11 CDT 2022


From: Huw Davies <huw at codeweavers.com>

Signed-off-by: Huw Davies <huw at codeweavers.com>
Signed-off-by: Andrew Eikum <aeikum 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 1a5b348da9f..462fd3625f0 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.36.0





More information about the wine-devel mailing list