"Startup" section to debugger doc added

This commit is contained in:
thrust26 2017-12-04 18:06:40 +01:00
parent 260a8b7bb0
commit a91bcbadc9
1 changed files with 122 additions and 76 deletions

View File

@ -16,6 +16,7 @@
<li><a href="#Features">Features</a></li> <li><a href="#Features">Features</a></li>
<li><a href="#HowToDebugger">How to use the Debugger</a> <li><a href="#HowToDebugger">How to use the Debugger</a>
<ul> <ul>
<li><a href="#Startup">Startup</a></li>
<li><a href="#GlobalButtons">Global Buttons</a></li> <li><a href="#GlobalButtons">Global Buttons</a></li>
<li><a href="#ChangeTracking">Change Tracking</a></li> <li><a href="#ChangeTracking">Change Tracking</a></li>
<li><a href="#PromptTab">Prompt Tab</a> <li><a href="#PromptTab">Prompt Tab</a>
@ -240,6 +241,68 @@ execution by stepping one instruction, scanline, or frame at a time
also set breakpoints or traps, which will cause the emulator to enter also set breakpoints or traps, which will cause the emulator to enter
the debugger when they are triggered, even if it happens in mid-frame.</p> the debugger when they are triggered, even if it happens in mid-frame.</p>
<h3><a name="Startup">Startup</a></h3>
At startup, the debugger automatically tries load a number of files which
will provide additional information for the debugger and can make debugging
more convenient.
<ul>
<li>
"autoexec.script"</br>
Use this plain text file to define e.g. your own functions or settings.
They will be loaded at startup for each ROM.
<p>The location of this file will depend on the OS as follows:</p>
<p>
<table cellpadding="3" border="1">
<tr>
<td><b>Linux/Unix</b></td>
<td><i>~/.stella/autoexec.script</i></td>
</tr>
<tr>
<td><b>Macintosh</b></td>
<td><i>~/Library/Application Support/Stella/autoexec.script</i></td>
</tr>
<tr>
<td><b>Windows</b></td>
<td><i>%APPDATA%\Stella\autoexec.script</i>&nbsp;&nbsp;&nbsp;
<b>or</b><br>
<i>_BASEDIR_\autoexec.script</i>
(if a file named 'basedir.txt' exists in the application
directory containing the full pathname for _BASEDIR_)
</td>
</tr>
</table>
</p>
</li>
<li>
"&lt;rom_filename&gt;.script"</br>
In this ROM specific, plain text file you can store breaks, traps, watches
etc. for future re-use. Use the "save" command to create this file using
the current settings. You can also manually edit the file and add more commands.
</br></br>
</li>
<li>
"&lt;rom_filename&gt;.cfg"</br>
This file is described in <a href="#DistellaConfiguration">
<b>Distella Configuration Files</b></a>.
</br></br>
</li>
<li>
"&lt;rom_filename&gt;.lst"</br>
</li>
<li>
"&lt;rom_filename&gt;.sym"</br>
If you provied the -l and -s parameters DASM will create these two files during
assembly. Stella uses the file content to display the correct labels.
</li>
</ul>
<p>Note that all files are only accessed if you enter
the debugger at least once during a program run. This means you can create
these files, and not worry about slowing down emulation unless you're
actively using the debugger.</p>
<!-- ///////////////////////////////////////////////////////////////////////// --> <!-- ///////////////////////////////////////////////////////////////////////// -->
<br> <br>
<h2><a name="GlobalButtons">Global Buttons</a></h2> <h2><a name="GlobalButtons">Global Buttons</a></h2>
@ -486,13 +549,12 @@ to change the meaning of an expression. The prefixes are:</p>
assumed to be in the default base. When you first start Stella, assumed to be in the default base. When you first start Stella,
the default base is 16 (hexadecimal). You can change it with the the default base is 16 (hexadecimal). You can change it with the
"base" command. If you want to change the default base to decimal permanently, "base" command. If you want to change the default base to decimal permanently,
you can put a "base #10" command in your "autoexec.script" file (see you can put a "base #10" command in your "autoexec.script" file (for details
the section on "Startup").</p> see <a href="#Startup"><b>Startup</b></a>).</p>
<p>Remember, you can use arbitrarily complex expressions with any
command that takes arguments.</p>
</li> </li>
</ul> </ul>
<p>Remember, you can use arbitrarily complex expressions with any
command that takes arguments.</p>
</br> </br>
<h3><a name="BreakpointsEtc">Breakpoints, watches and traps, oh my!</a></h3> <h3><a name="BreakpointsEtc">Breakpoints, watches and traps, oh my!</a></h3>
@ -736,56 +798,35 @@ all traps at once with the "cleartraps" command.</p></p>
</br> </br>
<h3><a name="SaveWork">Save your work!</a></h3> <h3><a name="SaveWork">Save your work!</a></h3>
Stella offers several commands to save your work inside the debugger for <p>Stella offers several commands to save your work inside the debugger for
later re-use. later re-use.</p>
<h4>save</h4> <ul>
<p>If you've defined a lot of complex functions, you probably will <li>
<b><a name="savecmd">save</a></b>: If you've defined a lot of complex functions, you probably will
want to re-use them in future runs of the debugger. You can save all want to re-use them in future runs of the debugger. You can save all
your functions, breakpoints, conditional breaks, traps and watches with the your functions, breakpoints, conditional breaks, traps and watches with the
"save" command. If you name your saved file the same as the ROM filename "save" command. If you name your saved file the same as the ROM filename
and place it in the ROM directory, it will be auto-loaded next time you and place it in the ROM directory, it will be auto-loaded next time you
load the same ROM in Stella. The save file is just a plain text file load the same ROM in Stella. The saved file is just a plain text file
called "rom_filename.script", so you can edit it and add new functions, etc.</p> called "&lt;rom_filename&gt;.script", so you can edit it and add new functions, etc.
<p>While "save" is ROM specific, you can also create a file called <p>Note: While "save" is ROM specific, you can also create a file called
"autoexec.script" which will be loaded when the debugger starts, no matter "autoexec.script" which will be loaded when the debugger starts, no matter
what ROM you have loaded. The location of this file will depend on the what ROM you have loaded.<p>
version of Stella, as follows:</p> See <a href="#Startup"><b>Startup</b></a> for details.
</li>
<p><table cellpadding="3" border="1"> <li>
<tr> <b>saveconfig</b>: The "saveconfig" command creates a
<td><b>Linux/Unix</b></td> <a href="#DistellaConfiguration"><b>DiStella Configuration File</b></a> which is
<td><i>~/.stella/autoexec.script</i></td>
</tr>
<tr>
<td><b>Macintosh</b></td>
<td><i>~/Library/Application Support/Stella/autoexec.script</i></td>
</tr>
<tr>
<td><b>Windows</b></td>
<td><i>%APPDATA%\Stella\autoexec.script</i>&nbsp;&nbsp;&nbsp;
<b>OR</b><br>
<i>_BASEDIR_\autoexec.script</i>
(if a file named 'basedir.txt' exists in the application
directory containing the full pathname for _BASEDIR_)
</td>
</tr>
</table>
<p>Note that these '.script' script files are only accessed if you enter
the debugger at least once during a program run. This means you can create
these files, and not worry about slowing down emulation unless you're
actively using the debugger.</p>
<h4>saveconfig</h4>
The "saveconfig" command creates a <a href="#DistellaConfiguration"><b>DiStella Configuration File</b></a> which is
based on Stella's dynamic and static analysis of the current ROM. based on Stella's dynamic and static analysis of the current ROM.
<p>This will be automatically loaded the next time your start the debugger. <p>This will be automatically loaded the next time your start the debugger.
From there on, you can continue analyzing the ROM and then use "saveconfig" From there on, you can continue analyzing the ROM and then use "saveconfig"
again to update the configuration. You can also use "loadconfig" to load it again to update the configuration. You can also use "loadconfig" to load it
manually. manually.
<p>Note that this is not tested for multi-banked ROMs.</p> <p>Note that this is not tested for multi-banked ROMs.</p>
</li>
<h4>savedis</h4> <li>
<b>savedis</b>:
While your are playing or debugging a game, Stella will gather dynamic While your are playing or debugging a game, Stella will gather dynamic
information about the ROM. It can then use that information together with information about the ROM. It can then use that information together with
a static analysis of the ROM and therefore create a better disassembly a static analysis of the ROM and therefore create a better disassembly
@ -793,20 +834,25 @@ than DiStella alone. "savedis" allows you to save that disassembly as the
result of this combined analysis. result of this combined analysis.
<p>Note that this currently only works for single banked ROMs. For larger <p>Note that this currently only works for single banked ROMs. For larger
ROMs, the created disassembly is incomplete.</p> ROMs, the created disassembly is incomplete.</p>
</li>
<h4>saverom</h4> <li>
<p><b>saverom</b>:
If you have manipulated a ROM, you can save it with "saverom". The file is If you have manipulated a ROM, you can save it with "saverom". The file is
named '&lt;rom_filename&gt;.a26'. named "&lt;rom_filename&gt;.a26".</p>
</li>
<h4>saveses</h4> <li>
<p><b>saveses</b>:
The "saveses" command dumps the whole prompt session into a file named The "saveses" command dumps the whole prompt session into a file named
"YYYY-MM-DD_HH-mm-ss.txt". So you can later lookup what you did exactly "&lt;YYYY-MM-DD_HH-mm-ss&gt;.txt". So you can later lookup what you did exactly
when you were debugging at that time. when you were debugging at that time.</p>
</li>
<h4>savestate</h4> <li>
<p>This command works identical to the save state hotkey (F9) during emulation. <p><b>savestate</b>:
This command works identical to the save state hotkey (F9) during emulation.
Any previously saved state can be loaded with "loadstate" plus the slot Any previously saved state can be loaded with "loadstate" plus the slot
number (0-9).</p> number (0-9).</p>
</li>
</ul>
</br> </br>
<h3><a name="PromptCommands">Prompt Commands</a></h3> <h3><a name="PromptCommands">Prompt Commands</a></h3>