--- np2/sound/vermouth/midiout.c 2003/12/01 04:01:42 1.5 +++ np2/sound/vermouth/midiout.c 2003/12/24 19:15:51 1.6 @@ -616,6 +616,7 @@ static void allresetmidi(MIDIHDL midi) { CHANNEL chterm; UINT flag; + midi->master = 127; ch = midi->channel; chterm = ch + 16; ZeroMemory(ch, sizeof(_CHANNEL) * 16); @@ -661,7 +662,7 @@ MIDIHDL midiout_create(MIDIMOD module, U ret->samprate = module->samprate; ret->worksize = worksize; ret->module = module; - ret->master = 127; + // ret->master = 127; ret->bank0[0] = module->tone[0]; ret->bank0[1] = module->tone[1]; ret->sampbuf = (SINT32 *)(ret + 1); @@ -731,14 +732,48 @@ void midiout_shortmsg(MIDIHDL hdl, UINT3 } } +static void longmsg_gm(MIDIHDL hdl, const BYTE *msg, UINT size) { + + if ((size > 5) && (msg[2] == 0x7f) && (msg[3] == 0x09)) { + allresetmidi(hdl); // GM reset + } +} + +static void longmsg_roland(MIDIHDL hdl, const BYTE *msg, UINT size) { + + UINT addr; + + if ((size > 10) && (msg[2] == 0x10) && + (msg[3] == 0x42) && (msg[4] == 0x12)) { // GS data set + addr = (msg[5] << 16) + (msg[6] << 8) + msg[7]; + if ((addr & (~0x400000)) == 0x7f) { // GS reset + allresetmidi(hdl); + TRACEOUT(("GS-Reset")); + } + else if (addr == 0x400004) { // Vol + hdl->master = msg[8] & 0x7f; + allvolupdate(hdl); + } + else { + TRACEOUT(("Roland GS - %.6x", addr)); + } + } +} + void midiout_longmsg(MIDIHDL hdl, const BYTE *msg, UINT size) { + UINT id; + if ((hdl == NULL) || (msg == NULL)) { return; } - if ((size > 5) && (msg[1] == 0x7e)) { // GM - if ((msg[2] == 0x7f) && (msg[3] == 0x09)) { - allresetmidi(hdl); // GM reset + if (size > 3) { // (msg[size - 1] == 0xf7) + id = msg[1]; + if (id == 0x7e) { // GM + longmsg_gm(hdl, msg, size); + } + else if (id == 0x41) { // Roland + longmsg_roland(hdl, msg, size); } } }