mirror of https://github.com/stella-emu/stella.git
added TIA randomization (see #126), TODO: doc
This commit is contained in:
parent
8563d8d793
commit
8da2766264
|
@ -208,6 +208,7 @@ Settings::Settings()
|
||||||
setPermanent("plr.bankrandom", "false");
|
setPermanent("plr.bankrandom", "false");
|
||||||
setPermanent("plr.ramrandom", "true");
|
setPermanent("plr.ramrandom", "true");
|
||||||
setPermanent("plr.cpurandom", "AXYP");
|
setPermanent("plr.cpurandom", "AXYP");
|
||||||
|
setPermanent("plr.tiarandom", "true");
|
||||||
setPermanent("plr.colorloss", "false");
|
setPermanent("plr.colorloss", "false");
|
||||||
setPermanent("plr.tv.jitter", "true");
|
setPermanent("plr.tv.jitter", "true");
|
||||||
setPermanent("plr.tv.jitter_recovery", "10");
|
setPermanent("plr.tv.jitter_recovery", "10");
|
||||||
|
@ -227,6 +228,7 @@ Settings::Settings()
|
||||||
setPermanent("dev.bankrandom", "true");
|
setPermanent("dev.bankrandom", "true");
|
||||||
setPermanent("dev.ramrandom", "true");
|
setPermanent("dev.ramrandom", "true");
|
||||||
setPermanent("dev.cpurandom", "SAXYP");
|
setPermanent("dev.cpurandom", "SAXYP");
|
||||||
|
setPermanent("dev.tiarandom", "true");
|
||||||
setPermanent("dev.colorloss", "true");
|
setPermanent("dev.colorloss", "true");
|
||||||
setPermanent("dev.tv.jitter", "true");
|
setPermanent("dev.tv.jitter", "true");
|
||||||
setPermanent("dev.tv.jitter_recovery", "2");
|
setPermanent("dev.tv.jitter_recovery", "2");
|
||||||
|
@ -677,8 +679,8 @@ void Settings::usage() const
|
||||||
<< " handling and RAM initialization\n"
|
<< " handling and RAM initialization\n"
|
||||||
<< " -plr.bankrandom <1|0> Randomize the startup bank on reset\n"
|
<< " -plr.bankrandom <1|0> Randomize the startup bank on reset\n"
|
||||||
<< " -plr.ramrandom <1|0> Randomize the contents of RAM on reset\n"
|
<< " -plr.ramrandom <1|0> Randomize the contents of RAM on reset\n"
|
||||||
<< " -plr.cpurandom <1|0> Randomize the contents of CPU registers on\n"
|
<< " -plr.tiarandom <1|0> Randomize the TIA registers on reset\n"
|
||||||
<< " reset\n"
|
<< " -plr.ramrandom <1|0> Randomize the contents of RAM on reset\n"
|
||||||
<< " -plr.debugcolors <1|0> Enable debug colors\n"
|
<< " -plr.debugcolors <1|0> Enable debug colors\n"
|
||||||
<< " -plr.colorloss <1|0> Enable PAL color-loss effect\n"
|
<< " -plr.colorloss <1|0> Enable PAL color-loss effect\n"
|
||||||
<< " -plr.tv.jitter <1|0> Enable TV jitter effect\n"
|
<< " -plr.tv.jitter <1|0> Enable TV jitter effect\n"
|
||||||
|
@ -695,6 +697,7 @@ void Settings::usage() const
|
||||||
<< " -dev.ramrandom <1|0> Randomize the contents of RAM on reset\n"
|
<< " -dev.ramrandom <1|0> Randomize the contents of RAM on reset\n"
|
||||||
<< " -dev.cpurandom <1|0> Randomize the contents of CPU registers on\n"
|
<< " -dev.cpurandom <1|0> Randomize the contents of CPU registers on\n"
|
||||||
<< " reset\n"
|
<< " reset\n"
|
||||||
|
<< " -dev.tiarandom <1|0> Randomize the TIA registers on reset\n"
|
||||||
<< " -dev.debugcolors <1|0> Enable debug colors\n"
|
<< " -dev.debugcolors <1|0> Enable debug colors\n"
|
||||||
<< " -dev.colorloss <1|0> Enable PAL color-loss effect\n"
|
<< " -dev.colorloss <1|0> Enable PAL color-loss effect\n"
|
||||||
<< " -dev.tv.jitter <1|0> Enable TV jitter effect\n"
|
<< " -dev.tv.jitter <1|0> Enable TV jitter effect\n"
|
||||||
|
|
|
@ -198,6 +198,15 @@ void TIA::reset()
|
||||||
// Simply call initialize(); mostly to get around calling a virtual method
|
// Simply call initialize(); mostly to get around calling a virtual method
|
||||||
// from the constructor
|
// from the constructor
|
||||||
initialize();
|
initialize();
|
||||||
|
|
||||||
|
if(myRandomize)
|
||||||
|
for(uInt32 i = 0; i < 0x10000; ++i)
|
||||||
|
{
|
||||||
|
uInt16 address = mySystem->randGenerator().next() & 0x3F;
|
||||||
|
uInt8 value = mySystem->randGenerator().next();
|
||||||
|
poke(address, value);
|
||||||
|
cycle(2); // process delay queue
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -956,6 +965,7 @@ void TIA::applyDeveloperSettings()
|
||||||
setBlSwapDelay(false);
|
setBlSwapDelay(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
myRandomize = mySettings.getBool(devSettings ? "dev.tiarandom" : "plr.tiarandom");
|
||||||
myTIAPinsDriven = devSettings ? mySettings.getBool("dev.tiadriven") : false;
|
myTIAPinsDriven = devSettings ? mySettings.getBool("dev.tiadriven") : false;
|
||||||
|
|
||||||
myEnableJitter = mySettings.getBool(devSettings ? "dev.tv.jitter" : "plr.tv.jitter");
|
myEnableJitter = mySettings.getBool(devSettings ? "dev.tv.jitter" : "plr.tv.jitter");
|
||||||
|
|
|
@ -819,6 +819,11 @@ class TIA : public Device
|
||||||
// Frames since the last time a frame was rendered to the render buffer
|
// Frames since the last time a frame was rendered to the render buffer
|
||||||
uInt32 myFramesSinceLastRender{0};
|
uInt32 myFramesSinceLastRender{0};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setting this to true randomizes TIA on reset.
|
||||||
|
*/
|
||||||
|
bool myRandomize{false};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Setting this to true injects random values into undefined reads.
|
* Setting this to true injects random values into undefined reads.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -145,11 +145,15 @@ void DeveloperDialog::addEmulationTab(const GUI::Font& font)
|
||||||
myRandomBankWidget->setToolTip("Randomize the startup bank for\n"
|
myRandomBankWidget->setToolTip("Randomize the startup bank for\n"
|
||||||
"most classic bankswitching types.");
|
"most classic bankswitching types.");
|
||||||
wid.push_back(myRandomBankWidget);
|
wid.push_back(myRandomBankWidget);
|
||||||
|
|
||||||
|
myRandomizeTIAWidget = new CheckboxWidget(myTab, font, myRandomBankWidget->getRight() + fontWidth * 2, ypos + 1,
|
||||||
|
"Randomize TIA");
|
||||||
|
wid.push_back(myRandomizeTIAWidget);
|
||||||
ypos += lineHeight + VGAP;
|
ypos += lineHeight + VGAP;
|
||||||
|
|
||||||
// Randomize RAM
|
// Randomize RAM
|
||||||
myRandomizeRAMWidget = new CheckboxWidget(myTab, font, HBORDER + INDENT * 2, ypos + 1,
|
myRandomizeRAMWidget = new CheckboxWidget(myTab, font, HBORDER + INDENT * 2, ypos + 1,
|
||||||
"Randomize zero-page and extended RAM", kRandRAMID);
|
"Randomize zero-page and extended RAM");
|
||||||
wid.push_back(myRandomizeRAMWidget);
|
wid.push_back(myRandomizeRAMWidget);
|
||||||
ypos += lineHeight + VGAP;
|
ypos += lineHeight + VGAP;
|
||||||
|
|
||||||
|
@ -162,7 +166,7 @@ void DeveloperDialog::addEmulationTab(const GUI::Font& font)
|
||||||
for(int i = 0; i < 5; ++i)
|
for(int i = 0; i < 5; ++i)
|
||||||
{
|
{
|
||||||
myRandomizeCPUWidget[i] = new CheckboxWidget(myTab, font, xpos, ypos + 1,
|
myRandomizeCPUWidget[i] = new CheckboxWidget(myTab, font, xpos, ypos + 1,
|
||||||
cpuregsLabels[i], kRandCPUID);
|
cpuregsLabels[i]);
|
||||||
wid.push_back(myRandomizeCPUWidget[i]);
|
wid.push_back(myRandomizeCPUWidget[i]);
|
||||||
xpos += CheckboxWidget::boxSize(font) + font.getStringWidth("XX") + fontWidth * 2.5;
|
xpos += CheckboxWidget::boxSize(font) + font.getStringWidth("XX") + fontWidth * 2.5;
|
||||||
}
|
}
|
||||||
|
@ -669,6 +673,7 @@ void DeveloperDialog::loadSettings(SettingsSet set)
|
||||||
myConsole[set] = instance().settings().getString(prefix + "console") == "7800" ? 1 : 0;
|
myConsole[set] = instance().settings().getString(prefix + "console") == "7800" ? 1 : 0;
|
||||||
// Randomization
|
// Randomization
|
||||||
myRandomBank[set] = instance().settings().getBool(prefix + "bankrandom");
|
myRandomBank[set] = instance().settings().getBool(prefix + "bankrandom");
|
||||||
|
myRandomizeTIA[set] = instance().settings().getBool(prefix + "tiarandom");
|
||||||
myRandomizeRAM[set] = instance().settings().getBool(prefix + "ramrandom");
|
myRandomizeRAM[set] = instance().settings().getBool(prefix + "ramrandom");
|
||||||
myRandomizeCPU[set] = instance().settings().getString(prefix + "cpurandom");
|
myRandomizeCPU[set] = instance().settings().getString(prefix + "cpurandom");
|
||||||
// Undriven TIA pins
|
// Undriven TIA pins
|
||||||
|
@ -725,6 +730,7 @@ void DeveloperDialog::saveSettings(SettingsSet set)
|
||||||
|
|
||||||
// Randomization
|
// Randomization
|
||||||
instance().settings().setValue(prefix + "bankrandom", myRandomBank[set]);
|
instance().settings().setValue(prefix + "bankrandom", myRandomBank[set]);
|
||||||
|
instance().settings().setValue(prefix + "tiarandom", myRandomizeTIA[set]);
|
||||||
instance().settings().setValue(prefix + "ramrandom", myRandomizeRAM[set]);
|
instance().settings().setValue(prefix + "ramrandom", myRandomizeRAM[set]);
|
||||||
instance().settings().setValue(prefix + "cpurandom", myRandomizeCPU[set]);
|
instance().settings().setValue(prefix + "cpurandom", myRandomizeCPU[set]);
|
||||||
|
|
||||||
|
@ -786,6 +792,7 @@ void DeveloperDialog::getWidgetStates(SettingsSet set)
|
||||||
myConsole[set] = myConsoleWidget->getSelected() == 1;
|
myConsole[set] = myConsoleWidget->getSelected() == 1;
|
||||||
// Randomization
|
// Randomization
|
||||||
myRandomBank[set] = myRandomBankWidget->getState();
|
myRandomBank[set] = myRandomBankWidget->getState();
|
||||||
|
myRandomizeTIA[set] = myRandomizeTIAWidget->getState();
|
||||||
myRandomizeRAM[set] = myRandomizeRAMWidget->getState();
|
myRandomizeRAM[set] = myRandomizeRAMWidget->getState();
|
||||||
string cpurandom;
|
string cpurandom;
|
||||||
const std::array<string, 5> cpuregs = {"S", "A", "X", "Y", "P"};
|
const std::array<string, 5> cpuregs = {"S", "A", "X", "Y", "P"};
|
||||||
|
@ -841,6 +848,7 @@ void DeveloperDialog::setWidgetStates(SettingsSet set)
|
||||||
myConsoleWidget->setSelectedIndex(myConsole[set]);
|
myConsoleWidget->setSelectedIndex(myConsole[set]);
|
||||||
// Randomization
|
// Randomization
|
||||||
myRandomBankWidget->setState(myRandomBank[set]);
|
myRandomBankWidget->setState(myRandomBank[set]);
|
||||||
|
myRandomizeTIAWidget->setState(myRandomizeTIA[set]);
|
||||||
myRandomizeRAMWidget->setState(myRandomizeRAM[set]);
|
myRandomizeRAMWidget->setState(myRandomizeRAM[set]);
|
||||||
|
|
||||||
const string& cpurandom = myRandomizeCPU[set];
|
const string& cpurandom = myRandomizeCPU[set];
|
||||||
|
@ -1025,6 +1033,7 @@ void DeveloperDialog::setDefaults()
|
||||||
myConsole[set] = 0;
|
myConsole[set] = 0;
|
||||||
// Randomization
|
// Randomization
|
||||||
myRandomBank[set] = devSettings ? true : false;
|
myRandomBank[set] = devSettings ? true : false;
|
||||||
|
myRandomizeTIA[set] = true;
|
||||||
myRandomizeRAM[set] = true;
|
myRandomizeRAM[set] = true;
|
||||||
myRandomizeCPU[set] = devSettings ? "SAXYP" : "AXYP";
|
myRandomizeCPU[set] = devSettings ? "SAXYP" : "AXYP";
|
||||||
// Undriven TIA pins
|
// Undriven TIA pins
|
||||||
|
|
|
@ -57,8 +57,6 @@ class DeveloperDialog : public Dialog
|
||||||
kPlrSettings = 'DVpl',
|
kPlrSettings = 'DVpl',
|
||||||
kDevSettings = 'DVdv',
|
kDevSettings = 'DVdv',
|
||||||
kConsole = 'DVco',
|
kConsole = 'DVco',
|
||||||
kRandRAMID = 'DVrm',
|
|
||||||
kRandCPUID = 'DVcp',
|
|
||||||
kTIAType = 'DVtt',
|
kTIAType = 'DVtt',
|
||||||
kTVJitter = 'DVjt',
|
kTVJitter = 'DVjt',
|
||||||
kTVJitterChanged = 'DVjr',
|
kTVJitterChanged = 'DVjr',
|
||||||
|
@ -94,6 +92,7 @@ class DeveloperDialog : public Dialog
|
||||||
PopUpWidget* myConsoleWidget{nullptr};
|
PopUpWidget* myConsoleWidget{nullptr};
|
||||||
StaticTextWidget* myLoadingROMLabel{nullptr};
|
StaticTextWidget* myLoadingROMLabel{nullptr};
|
||||||
CheckboxWidget* myRandomBankWidget{nullptr};
|
CheckboxWidget* myRandomBankWidget{nullptr};
|
||||||
|
CheckboxWidget* myRandomizeTIAWidget{nullptr};
|
||||||
CheckboxWidget* myRandomizeRAMWidget{nullptr};
|
CheckboxWidget* myRandomizeRAMWidget{nullptr};
|
||||||
StaticTextWidget* myRandomizeCPULabel{nullptr};
|
StaticTextWidget* myRandomizeCPULabel{nullptr};
|
||||||
CheckboxWidget* myUndrivenPinsWidget{nullptr};
|
CheckboxWidget* myUndrivenPinsWidget{nullptr};
|
||||||
|
@ -154,6 +153,7 @@ class DeveloperDialog : public Dialog
|
||||||
std::array<bool, 2> myDetectedInfo;
|
std::array<bool, 2> myDetectedInfo;
|
||||||
std::array<int, 2> myConsole;
|
std::array<int, 2> myConsole;
|
||||||
std::array<bool, 2> myRandomBank;
|
std::array<bool, 2> myRandomBank;
|
||||||
|
std::array<bool, 2> myRandomizeTIA;
|
||||||
std::array<bool, 2> myRandomizeRAM;
|
std::array<bool, 2> myRandomizeRAM;
|
||||||
std::array<string, 2> myRandomizeCPU;
|
std::array<string, 2> myRandomizeCPU;
|
||||||
std::array<bool, 2> myColorLoss;
|
std::array<bool, 2> myColorLoss;
|
||||||
|
|
Loading…
Reference in New Issue