fceux/help/Debugger.html

160 lines
9.8 KiB
HTML

<html>
<head>
<title>Debugger</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="generator" content="HelpNDoc Personal Edition 3.6.0.345">
<link type="text/css" rel="stylesheet" media="all" href="css/reset.css" />
<link type="text/css" rel="stylesheet" media="all" href="css/base.css" />
<link type="text/css" rel="stylesheet" media="all" href="css/hnd.css" />
<!--[if lte IE 8]>
<link type="text/css" rel="stylesheet" media="all" href="css/ielte8.css" />
<![endif]-->
<style type="text/css">
#topic_header
{
background-color: #EFEFEF;
}
</style>
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/hnd.js"></script>
<script type="text/javascript">
if (top.frames.length == 0)
{
var sTopicUrl = top.location.href.substring(top.location.href.lastIndexOf("/") + 1, top.location.href.length);
top.location.href = "fceux.html?" + sTopicUrl;
}
else if (top && top.FrameTOC && top.FrameTOC.SelectTocItem)
{
top.FrameTOC.SelectTocItem("Debugger");
}
</script>
</head>
<body>
<div id="topic_header">
<div id="topic_header_content">
<h1>Debugger</h1>
<div id="topic_breadcrumb">
<a href="Debug.html">Debug</a> &rsaquo;&rsaquo; </div>
</div>
<div id="topic_header_nav">
<a href="Debug.html"><img src="img/arrow_up.png" alt="Parent"/></a>
<a href="Debug.html"><img src="img/arrow_left.png" alt="Previous"/></a>
<a href="PPUViewer.html"><img src="img/arrow_right.png" alt="Next"/></a>
</div>
<div class="clear"></div>
</div>
<div id="topic_content">
<p><span class="rvts17">Debugger</span></p>
<p><br/></p>
<p>Taken from the FCEUXDSP 1.07 documentation.</p>
<p>More stuff added by AnS.</p>
<p><br/></p>
<p><span class="rvts12">Introduction</span></p>
<p><br/></p>
<p>The debugger is a powerful tool that reads, displays, and manipulates assembly language instructions in a game.</p>
<p><br/></p>
<p><span class="rvts16">Debugger Features</span></p>
<p><br/></p>
<ul style="text-indent: 0px; margin-left: 24px; list-style-position: outside;">
<li>When you hover the mouse cursor over the left pane in the debugger, at the bottom of Debugger window you can see the ROM file address of the data loaded there.</li>
<li>Right-click in that pane, it will bring up the Hex Editor at that address so you can immediately begin editing RAm or ROM data.</li>
<li>Left-click in that pane brings up the inline assembler (only if you point at ROM address)</li>
<li>Middle-click on a byte will bring up the <a class="rvts18" href="GameGenieEncoderDecoder.html">Game Genie Encoder</a> at that address, so you can easily make Game Genie codes.</li>
<li>"Break on bad opcode" feature; this can help you figure out where your game is crashing.</li>
<li>Debugging data like Breakpoints or Address Bookmarks are automatically saved in .DEB files and restored when games are closed / opened.</li>
<li>Ability to give Breakpoints a brief description/name.</li>
<li>All debugging information for addresses &lt; $8000 into the name list file romname.nes.ram.nl.</li>
<li>Added a feature to NL files to support arrays.</li>
<li>Range options for freezing / unfreezing addresses.</li>
<li>Dump RAM to file option.</li>
<li>Dump PPU memory to file option.</li>
<li>Cycles and Instructions counters can be used for profiling, writing synchronized code and making breakpoints based on the counter value.</li>
<li>When you need to quickly advance emulation to a given line of code, doubleclick on the line in Disassembly window, the "Add Execute breakpoint here" dialog will appear, click "OK" and then make "Run", soon Debugger will break at this line and you can "Delete" the breakpoint.</li>
<li>Stack window displays actual data from current Stack Pointer up to 0x1FF</li>
<li>"Scanline" shows current scanline number: -1 it means Prerender time, 240 is Idle scanline, 0-239 are visible scanlines, 241-260/310 are VBlank scanlines</li>
<li>After the Debugger snaps (either by hitting a breakpoint or when you press any "Step ..." button), you can unpause emulator by pressing Run button or using Pause hotkey. Also you can use Frame Advance key to unpause the emulator for only one frame.</li>
<li>"Display ROM offsets" option can print ROM offsets instead of CPU addresses in the Disassembly window.</li>
</ul>
<p><br/></p>
<p><br/></p>
<p><span class="rvts12">Using Debugger</span></p>
<p><br/></p>
<p><span class="rvts16">Symbolic Debugging</span></p>
<p><br/></p>
<p>The most important feature (at least for me) that was introduced in FCEUXD SP is symbolic debugging. &nbsp;With this new feature it's possible to rename addresses in the disassembly window (like $C022) to easily understandable names (like AddHealthpoints). It's also possible to add comments to lines in the disassembly window.</p>
<p><br/></p>
<p>To be able to use this feature it's necessary to create so called name list files (*.(bank).nl/*.ram.nl, Ex: NES Test Cart (PD).nes.0.nl, NES Test Cart (PD).nes.ram.nl) which contain all names and comments you wish to display in the disassembly window. These files are plain ASCII files of the following format (example follows):</p>
<p><br/></p>
<p>$C000#NewName1#Comment1</p>
<p>$C002##Comment2</p>
<p>$C004#NewName2#</p>
<p>$C006#NewName3#MultilineComment-Part1</p>
<p>\MultilineComment-Part2</p>
<p>\MultilineComment-Part3</p>
<p>$C008/10#NewName4#</p>
<p><br/></p>
<p>Every line contains two # characters which separate the three parts of one line: The first part (starting with a $ character) is the address to be renamed. Optionally you can add a "/number" part which marks the offsets as a beginning of an array of the given size (the size must be specified in hex form). &nbsp;The second (optional) part is the new name of that address. Whenever the line of that address is shown in the disassembly window an extra line saying "Name: NewName" is shown above it. &nbsp;Instructions referencing this address, for example JSR $C000 are also changed to JSR NewName1 (in that example). &nbsp;The third (optional) part is the comment that's also added above the disassembly line the comment refers to. It works exactly like the additional name line, only the prefix of that line is different. Comment lines start with "Comment: " rather than with "Name: ". &nbsp;Multi-lines comments are possible. Lines starting with a \ character are just appended to the comment of the preceding line. Multi-line comments are also shown in multiple lines in the disassembly window.</p>
<p><br/></p>
<p>Let's get back to the example.</p>
<p>The first line contains all three parts. Using this name list file all references to the address</p>
<p>$C000 are replaced with NewName1 and whenever line $C000 is shown in the disassembly window an</p>
<p>additional comment is also visible right above the actual disassembled line.</p>
<p>The second line defines only a comment while the third line defines only a name. Following that</p>
<p>there's a multi-line comment definition for address $C006.</p>
<p>The last line defines an array called NewName4 of size $10 (= 16) bytes starting at offset $C008.</p>
<p><br/></p>
<p>Now you know the format of the nl files but you do not yet know the naming convention for the</p>
<p>file names. Due to the bank-swapping nature of the NES it's getting a little bit difficult here.</p>
<p>Each bank needs it's own nl file. The naming convention goes like this: Take the name of the ROM</p>
<p>file and just add ".X.nl" to it where the X is the hexadecimal representation of the number of the</p>
<p>ROM bank. Suppose you have the ROM file "Faxanadu (U).nes" and you want to create a nl file for</p>
<p>ROM bank 15. As 15 is 0x0F in hex the name of the nl file would be "Faxanadu (U).nes.F.nl". All</p>
<p>nl files go into the same directory as the ROM file itself.</p>
<p><br/></p>
<p>There is also the *.ram.nl file specification, which allows you to substitute RAM addresses for</p>
<p>execution addresses, and have those named as well. In this case, you could use lines of this type:</p>
<p>$00A5#Mic Test OK#00=Not Passed, 01=Passed</p>
<p><br/></p>
<p>You can enable and disable symbolic debugging by clicking the checkbox "Symbolic Debugging" in</p>
<p>the debugger window. To forcibly reload the nl files of the currently active ROM file press the</p>
<p>button with the text "Reload Symbols".</p>
<p><br/></p>
<p><br/></p>
<p><span class="rvts16">Arrays</span></p>
<p><br/></p>
<p>The array feature is an easy way to group names and comments for sequential offsets.</p>
<p><br/></p>
<p>$C000/5#NewName1#Comment1</p>
<p><br/></p>
<p>is equivalent to</p>
<p><br/></p>
<p>$C000#NewName1#Comment1</p>
<p><span class="rvts12"><br/></span></p>
<p><br/></p>
<p><span class="rvts16">Inline Assembler</span></p>
<p><br/></p>
<p>The debugger has an Inline Assembler designed by Parasyte. &nbsp;To activate it, left-click in the left pane of the debugger, beside the assembly display. &nbsp;To use it, type in some code and press Enter to add it to the patch list. If you make a mistake, press "Undo". &nbsp;Once the patch is set up the way you want it, press "Apply". Be aware that this cannot be undone unless you reload the ROM. &nbsp;Parasyte implemented this feature before I had the Hex Editor working, otherwise I would have implemented a way to undo it from there. &nbsp;Press "Save" to write to the ROM file on disk; note that this will also save any changes you may have done in the Hex Editor.</p>
<p><br/></p>
<p><br/></p>
<p><br/></p>
<p class="rvps2"><span class="rvts13">Created with the Personal Edition of HelpNDoc: </span><a class="rvts14" href="http://www.helpndoc.com/create-epub-ebooks">Full featured EBook editor</a></p>
</div>
<div id="topic_footer">
<div id="topic_footer_content">
2012</div>
</div>
</body>
</html>