170 lines
7.8 KiB
HTML
170 lines
7.8 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html401/loose.dtd">
|
|
<html>
|
|
<!-- Created on November, 7 2008 by texi2html 1.78 -->
|
|
<!--
|
|
Written by: Lionel Cons <Lionel.Cons@cern.ch> (original author)
|
|
Karl Berry <karl@freefriends.org>
|
|
Olaf Bachmann <obachman@mathematik.uni-kl.de>
|
|
and many others.
|
|
Maintained by: Many creative people.
|
|
Send bugs and suggestions to <texi2html-bug@nongnu.org>
|
|
|
|
-->
|
|
<head>
|
|
<title>Simulavr: 3. Using with GDB</title>
|
|
|
|
<meta name="description" content="Simulavr: 3. Using with GDB">
|
|
<meta name="keywords" content="Simulavr: 3. Using with GDB">
|
|
<meta name="resource-type" content="document">
|
|
<meta name="distribution" content="global">
|
|
<meta name="Generator" content="texi2html 1.78">
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
|
<style type="text/css">
|
|
<!--
|
|
a.summary-letter {text-decoration: none}
|
|
pre.display {font-family: serif}
|
|
pre.format {font-family: serif}
|
|
pre.menu-comment {font-family: serif}
|
|
pre.menu-preformatted {font-family: serif}
|
|
pre.smalldisplay {font-family: serif; font-size: smaller}
|
|
pre.smallexample {font-size: smaller}
|
|
pre.smallformat {font-family: serif; font-size: smaller}
|
|
pre.smalllisp {font-size: smaller}
|
|
span.roman {font-family:serif; font-weight:normal;}
|
|
span.sansserif {font-family:sans-serif; font-weight:normal;}
|
|
ul.toc {list-style: none}
|
|
-->
|
|
</style>
|
|
|
|
|
|
</head>
|
|
|
|
<body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
|
|
|
|
<a name="Using-with-GDB"></a>
|
|
<a name="SEC5"></a>
|
|
<table cellpadding="1" cellspacing="1" border="0">
|
|
<tr><td valign="middle" align="left">[<a href="simulavr_4.html#SEC4" title="Previous section in reading order"> < </a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_6.html#SEC6" title="Next section in reading order"> > </a>]</td>
|
|
<td valign="middle" align="left"> </td>
|
|
<td valign="middle" align="left">[<a href="simulavr_2.html#SEC2" title="Beginning of this chapter or previous chapter"> << </a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr.html#Top" title="Up section"> Up </a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_8.html#SEC8" title="Next chapter"> >> </a>]</td>
|
|
<td valign="middle" align="left"> </td>
|
|
<td valign="middle" align="left"> </td>
|
|
<td valign="middle" align="left"> </td>
|
|
<td valign="middle" align="left"> </td>
|
|
<td valign="middle" align="left">[<a href="simulavr.html#Top" title="Cover (top) of document">Top</a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_toc.html#SEC_Contents" title="Table of contents">Contents</a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_11.html#SEC11" title="Index">Index</a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_abt.html#SEC_About" title="About (help)"> ? </a>]</td>
|
|
</tr></table>
|
|
<h1 class="chapter"> 3. Using with GDB </h1>
|
|
|
|
<p>If you want to use gdb as a source-level debugger with
|
|
simulavr running as a remote target, start simulavr with the
|
|
‘<samp>--gdbserver</samp>’ or ‘<samp>-g</samp>’ option. This will put simulavr
|
|
into gdbserver mode. simulavr will then act as a TCP server
|
|
program on the localhost listening for a connection from gdb.
|
|
</p>
|
|
<p>Once simulavr has accepted a connection from gdb, the two programs
|
|
communicate via gdb's remote serial protocol (see <a href="../gdb/index.html#Top">GDB Remote Serial Protocol: (gdb)Top</a> section `Protocol' in <cite>Debugging with GDB</cite>).
|
|
</p>
|
|
<p>Here's how you would start up simulavr in gdbserver mode:
|
|
</p>
|
|
<table><tr><td> </td><td><table class="cartouche" border="1"><tr><td>
|
|
<pre class="example">$ simulavr -d at90s8515 -g
|
|
</pre></td></tr></table>
|
|
</td></tr></table>
|
|
|
|
<p>Here's a sample gdb session showing what to do on the gdb
|
|
side to get gdb to talk to simulavr:
|
|
</p>
|
|
<table><tr><td> </td><td><table class="cartouche" border="1"><tr><td>
|
|
<pre class="example">This GDB was configured as "--host=i686-pc-linux-gnu --target=avr".
|
|
(gdb) file demo_kr.elf
|
|
Reading symbols from demo_kr.elf...done.
|
|
(gdb) target remote localhost:1212
|
|
Remote debugging using localhost:1212
|
|
0x0 in .__start_of_init__ ()
|
|
(gdb) load
|
|
Loading section .text, size 0x76 lma 0x0
|
|
Start address 0x0 , load size 118
|
|
Transfer rate: 944 bits in <1 sec, 29 bytes/write.
|
|
(gdb) break main
|
|
Breakpoint 1 at 0x6e: file demo_kr.c, line 17.
|
|
(gdb) continue
|
|
Continuing.
|
|
|
|
Breakpoint 1, main () at demo_kr.c:17
|
|
17 sbi(DDRC, (
|
|
(gdb) quit
|
|
The program is running. Exit anyway? (y or n) y
|
|
</pre></td></tr></table>
|
|
</td></tr></table>
|
|
|
|
<p>Notice that simulavr knew nothing about the program to debug when it
|
|
was started. Gdb was told which file to debug with the ‘<samp>file</samp>’
|
|
command. After gdb has read in the program and connected to simulavr,
|
|
the program's instructions are downloaded into the simulator via the
|
|
‘<samp>load</samp>’ command. The ‘<samp>load</samp>’ command is not necessary if
|
|
simulavr already has the program loaded into it's flash memory area. It
|
|
is ok to issue multiple ‘<samp>load</samp>’ commands.
|
|
</p>
|
|
<p>Also, notice that no ‘<samp>run</samp>’ command was given to gdb. Gdb assumes
|
|
that the simulator has started and is ready to continue. Giving gdb the
|
|
‘<samp>run</samp>’ command, will cause it to stop the current debug session and
|
|
start a new one, which is not likely to be what you want to do.
|
|
</p>
|
|
<p>When specifying the remote target to connect to, it is sufficient to
|
|
write “target remote :1212” instead of “target remote localhost:1212”.
|
|
</p>
|
|
<p>Hitting <kbd>CTRL-c</kbd> in gdb can be used to interrupt the simulator while it is
|
|
processing instructions and return control back to gdb. This is most
|
|
useful when gdb is waiting for a response from the simulator and the
|
|
program running in the simulator is in an infinite loop.
|
|
</p>
|
|
<p>Issuing a ‘<samp>signal SIGxxx</samp>’ command from gdb will send the signal to
|
|
the simulator via a <i>continue with signal</i> packet. The simulator will
|
|
process and interpret the signal, but will not pass it on to the AVR
|
|
program running in the simulator since it really makes no sense to do
|
|
so. In some circumstances, it may make sense to use the gdb signal
|
|
mechanism as a way to initiate some sort of external stimulus to be
|
|
passed on to the virtual hardware system of the simulator. Signals from
|
|
gdb which are processed have the following meanings:
|
|
</p>
|
|
<dl compact="compact">
|
|
<dd><a name="IDX17"></a>
|
|
</dd>
|
|
<dt> <code>SIGHUP</code></dt>
|
|
<dd><p>Initiate a reset of the simulator. (Simulates a hardware reset).
|
|
</p>
|
|
</dd>
|
|
</dl>
|
|
|
|
<table class="menu" border="0" cellspacing="0">
|
|
<tr><td align="left" valign="top"><a href="simulavr_6.html#SEC6">3.1 GDB Hints</a></td><td> </td><td align="left" valign="top">
|
|
</td></tr>
|
|
<tr><td align="left" valign="top"><a href="simulavr_7.html#SEC7">3.2 Building GDB for AVR</a></td><td> </td><td align="left" valign="top">
|
|
</td></tr>
|
|
</table>
|
|
|
|
<hr size="6">
|
|
<table cellpadding="1" cellspacing="1" border="0">
|
|
<tr><td valign="middle" align="left">[<a href="simulavr_4.html#SEC4" title="Previous section in reading order"> < </a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_6.html#SEC6" title="Next section in reading order"> > </a>]</td>
|
|
<td valign="middle" align="left"> </td>
|
|
<td valign="middle" align="left">[<a href="simulavr_2.html#SEC2" title="Beginning of this chapter or previous chapter"> << </a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr.html#Top" title="Up section"> Up </a>]</td>
|
|
<td valign="middle" align="left">[<a href="simulavr_8.html#SEC8" title="Next chapter"> >> </a>]</td>
|
|
</tr></table>
|
|
<p>
|
|
<font size="-1">
|
|
This document was generated by <em>eweddington</em> on <em>November, 7 2008</em> using <a href="http://www.nongnu.org/texi2html/"><em>texi2html 1.78</em></a>.
|
|
</font>
|
|
<br>
|
|
|
|
</p>
|
|
</body>
|
|
</html>
|