mirror of
https://github.com/tildearrow/furnace.git
synced 2025-01-06 23:51:21 +00:00
OPL: it's coming together
This commit is contained in:
parent
36db137e8f
commit
bd00165ded
2 changed files with 6 additions and 6 deletions
|
@ -39,7 +39,7 @@ void DivInstrument::putInsData(SafeWriter* w) {
|
||||||
w->writeC(fm.fb);
|
w->writeC(fm.fb);
|
||||||
w->writeC(fm.fms);
|
w->writeC(fm.fms);
|
||||||
w->writeC(fm.ams);
|
w->writeC(fm.ams);
|
||||||
w->writeC(4); // operator count; always 4
|
w->writeC(fm.ops);
|
||||||
w->writeC(fm.opllPreset);
|
w->writeC(fm.opllPreset);
|
||||||
w->writeC(0); // reserved
|
w->writeC(0); // reserved
|
||||||
w->writeC(0);
|
w->writeC(0);
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
#define rWrite(a,v) if (!skipRegisterWrites) {pendingWrites[a]=v;}
|
#define rWrite(a,v) if (!skipRegisterWrites) {pendingWrites[a]=v;}
|
||||||
#define immWrite(a,v) if (!skipRegisterWrites) {writes.emplace(a,v); if (dumpWrites) {addWrite(a,v);} }
|
#define immWrite(a,v) if (!skipRegisterWrites) {writes.emplace(a,v); if (dumpWrites) {addWrite(a,v);} }
|
||||||
|
|
||||||
#define CHIP_FREQBASE 4720272
|
#define CHIP_FREQBASE 9440540
|
||||||
|
|
||||||
// N = invalid
|
// N = invalid
|
||||||
#define N 255
|
#define N 255
|
||||||
|
@ -193,7 +193,7 @@ void DivPlatformOPL::acquire_nuked(short* bufL, short* bufR, size_t start, size_
|
||||||
for (size_t h=start; h<start+len; h++) {
|
for (size_t h=start; h<start+len; h++) {
|
||||||
os[0]=0; os[1]=0;
|
os[0]=0; os[1]=0;
|
||||||
if (!writes.empty() && --delay<0) {
|
if (!writes.empty() && --delay<0) {
|
||||||
delay=12;
|
delay=1;
|
||||||
QueuedWrite& w=writes.front();
|
QueuedWrite& w=writes.front();
|
||||||
OPL3_WriteReg(&fm,w.addr,w.val);
|
OPL3_WriteReg(&fm,w.addr,w.val);
|
||||||
regPool[w.addr&511]=w.val;
|
regPool[w.addr&511]=w.val;
|
||||||
|
@ -363,7 +363,7 @@ void DivPlatformOPL::tick() {
|
||||||
for (int i=0; i<20; i++) {
|
for (int i=0; i<20; i++) {
|
||||||
if (chan[i].freqChanged) {
|
if (chan[i].freqChanged) {
|
||||||
chan[i].freq=parent->calcFreq(chan[i].baseFreq,chan[i].pitch,false,octave(chan[i].baseFreq));
|
chan[i].freq=parent->calcFreq(chan[i].baseFreq,chan[i].pitch,false,octave(chan[i].baseFreq));
|
||||||
if (chan[i].freq>262143) chan[i].freq=262143;
|
if (chan[i].freq>131071) chan[i].freq=131071;
|
||||||
int freqt=toFreq(chan[i].freq);
|
int freqt=toFreq(chan[i].freq);
|
||||||
chan[i].freqH=freqt>>8;
|
chan[i].freqH=freqt>>8;
|
||||||
chan[i].freqL=freqt&0xff;
|
chan[i].freqL=freqt&0xff;
|
||||||
|
@ -851,10 +851,10 @@ void DivPlatformOPL::setFlags(unsigned int flags) {
|
||||||
|
|
||||||
if (oplType==3) {
|
if (oplType==3) {
|
||||||
chipClock=COLOR_NTSC*4.0;
|
chipClock=COLOR_NTSC*4.0;
|
||||||
rate=chipClock/36;
|
rate=chipClock/288;
|
||||||
} else {
|
} else {
|
||||||
chipClock=COLOR_NTSC;
|
chipClock=COLOR_NTSC;
|
||||||
rate=chipClock/9;
|
rate=chipClock/72;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue