add a chip playground

in debug menu
This commit is contained in:
tildearrow 2022-02-01 18:08:19 -05:00
parent 3ca7ebd1fc
commit d691ec6d76
30 changed files with 226 additions and 0 deletions

View file

@ -277,6 +277,19 @@ class DivDispatch {
*/ */
std::vector<DivRegWrite>& getRegisterWrites(); std::vector<DivRegWrite>& getRegisterWrites();
/**
* poke a register.
* @param addr address.
* @param val value.
*/
virtual void poke(unsigned int addr, unsigned short val);
/**
* poke a register.
* @param wlist a vector containing DivRegWrites.
*/
virtual void poke(std::vector<DivRegWrite>& wlist);
/** /**
* initialize this DivDispatch. * initialize this DivDispatch.
* @param parent the parent DivEngine. * @param parent the parent DivEngine.

View file

@ -3927,6 +3927,20 @@ bool DivEngine::removeSystem(int index) {
return true; return true;
} }
void DivEngine::poke(int sys, unsigned int addr, unsigned short val) {
if (sys<0 || sys>=song.systemLen) return;
isBusy.lock();
disCont[sys].dispatch->poke(addr,val);
isBusy.unlock();
}
void DivEngine::poke(int sys, std::vector<DivRegWrite>& wlist) {
if (sys<0 || sys>=song.systemLen) return;
isBusy.lock();
disCont[sys].dispatch->poke(wlist);
isBusy.unlock();
}
String DivEngine::getLastError() { String DivEngine::getLastError() {
return lastError; return lastError;
} }

View file

@ -494,6 +494,12 @@ class DivEngine {
// remove system // remove system
bool removeSystem(int index); bool removeSystem(int index);
// write to register on system
void poke(int sys, unsigned int addr, unsigned short val);
// write to register on system
void poke(int sys, std::vector<DivRegWrite>& wlist);
// get last error // get last error
String getLastError(); String getLastError();

View file

@ -78,6 +78,14 @@ std::vector<DivRegWrite>& DivDispatch::getRegisterWrites() {
return regWrites; return regWrites;
} }
void DivDispatch::poke(unsigned int addr, unsigned short val) {
}
void DivDispatch::poke(std::vector<DivRegWrite>& wlist) {
}
int DivDispatch::init(DivEngine* p, int channels, int sugRate, unsigned int flags) { int DivDispatch::init(DivEngine* p, int channels, int sugRate, unsigned int flags) {
return 0; return 0;
} }

View file

@ -728,6 +728,14 @@ void* DivPlatformArcade::getChanState(int ch) {
return &chan[ch]; return &chan[ch];
} }
void DivPlatformArcade::poke(unsigned int addr, unsigned short val) {
immWrite(addr,val);
}
void DivPlatformArcade::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) immWrite(i.addr,i.val);
}
void DivPlatformArcade::reset() { void DivPlatformArcade::reset() {
while (!writes.empty()) writes.pop(); while (!writes.empty()) writes.pop();
if (useYMFM) { if (useYMFM) {

View file

@ -79,6 +79,8 @@ class DivPlatformArcade: public DivDispatch {
void setFlags(unsigned int flags); void setFlags(unsigned int flags);
bool isStereo(); bool isStereo();
void setYMFM(bool use); void setYMFM(bool use);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformArcade(); ~DivPlatformArcade();

View file

@ -368,6 +368,14 @@ void DivPlatformAY8910::notifyInsDeletion(void* ins) {
} }
} }
void DivPlatformAY8910::poke(unsigned int addr, unsigned short val) {
immWrite(addr,val);
}
void DivPlatformAY8910::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) immWrite(i.addr,i.val);
}
void DivPlatformAY8910::setFlags(unsigned int flags) { void DivPlatformAY8910::setFlags(unsigned int flags) {
switch (flags&15) { switch (flags&15) {
case 1: case 1:

View file

@ -65,6 +65,8 @@ class DivPlatformAY8910: public DivDispatch {
bool isStereo(); bool isStereo();
bool keyOffAffectsArp(int ch); bool keyOffAffectsArp(int ch);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
}; };

View file

@ -408,6 +408,14 @@ void DivPlatformAY8930::notifyInsDeletion(void* ins) {
} }
} }
void DivPlatformAY8930::poke(unsigned int addr, unsigned short val) {
immWrite(addr,val);
}
void DivPlatformAY8930::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) immWrite(i.addr,i.val);
}
void DivPlatformAY8930::setFlags(unsigned int flags) { void DivPlatformAY8930::setFlags(unsigned int flags) {
switch (flags&15) { switch (flags&15) {
case 1: case 1:

View file

@ -58,6 +58,8 @@ class DivPlatformAY8930: public DivDispatch {
bool isStereo(); bool isStereo();
bool keyOffAffectsArp(int ch); bool keyOffAffectsArp(int ch);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
}; };

View file

@ -349,6 +349,14 @@ void DivPlatformC64::reset() {
vol=15; vol=15;
} }
void DivPlatformC64::poke(unsigned int addr, unsigned short val) {
rWrite(addr,val);
}
void DivPlatformC64::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) rWrite(i.addr,i.val);
}
void DivPlatformC64::setChipModel(bool is6581) { void DivPlatformC64::setChipModel(bool is6581) {
if (is6581) { if (is6581) {
sid.set_chip_model(MOS6581); sid.set_chip_model(MOS6581);

View file

@ -66,6 +66,8 @@ class DivPlatformC64: public DivDispatch {
void setFlags(unsigned int flags); void setFlags(unsigned int flags);
void notifyInsChange(int ins); void notifyInsChange(int ins);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void setChipModel(bool is6581); void setChipModel(bool is6581);
void quit(); void quit();

View file

@ -349,6 +349,14 @@ void DivPlatformGB::notifyInsDeletion(void* ins) {
} }
} }
void DivPlatformGB::poke(unsigned int addr, unsigned short val) {
immWrite(addr,val);
}
void DivPlatformGB::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) immWrite(i.addr,i.val);
}
int DivPlatformGB::init(DivEngine* p, int channels, int sugRate, unsigned int flags) { int DivPlatformGB::init(DivEngine* p, int channels, int sugRate, unsigned int flags) {
for (int i=0; i<4; i++) { for (int i=0; i<4; i++) {
isMuted[i]=false; isMuted[i]=false;

View file

@ -51,6 +51,8 @@ class DivPlatformGB: public DivDispatch {
void notifyInsChange(int ins); void notifyInsChange(int ins);
void notifyWaveChange(int wave); void notifyWaveChange(int wave);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformGB(); ~DivPlatformGB();

View file

@ -643,6 +643,14 @@ void DivPlatformGenesis::notifyInsDeletion(void* ins) {
psg.notifyInsDeletion(ins); psg.notifyInsDeletion(ins);
} }
void DivPlatformGenesis::poke(unsigned int addr, unsigned short val) {
immWrite(addr,val);
}
void DivPlatformGenesis::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) immWrite(i.addr,i.val);
}
int DivPlatformGenesis::getPortaFloor(int ch) { int DivPlatformGenesis::getPortaFloor(int ch) {
return (ch>5)?12:0; return (ch>5)?12:0;
} }

View file

@ -86,6 +86,8 @@ class DivPlatformGenesis: public DivDispatch {
void notifyInsChange(int ins); void notifyInsChange(int ins);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
int getPortaFloor(int ch); int getPortaFloor(int ch);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformGenesis(); ~DivPlatformGenesis();

View file

@ -397,6 +397,14 @@ void DivPlatformNES::notifyInsDeletion(void* ins) {
} }
} }
void DivPlatformNES::poke(unsigned int addr, unsigned short val) {
rWrite(addr,val);
}
void DivPlatformNES::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) rWrite(i.addr,i.val);
}
int DivPlatformNES::init(DivEngine* p, int channels, int sugRate, unsigned int flags) { int DivPlatformNES::init(DivEngine* p, int channels, int sugRate, unsigned int flags) {
parent=p; parent=p;
apuType=flags; apuType=flags;

View file

@ -54,6 +54,8 @@ class DivPlatformNES: public DivDispatch {
bool keyOffAffectsArp(int ch); bool keyOffAffectsArp(int ch);
void setFlags(unsigned int flags); void setFlags(unsigned int flags);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformNES(); ~DivPlatformNES();

View file

@ -405,6 +405,14 @@ void DivPlatformPCE::setFlags(unsigned int flags) {
rate=chipClock/12; rate=chipClock/12;
} }
void DivPlatformPCE::poke(unsigned int addr, unsigned short val) {
rWrite(addr,val);
}
void DivPlatformPCE::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) rWrite(i.addr,i.val);
}
int DivPlatformPCE::init(DivEngine* p, int channels, int sugRate, unsigned int flags) { int DivPlatformPCE::init(DivEngine* p, int channels, int sugRate, unsigned int flags) {
parent=p; parent=p;
dumpWrites=false; dumpWrites=false;

View file

@ -70,6 +70,8 @@ class DivPlatformPCE: public DivDispatch {
void setFlags(unsigned int flags); void setFlags(unsigned int flags);
void notifyWaveChange(int wave); void notifyWaveChange(int wave);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformPCE(); ~DivPlatformPCE();

View file

@ -322,6 +322,14 @@ void DivPlatformSAA1099::setFlags(unsigned int flags) {
rate=chipClock/32; rate=chipClock/32;
} }
void DivPlatformSAA1099::poke(unsigned int addr, unsigned short val) {
rWrite(addr,val);
}
void DivPlatformSAA1099::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) rWrite(i.addr,i.val);
}
int DivPlatformSAA1099::init(DivEngine* p, int channels, int sugRate, unsigned int flags) { int DivPlatformSAA1099::init(DivEngine* p, int channels, int sugRate, unsigned int flags) {
parent=p; parent=p;
dumpWrites=false; dumpWrites=false;

View file

@ -62,6 +62,8 @@ class DivPlatformSAA1099: public DivDispatch {
int getPortaFloor(int ch); int getPortaFloor(int ch);
bool keyOffAffectsArp(int ch); bool keyOffAffectsArp(int ch);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
}; };

View file

@ -230,6 +230,14 @@ void DivPlatformSMS::notifyInsDeletion(void* ins) {
} }
} }
void DivPlatformSMS::poke(unsigned int addr, unsigned short val) {
rWrite(val);
}
void DivPlatformSMS::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) rWrite(i.val);
}
void DivPlatformSMS::setFlags(unsigned int flags) { void DivPlatformSMS::setFlags(unsigned int flags) {
if ((flags&3)==2) { if ((flags&3)==2) {
chipClock=4000000; chipClock=4000000;

View file

@ -48,6 +48,8 @@ class DivPlatformSMS: public DivDispatch {
int getPortaFloor(int ch); int getPortaFloor(int ch);
void setFlags(unsigned int flags); void setFlags(unsigned int flags);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformSMS(); ~DivPlatformSMS();

View file

@ -254,6 +254,14 @@ void DivPlatformTIA::notifyInsDeletion(void* ins) {
} }
} }
void DivPlatformTIA::poke(unsigned int addr, unsigned short val) {
rWrite(addr,val);
}
void DivPlatformTIA::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) rWrite(i.addr,i.val);
}
void DivPlatformTIA::setFlags(unsigned int flags) { void DivPlatformTIA::setFlags(unsigned int flags) {
if (flags&1) { if (flags&1) {
rate=31250; rate=31250;

View file

@ -35,6 +35,8 @@ class DivPlatformTIA: public DivDispatch {
bool isStereo(); bool isStereo();
bool keyOffAffectsArp(int ch); bool keyOffAffectsArp(int ch);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
}; };

View file

@ -721,6 +721,14 @@ void* DivPlatformYM2610::getChanState(int ch) {
return &chan[ch]; return &chan[ch];
} }
void DivPlatformYM2610::poke(unsigned int addr, unsigned short val) {
immWrite(addr,val);
}
void DivPlatformYM2610::poke(std::vector<DivRegWrite>& wlist) {
for (DivRegWrite& i: wlist) immWrite(i.addr,i.val);
}
void DivPlatformYM2610::reset() { void DivPlatformYM2610::reset() {
while (!writes.empty()) writes.pop(); while (!writes.empty()) writes.pop();
if (dumpWrites) { if (dumpWrites) {

View file

@ -77,6 +77,8 @@ class DivPlatformYM2610: public DivDispatch {
bool keyOffAffectsArp(int ch); bool keyOffAffectsArp(int ch);
void notifyInsChange(int ins); void notifyInsChange(int ins);
void notifyInsDeletion(void* ins); void notifyInsDeletion(void* ins);
void poke(unsigned int addr, unsigned short val);
void poke(std::vector<DivRegWrite>& wlist);
int init(DivEngine* parent, int channels, int sugRate, unsigned int flags); int init(DivEngine* parent, int channels, int sugRate, unsigned int flags);
void quit(); void quit();
~DivPlatformYM2610(); ~DivPlatformYM2610();

View file

@ -3246,6 +3246,68 @@ void FurnaceGUI::drawDebug() {
ImGui::Columns(); ImGui::Columns();
ImGui::TreePop(); ImGui::TreePop();
} }
if (ImGui::TreeNode("Playground")) {
if (pgSys<0 || pgSys>=e->song.systemLen) pgSys=0;
if (ImGui::BeginCombo("System",fmt::sprintf("%d. %s",pgSys+1,e->getSystemName(e->song.system[pgSys])).c_str())) {
for (int i=0; i<e->song.systemLen; i++) {
if (ImGui::Selectable(fmt::sprintf("%d. %s",i+1,e->getSystemName(e->song.system[i])).c_str())) {
pgSys=i;
break;
}
}
ImGui::EndCombo();
}
ImGui::Text("Program");
if (pgProgram.empty()) {
ImGui::Text("-nothing here-");
} else {
char id[32];
for (size_t index=0; index<pgProgram.size(); index++) {
DivRegWrite& i=pgProgram[index];
snprintf(id,31,"pgw%ld",index);
ImGui::PushID(id);
ImGui::SetNextItemWidth(100.0f*dpiScale);
ImGui::InputScalar("##PAddress",ImGuiDataType_U32,&i.addr,NULL,NULL,"%.2X",ImGuiInputTextFlags_CharsHexadecimal);
ImGui::SameLine();
ImGui::Text("=");
ImGui::SameLine();
ImGui::SetNextItemWidth(100.0f*dpiScale);
ImGui::InputScalar("##PValue",ImGuiDataType_U16,&i.val,NULL,NULL,"%.2X",ImGuiInputTextFlags_CharsHexadecimal);
ImGui::SameLine();
if (ImGui::Button(ICON_FA_TIMES "##PRemove")) {
pgProgram.erase(pgProgram.begin()+index);
index--;
}
ImGui::PopID();
}
}
if (ImGui::Button("Execute")) {
e->poke(pgSys,pgProgram);
}
ImGui::SameLine();
if (ImGui::Button("Clear")) {
pgProgram.clear();
}
ImGui::Text("Address");
ImGui::SameLine();
ImGui::SetNextItemWidth(100.0f*dpiScale);
ImGui::InputInt("##PAddress",&pgAddr,0,0,ImGuiInputTextFlags_CharsHexadecimal);
ImGui::SameLine();
ImGui::Text("Value");
ImGui::SameLine();
ImGui::SetNextItemWidth(100.0f*dpiScale);
ImGui::InputInt("##PValue",&pgVal,0,0,ImGuiInputTextFlags_CharsHexadecimal);
ImGui::SameLine();
if (ImGui::Button("Write")) {
e->poke(pgSys,pgAddr,pgVal);
}
ImGui::SameLine();
if (ImGui::Button("Add")) {
pgProgram.push_back(DivRegWrite(pgAddr,pgVal));
}
ImGui::TreePop();
}
if (ImGui::TreeNode("Settings")) { if (ImGui::TreeNode("Settings")) {
if (ImGui::Button("Sync")) syncSettings(); if (ImGui::Button("Sync")) syncSettings();
ImGui::SameLine(); ImGui::SameLine();

View file

@ -256,6 +256,9 @@ class FurnaceGUI {
FurnaceGUIWindows curWindow; FurnaceGUIWindows curWindow;
float peak[2]; float peak[2];
std::vector<DivRegWrite> pgProgram;
int pgSys, pgAddr, pgVal;
struct ActiveNote { struct ActiveNote {
int chan; int chan;
int note; int note;