parent
7c9beca93f
commit
f29d4bce1b
|
@ -586,6 +586,16 @@ int DivPlatformArcade::dispatch(DivCommand c) {
|
||||||
rWrite(0x1b,c.value&3);
|
rWrite(0x1b,c.value&3);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case DIV_CMD_FM_FB: {
|
||||||
|
if (c.chan>7) break;
|
||||||
|
chan[c.chan].state.fb=c.value&7;
|
||||||
|
if (isMuted[c.chan]) {
|
||||||
|
rWrite(chanOffs[c.chan]+ADDR_LR_FB_ALG,(chan[c.chan].state.alg&7)|(chan[c.chan].state.fb<<3));
|
||||||
|
} else {
|
||||||
|
rWrite(chanOffs[c.chan]+ADDR_LR_FB_ALG,(chan[c.chan].state.alg&7)|(chan[c.chan].state.fb<<3)|((chan[c.chan].chVolL&1)<<6)|((chan[c.chan].chVolR&1)<<7));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case DIV_CMD_FM_MULT: {
|
case DIV_CMD_FM_MULT: {
|
||||||
if (c.chan>7) break;
|
if (c.chan>7) break;
|
||||||
unsigned short baseAddr=chanOffs[c.chan]|opOffs[orderedOps[c.value]];
|
unsigned short baseAddr=chanOffs[c.chan]|opOffs[orderedOps[c.value]];
|
||||||
|
|
|
@ -483,6 +483,11 @@ int DivPlatformGenesis::dispatch(DivCommand c) {
|
||||||
rWrite(0x22,lfoValue);
|
rWrite(0x22,lfoValue);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case DIV_CMD_FM_FB: {
|
||||||
|
chan[c.chan].state.fb=c.value&7;
|
||||||
|
rWrite(chanOffs[c.chan]+ADDR_FB_ALG,(chan[c.chan].state.alg&7)|(chan[c.chan].state.fb<<3));
|
||||||
|
break;
|
||||||
|
}
|
||||||
case DIV_CMD_FM_MULT: {
|
case DIV_CMD_FM_MULT: {
|
||||||
unsigned short baseAddr=chanOffs[c.chan]|opOffs[orderedOps[c.value]];
|
unsigned short baseAddr=chanOffs[c.chan]|opOffs[orderedOps[c.value]];
|
||||||
DivInstrumentFM::Operator& op=chan[c.chan].state.op[orderedOps[c.value]];
|
DivInstrumentFM::Operator& op=chan[c.chan].state.op[orderedOps[c.value]];
|
||||||
|
|
|
@ -552,6 +552,12 @@ int DivPlatformYM2610::dispatch(DivCommand c) {
|
||||||
rWrite(0x22,(c.value&7)|((c.value>>4)<<3));
|
rWrite(0x22,(c.value&7)|((c.value>>4)<<3));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case DIV_CMD_FM_FB: {
|
||||||
|
if (c.chan>3) break;
|
||||||
|
chan[c.chan].state.fb=c.value&7;
|
||||||
|
rWrite(chanOffs[c.chan]+ADDR_FB_ALG,(chan[c.chan].state.alg&7)|(chan[c.chan].state.fb<<3));
|
||||||
|
break;
|
||||||
|
}
|
||||||
case DIV_CMD_FM_MULT: {
|
case DIV_CMD_FM_MULT: {
|
||||||
if (c.chan>3) break;
|
if (c.chan>3) break;
|
||||||
unsigned short baseAddr=chanOffs[c.chan]|opOffs[orderedOps[c.value]];
|
unsigned short baseAddr=chanOffs[c.chan]|opOffs[orderedOps[c.value]];
|
||||||
|
|
Loading…
Reference in New Issue