Skip to content

Commit

Permalink
SHERLOCK: RT: Miles AdLib Driver midi note fix
Browse files Browse the repository at this point in the history
- fixed checking notes for percussion channel, fixes some notes
missing during intro music
- remove currentA0hReg from PhysicalFmVoiceEntry struct, wasn't used
- moved setting virtual FM-voice in-use flag inside releaseFmVoice()
  • Loading branch information
Martin Kiewitz committed Jun 26, 2015
1 parent c167a29 commit 057774f
Showing 1 changed file with 9 additions and 6 deletions.
15 changes: 9 additions & 6 deletions engines/sherlock/tattoo/drivers/tattoo_adlib.cpp
Expand Up @@ -165,6 +165,7 @@ class MidiDriver_Miles_AdLib : public MidiDriver_Emulated {

uint16 currentPriority;

byte currentOriginalMidiNote;
byte currentNote;
int16 currentTransposition;
byte currentVelocity;
Expand All @@ -176,6 +177,7 @@ class MidiDriver_Miles_AdLib : public MidiDriver_Emulated {
currentInstrumentPtr(NULL),
isPhysical(false), physicalFmVoice(0),
currentPriority(0),
currentOriginalMidiNote(0),
currentNote(0),
currentTransposition(0),
currentVelocity(0),
Expand All @@ -187,12 +189,11 @@ class MidiDriver_Miles_AdLib : public MidiDriver_Emulated {
bool inUse;
byte virtualFmVoice;

byte currentA0hReg;
byte currentB0hReg;

PhysicalFmVoiceEntry(): inUse(false),
virtualFmVoice(0),
currentA0hReg(0), currentB0hReg(0) { }
currentB0hReg(0) { }
};

OPL::OPL *_opl;
Expand Down Expand Up @@ -429,7 +430,6 @@ int16 MidiDriver_Miles_AdLib::searchFreePhysicalFmVoiceChannel() {
void MidiDriver_Miles_AdLib::noteOn(byte midiChannel, byte note, byte velocity) {
const InstrumentEntry *instrumentPtr = NULL;

//warning("Note On: channel %d, note %d, velocity %d", midiChannel, note, velocity);
if (velocity == 0) {
noteOff(midiChannel, note);
return;
Expand All @@ -448,6 +448,8 @@ void MidiDriver_Miles_AdLib::noteOn(byte midiChannel, byte note, byte velocity)
return;
}

//warning("Note On: channel %d, note %d, velocity %d, instrument %d/%d", midiChannel, note, velocity, instrumentPtr->bankId, instrumentPtr->patchId);

// look for free virtual FM voice
int16 virtualFmVoice = searchFreeVirtualFmVoiceChannel();

Expand All @@ -471,6 +473,7 @@ void MidiDriver_Miles_AdLib::noteOn(byte midiChannel, byte note, byte velocity)

_virtualFmVoices[virtualFmVoice].inUse = true;
_virtualFmVoices[virtualFmVoice].actualMidiChannel = midiChannel;
_virtualFmVoices[virtualFmVoice].currentOriginalMidiNote = note;
_virtualFmVoices[virtualFmVoice].currentInstrumentPtr = instrumentPtr;
_virtualFmVoices[virtualFmVoice].currentVelocity = velocity;
_virtualFmVoices[virtualFmVoice].isPhysical = false;
Expand Down Expand Up @@ -506,15 +509,14 @@ void MidiDriver_Miles_AdLib::noteOff(byte midiChannel, byte note) {
// Search through all virtual FM-Voices for current midiChannel + note
for (byte virtualFmVoice = 0; virtualFmVoice < SHERLOCK_MILES_ADLIB_VIRTUAL_FMVOICES_COUNT; virtualFmVoice++) {
if (_virtualFmVoices[virtualFmVoice].inUse) {
if ((_virtualFmVoices[virtualFmVoice].actualMidiChannel == midiChannel) && (_virtualFmVoices[virtualFmVoice].currentNote == note)) {
if ((_virtualFmVoices[virtualFmVoice].actualMidiChannel == midiChannel) && (_virtualFmVoices[virtualFmVoice].currentOriginalMidiNote == note)) {
// found one
if (_midiChannels[midiChannel].currentSustain >= 64) {
_virtualFmVoices[virtualFmVoice].sustained = true;
continue;
}
//
releaseFmVoice(virtualFmVoice);
_virtualFmVoices[virtualFmVoice].inUse = false;
}
}
}
Expand Down Expand Up @@ -596,7 +598,6 @@ void MidiDriver_Miles_AdLib::prioritySort() {
//warning("priority old %d, priority new %d", unvoicedHighestPriority, voicedLowestPriority);

releaseFmVoice(voicedLowestFmVoice);
_virtualFmVoices[voicedLowestFmVoice].inUse = false;

// Get some data of the unvoiced highest priority virtual FM Voice
midiChannel = _virtualFmVoices[unvoicedHighestFmVoice].actualMidiChannel;
Expand All @@ -622,6 +623,7 @@ void MidiDriver_Miles_AdLib::prioritySort() {
void MidiDriver_Miles_AdLib::releaseFmVoice(byte virtualFmVoice) {
// virtual Voice not actually played? -> exit
if (!_virtualFmVoices[virtualFmVoice].isPhysical) {
_virtualFmVoices[virtualFmVoice].inUse = false;
return;
}

Expand All @@ -633,6 +635,7 @@ void MidiDriver_Miles_AdLib::releaseFmVoice(byte virtualFmVoice) {

// this virtual FM voice isn't physical anymore
_virtualFmVoices[virtualFmVoice].isPhysical = false;
_virtualFmVoices[virtualFmVoice].inUse = false;

// Remove physical FM-Voice from being active
_physicalFmVoices[physicalFmVoice].inUse = false;
Expand Down

0 comments on commit 057774f

Please sign in to comment.