GA20: excellent...

This commit is contained in:
tildearrow 2025-03-02 19:34:52 -05:00
parent f13824525a
commit 2c75555fae
4 changed files with 54 additions and 5 deletions

View file

@ -93,6 +93,52 @@ void DivPlatformGA20::acquire(short** buf, size_t len) {
}
}
void DivPlatformGA20::acquireDirect(blip_buffer_t** bb, size_t off, size_t len) {
if (ga20BufLen<len) {
ga20BufLen=len;
for (int i=0; i<4; i++) {
delete[] ga20Buf[i];
ga20Buf[i]=new short[ga20BufLen];
}
}
for (int i=0; i<4; i++) {
oscBuf[i]->begin(len);
}
for (size_t h=off; h<off+len; h++) {
if ((--delay)<=0) {
delay=MAX(0,delay);
if (!writes.empty()) {
QueuedWrite& w=writes.front();
ga20.write(w.addr,w.val);
regPool[w.addr]=w.val;
writes.pop();
delay=1;
}
}
short *buffer[4]={
&ga20Buf[0][h],
&ga20Buf[1][h],
&ga20Buf[2][h],
&ga20Buf[3][h]
};
ga20.sound_stream_update(buffer,1);
const int out=(signed int)(ga20Buf[0][h]+ga20Buf[1][h]+ga20Buf[2][h]+ga20Buf[3][h])>>2;
if (out!=oldOut) {
blip_add_delta(bb[0],h,out-oldOut);
oldOut=out;
}
for (int i=0; i<4; i++) {
oscBuf[i]->putSample(h,ga20Buf[i][h]>>1);
}
}
for (int i=0; i<4; i++) {
oscBuf[i]->end(len);
}
}
u8 DivPlatformGA20::read_byte(u32 address) {
if ((sampleMem!=NULL) && (address<0x100000)) {
return sampleMem[address&0xfffff];
@ -375,6 +421,7 @@ void DivPlatformGA20::reset() {
memset(regPool,0,32);
ga20.device_reset();
delay=0;
oldOut=0;
for (int i=0; i<4; i++) {
chan[i]=DivPlatformGA20::Channel();
chan[i].std.setEngine(parent);
@ -385,6 +432,10 @@ void DivPlatformGA20::reset() {
}
}
bool DivPlatformGA20::hasAcquireDirect() {
return true;
}
int DivPlatformGA20::getOutputCount() {
return 1;
}

View file

@ -59,6 +59,7 @@ class DivPlatformGA20: public DivDispatch, public iremga20_intf {
bool sampleLoaded[256];
int delay;
int oldOut;
short* ga20Buf[4];
size_t ga20BufLen;
@ -74,6 +75,7 @@ class DivPlatformGA20: public DivDispatch, public iremga20_intf {
void chWrite(unsigned char ch, unsigned int addr, unsigned char val);
public:
virtual u8 read_byte(u32 address) override;
virtual void acquireDirect(blip_buffer_t** bb, size_t off, size_t len) override;
virtual void acquire(short** buf, size_t len) override;
virtual int dispatch(DivCommand c) override;
virtual void* getChanState(int chan) override;
@ -86,6 +88,7 @@ class DivPlatformGA20: public DivDispatch, public iremga20_intf {
virtual void forceIns() override;
virtual void tick(bool sysTick=true) override;
virtual void muteChannel(int ch, bool mute) override;
virtual bool hasAcquireDirect() override;
virtual int getOutputCount() override;
virtual void notifyInsChange(int ins) override;
virtual void notifyWaveChange(int wave) override;

View file

@ -650,10 +650,6 @@ bool DivPlatformPCSpeaker::hasAcquireDirect() {
return (speakerType==0 || speakerType==3);
}
bool DivPlatformPCSpeaker::isOscBufPositional() {
return (speakerType==0 || speakerType==3);
}
void DivPlatformPCSpeaker::setFlags(const DivConfig& flags) {
switch (flags.getInt("clockSel",0)) {
case 1: // PC-98

View file

@ -88,7 +88,6 @@ class DivPlatformPCSpeaker: public DivDispatch {
void muteChannel(int ch, bool mute);
bool keyOffAffectsArp(int ch);
bool hasAcquireDirect();
bool isOscBufPositional();
void setFlags(const DivConfig& flags);
void notifyInsDeletion(void* ins);
void notifyPlaybackStop();