blob: 619fcb38fc949ff05e9921663e292f2ce358b7b0 [file] [log] [blame]
How to use SIS with GDB
-----------------------
1. Building GDB with SIS
To build GDB with the SIS/ERC32 simulator, configure with option
'--target sparc-erc32-aout' and build as usual.
2. Attaching the simulator
To attach GDB to the simulator, use:
target sim [options] [files]
The following options are supported:
-nfp Disable FPU. FPops will cause an FPU disabled trap.
-freq <f> Set the simulated "system clock" to <f> MHz.
-v Verbose mode.
-nogdb Disable GDB breakpoint handling (see below)
The listed [files] are expected to be in aout format and will be
loaded in the simulator memory prior. This could be used to load
a boot block at address 0x0 if the application is linked to run
from RAM (0x2000000).
To start debugging a program type 'load <program>' and debug as
usual.
The native simulator commands can be reached using the GDB 'sim'
command:
sim <sis_command>
Direct simulator commands during a GDB session must be issued
with care not to disturb GDB's operation ...
For info on supported ERC32 functionality, see README.sis.
3. Loading aout files
The GDB load command loads an aout file into the simulator
memory with the data section starting directly after the text
section regardless of wich start address was specified for the data
at link time! This means that your applications either has to include
a routine that initialise the data segment at the proper address or
link with the data placed directly after the text section.
A copying routine is fairly simple, just copy all data between
_etext and _data to a memory loaction starting at _environ. This
should be done at the same time as the bss is cleared (in srt0.s).
4. GDB breakpoint handling
GDB inserts breakpoint in the form of the 'ta 1' instruction. The
GDB-integrated simulator will therefore recognize the breakpoint
instruction and return control to GDB. If the application uses
'ta 1', the breakpoint detection can be disabled with the -nogdb
switch. In this case however, GDB breakpoints will not work.
Report problems to Jiri Gaisler ESA/ESTEC (jgais@wd.estec.esa.nl)