web-legacy/milkymist-wiki/wiki/index.php?title=Using_GDB_i...

229 lines
19 KiB
HTML
Raw Normal View History

2014-09-19 12:52:20 +08:00
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" dir="ltr">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<meta name="generator" content="MediaWiki 1.14.0" />
<meta name="keywords" content="Using GDB in-system debugger" />
<link rel="alternate" type="application/x-wiki" title="Edit" href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit" />
<link rel="edit" title="Edit" href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit" />
<link rel="shortcut icon" href="../favicon.ico" />
<link rel="search" type="application/opensearchdescription+xml" href="opensearch_desc.php" title="Milkymist Wiki (en)" />
<link title="Creative Commons" type="application/rdf+xml" href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=creativecommons" rel="meta" />
<link rel="copyright" href="http://www.milkymist.org/wiki/index.php?title=Copyright" />
<link rel="alternate" type="application/rss+xml" title="Milkymist Wiki RSS Feed" href="http://milkymist.org/wiki/index.php?title=Special:RecentChanges&amp;feed=rss" />
<link rel="alternate" type="application/atom+xml" title="Milkymist Wiki Atom Feed" href="http://milkymist.org/wiki/index.php?title=Special:RecentChanges&amp;feed=atom" />
<title>Using GDB in-system debugger - Milkymist Wiki</title>
<link rel="stylesheet" href="skins/common/shared.css%3F195.css" type="text/css" media="screen" />
<link rel="stylesheet" href="skins/common/commonPrint.css%3F195.css" type="text/css" media="print" />
<link rel="stylesheet" href="skins/monobook/main.css%3F195.css" type="text/css" media="screen" />
<!--[if lt IE 5.5000]><link rel="stylesheet" href="/wiki/skins/monobook/IE50Fixes.css?195" type="text/css" media="screen" /><![endif]-->
<!--[if IE 5.5000]><link rel="stylesheet" href="/wiki/skins/monobook/IE55Fixes.css?195" type="text/css" media="screen" /><![endif]-->
<!--[if IE 6]><link rel="stylesheet" href="/wiki/skins/monobook/IE60Fixes.css?195" type="text/css" media="screen" /><![endif]-->
<!--[if IE 7]><link rel="stylesheet" href="/wiki/skins/monobook/IE70Fixes.css?195" type="text/css" media="screen" /><![endif]-->
<link rel="stylesheet" href="http://milkymist.org/wiki/index.php?title=MediaWiki:Common.css&amp;usemsgcache=yes&amp;ctype=text%2Fcss&amp;smaxage=18000&amp;action=raw&amp;maxage=18000" type="text/css" />
<link rel="stylesheet" href="http://milkymist.org/wiki/index.php?title=MediaWiki:Print.css&amp;usemsgcache=yes&amp;ctype=text%2Fcss&amp;smaxage=18000&amp;action=raw&amp;maxage=18000" type="text/css" media="print" />
<link rel="stylesheet" href="http://milkymist.org/wiki/index.php?title=MediaWiki:Monobook.css&amp;usemsgcache=yes&amp;ctype=text%2Fcss&amp;smaxage=18000&amp;action=raw&amp;maxage=18000" type="text/css" />
<link rel="stylesheet" href="http://milkymist.org/wiki/index.php?title=-&amp;action=raw&amp;maxage=18000&amp;gen=css" type="text/css" />
<!--[if lt IE 7]><script type="text/javascript" src="/wiki/skins/common/IEFixes.js?195"></script>
<meta http-equiv="imagetoolbar" content="no" /><![endif]-->
<script type= "text/javascript">/*<![CDATA[*/
var skin = "monobook";
var stylepath = "/wiki/skins";
var wgArticlePath = "/wiki/index.php?title=$1";
var wgScriptPath = "/wiki";
var wgScript = "/wiki/index.php";
var wgVariantArticlePath = false;
var wgActionPaths = {};
var wgServer = "http://milkymist.org";
var wgCanonicalNamespace = "";
var wgCanonicalSpecialPageName = false;
var wgNamespaceNumber = 0;
var wgPageName = "Using_GDB_in-system_debugger";
var wgTitle = "Using GDB in-system debugger";
var wgAction = "view";
var wgArticleId = "158";
var wgIsArticle = true;
var wgUserName = null;
var wgUserGroups = null;
var wgUserLanguage = "en";
var wgContentLanguage = "en";
var wgBreakFrames = false;
var wgCurRevisionId = "1293";
var wgVersion = "1.14.0";
var wgEnableAPI = true;
var wgEnableWriteAPI = true;
var wgSeparatorTransformTable = ["", ""];
var wgDigitTransformTable = ["", ""];
var wgRestrictionEdit = [];
var wgRestrictionMove = [];
/*]]>*/</script>
<script type="text/javascript" src="skins/common/wikibits.js%3F195"><!-- wikibits js --></script>
<!-- Head Scripts -->
<script type="text/javascript" src="skins/common/ajax.js%3F195"></script>
<script type="text/javascript" src="http://milkymist.org/wiki/index.php?title=-&amp;action=raw&amp;gen=js&amp;useskin=monobook"><!-- site js --></script>
</head>
<body class="mediawiki ltr ns-0 ns-subject page-Using_GDB_in-system_debugger skin-monobook">
<div id="globalWrapper">
<div id="column-content">
<div id="content">
<a name="top" id="top"></a>
<h1 id="firstHeading" class="firstHeading">Using GDB in-system debugger</h1>
<div id="bodyContent">
<h3 id="siteSub">From Milkymist Wiki</h3>
<div id="contentSub"></div>
<div id="jump-to-nav">Jump to: <a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#column-one">navigation</a>, <a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#searchInput">search</a></div> <!-- start content -->
<table id="toc" class="toc" summary="Contents"><tr><td><div id="toctitle"><h2>Contents</h2></div>
<ul>
<li class="toclevel-1"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Compiling_GDB"><span class="tocnumber">1</span> <span class="toctext">Compiling GDB</span></a></li>
<li class="toclevel-1"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Obtaining_Flickernoise_debug_information"><span class="tocnumber">2</span> <span class="toctext">Obtaining Flickernoise debug information</span></a></li>
<li class="toclevel-1"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Running_GDB"><span class="tocnumber">3</span> <span class="toctext">Running GDB</span></a></li>
<li class="toclevel-1"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Connecting_to_the_target"><span class="tocnumber">4</span> <span class="toctext">Connecting to the target</span></a>
<ul>
<li class="toclevel-2"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Directly"><span class="tocnumber">4.1</span> <span class="toctext">Directly</span></a></li>
<li class="toclevel-2"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#With_flterm_pass-through"><span class="tocnumber">4.2</span> <span class="toctext">With flterm pass-through</span></a></li>
<li class="toclevel-2"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Over_JTAG"><span class="tocnumber">4.3</span> <span class="toctext">Over JTAG</span></a></li>
<li class="toclevel-2"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#Tips"><span class="tocnumber">4.4</span> <span class="toctext">Tips</span></a></li>
</ul>
</li>
<li class="toclevel-1"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html#GDB_commands"><span class="tocnumber">5</span> <span class="toctext">GDB commands</span></a></li>
</ul>
</td></tr></table><script type="text/javascript"> if (window.showTocToggle) { var tocShowText = "show"; var tocHideText = "hide"; showTocToggle(); } </script>
<a name="Compiling_GDB" id="Compiling_GDB"></a><h1><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=1" title="Edit section: Compiling GDB">edit</a>]</span> <span class="mw-headline"> Compiling GDB </span></h1>
<p>A <a href="http://sourceware.org/ml/gdb-patches/2011-04/msg00066.html" class="external text" title="http://sourceware.org/ml/gdb-patches/2011-04/msg00066.html" rel="nofollow">patch</a> is needed to make direct serial connections work. It was merged in GDB 7.3.
Compile GDB with the target <code>lm32-rtems4.11</code>.
Those steps should be included in the <a href="https://github.com/milkymist/scripts" class="external text" title="https://github.com/milkymist/scripts" rel="nofollow">build scripts</a>.
</p>
<a name="Obtaining_Flickernoise_debug_information" id="Obtaining_Flickernoise_debug_information"></a><h1><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=2" title="Edit section: Obtaining Flickernoise debug information">edit</a>]</span> <span class="mw-headline"> Obtaining Flickernoise debug information </span></h1>
<p>When building Flickernoise, the file <code>bin/flickernoise.elf</code> contains the debug information. Starting with Flickernoise 1.0RC1, this file is provided with the releases to make debugging easier. With
earlier versions, you have to compile Flickernoise yourself (the <a href="https://github.com/milkymist/scripts" class="external text" title="https://github.com/milkymist/scripts" rel="nofollow">build scripts</a> automate that).
</p><p><b>Make sure the <code>.elf</code> file and the code that the M1 is running are in sync!</b> If in doubt, <a href="http://www.milkymist.org/socdoc/bios.pdf" class="external text" title="http://www.milkymist.org/socdoc/bios.pdf" rel="nofollow">netboot</a> the binary that was just built.
</p>
<a name="Running_GDB" id="Running_GDB"></a><h1><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=3" title="Edit section: Running GDB">edit</a>]</span> <span class="mw-headline"> Running GDB </span></h1>
<pre>lm32-rtems4.11-gdb flickernoise.elf
</pre>
<a name="Connecting_to_the_target" id="Connecting_to_the_target"></a><h1><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=4" title="Edit section: Connecting to the target">edit</a>]</span> <span class="mw-headline"> Connecting to the target </span></h1>
<a name="Directly" id="Directly"></a><h2><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=5" title="Edit section: Directly">edit</a>]</span> <span class="mw-headline"> Directly </span></h2>
<p>Use these commands in GDB:
</p>
<pre>set remote interrupt-on-connect on
set remote interrupt-sequence BREAK
target remote /dev/ttyUSB0
</pre>
<a name="With_flterm_pass-through" id="With_flterm_pass-through"></a><h2><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=6" title="Edit section: With flterm pass-through">edit</a>]</span> <span class="mw-headline"> With flterm pass-through </span></h2>
<p>To use it start flterm with --gdb-passthrough. Then start gdb and run the following commands:
</p>
<pre>set remote interrupt-on-connect on
target remote &lt;pseudo terminal printed by flterm&gt;
</pre>
<p>Note: there is _no_ 'set remote interrupt-sequence BREAK'. flterm takes
care of converting Ctrl+C (ETX) to a BREAK.
</p>
<a name="Over_JTAG" id="Over_JTAG"></a><h2><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=7" title="Edit section: Over JTAG">edit</a>]</span> <span class="mw-headline"> Over JTAG </span></h2>
<p>With <a href="http://git.serverraum.org/?p=mw/openocd-lm32.git;a=summary" class="external text" title="http://git.serverraum.org/?p=mw/openocd-lm32.git;a=summary" rel="nofollow">OpenOCD</a>.Does not work reliably yet.
</p>
<a name="Tips" id="Tips"></a><h2><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=8" title="Edit section: Tips">edit</a>]</span> <span class="mw-headline"> Tips </span></h2>
<p>To track down GDB connection problems:
</p>
<pre>set debug remote 1
</pre>
<a name="GDB_commands" id="GDB_commands"></a><h1><span class="editsection">[<a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit&amp;section=9" title="Edit section: GDB commands">edit</a>]</span> <span class="mw-headline"> GDB commands </span></h1>
<p>When reporting a freeze, include at least the output from the <code>backtrace</code> command that gives a stack trace.
</p>
<ul><li> <a href="http://linux.bytesex.org/gdb.html" class="external text" title="http://linux.bytesex.org/gdb.html" rel="nofollow">GDB mini intro</a>
</li></ul>
<!--
NewPP limit report
Preprocessor node count: 15/1000000
Post-expand include size: 0/2097152 bytes
Template argument size: 0/2097152 bytes
Expensive parser function count: 0/100
-->
<!-- Saved in parser cache with key sbsql1-mw_:pcache:idhash:158-0!1!0!!en!2 and timestamp 20140823124216 -->
<div class="printfooter">
Retrieved from "<a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html">http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger</a>"</div>
<!-- end content -->
<div class="visualClear"></div>
</div>
</div>
</div>
<div id="column-one">
<div id="p-cactions" class="portlet">
<h5>Views</h5>
<div class="pBody">
<ul>
<li id="ca-nstab-main" class="selected"><a href="index.php%3Ftitle=Using_GDB_in-system_debugger.html" title="View the content page [c]" accesskey="c">Page</a></li>
<li id="ca-talk" class="new"><a href="http://milkymist.org/wiki/index.php?title=Talk:Using_GDB_in-system_debugger&amp;action=edit&amp;redlink=1" title="Discussion about the content page [t]" accesskey="t">Discussion</a></li>
<li id="ca-edit"><a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=edit" title="You can edit this page.&#10;Please use the preview button before saving [e]" accesskey="e">Edit</a></li>
<li id="ca-history"><a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;action=history" title="Past versions of this page [h]" accesskey="h">History</a></li> </ul>
</div>
</div>
<div class="portlet" id="p-personal">
<h5>Personal tools</h5>
<div class="pBody">
<ul>
<li id="pt-login"><a href="http://milkymist.org/wiki/index.php?title=Special:UserLogin&amp;returnto=Using_GDB_in-system_debugger" title="You are encouraged to log in; however, it is not mandatory [o]" accesskey="o">Log in / create account</a></li>
</ul>
</div>
</div>
<div class="portlet" id="p-logo">
<a style="background-image: url(http://www.milkymist.org/wikilogo.png);" href="../wiki.html" title="Visit the main page [z]" accesskey="z"></a>
</div>
<script type="text/javascript"> if (window.isMSIE55) fixalpha(); </script>
<div class='generated-sidebar portlet' id='p-navigation'>
<h5>Navigation</h5>
<div class='pBody'>
<ul>
<li id="n-mainpage-description"><a href="../wiki.html">Main Page</a></li>
<li id="n-portal"><a href="http://milkymist.org/wiki/index.php?title=Milkymist_Wiki:Community_Portal" title="About the project, what you can do, where to find things">Community portal</a></li>
<li id="n-currentevents"><a href="http://milkymist.org/wiki/index.php?title=Milkymist_Wiki:Current_events" title="Find background information on current events">Current events</a></li>
<li id="n-recentchanges"><a href="http://milkymist.org/wiki/index.php?title=Special:RecentChanges" title="The list of recent changes in the wiki [r]" accesskey="r">Recent changes</a></li>
<li id="n-randompage"><a href="http://milkymist.org/wiki/index.php?title=Special:Random" title="Load a random page [x]" accesskey="x">Random page</a></li>
<li id="n-help"><a href="http://milkymist.org/wiki/index.php?title=Help:Contents" title="The place to find out">Help</a></li>
</ul>
</div>
</div>
<div id="p-search" class="portlet">
<h5><label for="searchInput">Search</label></h5>
<div id="searchBody" class="pBody">
<form action="http://milkymist.org/wiki/index.php?title=Special:Search" id="searchform"><div>
<input id="searchInput" name="search" type="text" title="Search Milkymist Wiki [f]" accesskey="f" value="" />
<input type='submit' name="go" class="searchButton" id="searchGoButton" value="Go" title="Go to a page with this exact name if exists" />&nbsp;
<input type='submit' name="fulltext" class="searchButton" id="mw-searchButton" value="Search" title="Search the pages for this text" />
</div></form>
</div>
</div>
<div class="portlet" id="p-tb">
<h5>Toolbox</h5>
<div class="pBody">
<ul>
<li id="t-whatlinkshere"><a href="http://milkymist.org/wiki/index.php?title=Special:WhatLinksHere/Using_GDB_in-system_debugger" title="List of all wiki pages that link here [j]" accesskey="j">What links here</a></li>
<li id="t-recentchangeslinked"><a href="http://milkymist.org/wiki/index.php?title=Special:RecentChangesLinked/Using_GDB_in-system_debugger" title="Recent changes in pages linked from this page [k]" accesskey="k">Related changes</a></li>
<li id="t-specialpages"><a href="http://milkymist.org/wiki/index.php?title=Special:SpecialPages" title="List of all special pages [q]" accesskey="q">Special pages</a></li>
<li id="t-print"><a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;printable=yes" title="Printable version of this page [p]" accesskey="p">Printable version</a></li> <li id="t-permalink"><a href="http://milkymist.org/wiki/index.php?title=Using_GDB_in-system_debugger&amp;oldid=1293" title="Permanent link to this version of the page">Permanent link</a></li> </ul>
</div>
</div>
</div><!-- end of the left (by default at least) column -->
<div class="visualClear"></div>
<div id="footer">
<div id="f-poweredbyico"><a href="http://www.mediawiki.org/"><img src="skins/common/images/poweredby_mediawiki_88x31.png" alt="Powered by MediaWiki" /></a></div>
<div id="f-copyrightico"><a href="http://www.milkymist.org/wiki/index.php?title=Copyright"><img src="skins/common/images/gnu-fdl.png" alt='GNU Free Documentation License 1.3 and CC-BY-SA 3.0 Unported' /></a></div>
<ul id="f-list">
<li id="lastmod"> This page was last modified on 12 June 2011, at 09:09.</li>
<li id="viewcount">This page has been accessed 5,230 times.</li>
<li id="copyright">Content is available under <a href="http://www.milkymist.org/wiki/index.php?title=Copyright" class="external " title="http://www.milkymist.org/wiki/index.php?title=Copyright">GNU Free Documentation License 1.3 and CC-BY-SA 3.0 Unported</a>.</li>
<li id="privacy"><a href="http://milkymist.org/wiki/index.php?title=Milkymist_Wiki:Privacy_policy" title="Milkymist Wiki:Privacy policy">Privacy policy</a></li>
<li id="about"><a href="http://milkymist.org/wiki/index.php?title=Milkymist_Wiki:About" title="Milkymist Wiki:About">About Milkymist Wiki</a></li>
<li id="disclaimer"><a href="http://milkymist.org/wiki/index.php?title=Milkymist_Wiki:General_disclaimer" title="Milkymist Wiki:General disclaimer">Disclaimers</a></li>
</ul>
</div>
</div>
<script type="text/javascript">if (window.runOnloadHook) runOnloadHook();</script>
<!-- Served in 0.210 secs. --></body></html>