Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende ÜberarbeitungNächste ÜberarbeitungBeide Seiten der Revision | ||
software:gdb:start [2016-02-17 12:29] – abajric | software:gdb:start [2018-04-13 11:18] – mgehrig2 | ||
---|---|---|---|
Zeile 6: | Zeile 6: | ||
* [[https:// | * [[https:// | ||
</ | </ | ||
+ | ===== Hauptfunktionen des GDB ===== | ||
Der GNU Debugger erlaubt es, zu sehen, was in einem Programm während der Ausführung passiert oder was ein Programm zuletzt gemacht vor einem Absturz. | Der GNU Debugger erlaubt es, zu sehen, was in einem Programm während der Ausführung passiert oder was ein Programm zuletzt gemacht vor einem Absturz. | ||
Zeile 14: | Zeile 14: | ||
* Untersuchen was geschehen ist, wenn das Programm angehalten wurde | * Untersuchen was geschehen ist, wenn das Programm angehalten wurde | ||
* Inhalt des Speichers ändern | * Inhalt des Speichers ändern | ||
+ | |||
===== Handhabung ===== | ===== Handhabung ===== | ||
- | GDB ist in vielen [[http:// | + | GDB ist in vielen [[http:// |
- | + | Das ist besonders nütztlich, um ein Segfault zu überprüfen. | |
- | '' | + | |
- | + | ||
- | Programm starten: | + | |
- | + | ||
- | '' | + | |
- | + | ||
- | Programm beenden: | + | |
- | + | ||
- | '' | + | |
- | GDB beenden: | + | Mehr dazu unter im [[software:gdb: |
- | '' | ||
- | Alle GDB Befehle | + | ===== Coredumps ===== |
+ | Mit Coredumps | ||
+ | Ein // | ||
+ | Es ist ebenfalls möglich, lokale Variablen nach dem Absturz zu untersuchen. | ||
- | '' | + | Mehr dazu unter unter [[software: |
Zeile 141: | Zeile 135: | ||
< | < | ||
.include " | .include " | ||
+ | |||
+ | .stabs " | ||
+ | .stabs " | ||
.data | .data | ||
Zeile 154: | Zeile 151: | ||
.text | .text | ||
Ltext0: | Ltext0: | ||
- | |||
- | .stabs " | ||
- | .stabs " | ||
reset: | reset: | ||
Zeile 275: | Zeile 269: | ||
</ | </ | ||
+ | |||
+ | ==== Beschreibung der STABS ==== | ||
+ | |||
+ | Online Doku von GDB: | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | |||
+ | === Definition von Typen === | ||
+ | ([[https:// | ||
+ | Type 1 = void und Type 2 = int. | ||
+ | |||
+ | < | ||
+ | .stabs " | ||
+ | .stabs " | ||
+ | </ | ||
+ | |||
+ | === Definition von globalen Variablen === | ||
+ | |||
+ | ([[https:// | ||
+ | Variable targetCommand an Adresse 0x100000 vom Type 2 = int. | ||
+ | |||
+ | < | ||
+ | .data | ||
+ | .org 0x100000 | ||
+ | .stabs " | ||
+ | .global targetCommand | ||
+ | targetCommand: | ||
+ | .int 0 | ||
+ | </ | ||
+ | |||
+ | === Definition vom Java-Sourcecode === | ||
+ | |||
+ | ([[https:// | ||
+ | Der erste STABS mit N_SO ist der Build-Ordner. Der Zweite ist der relative Pfad zum Source-File. | ||
+ | |||
+ | < | ||
+ | .org 0x400100 | ||
+ | .stabs "/ | ||
+ | .stabs " | ||
+ | .text | ||
+ | Ltext0: | ||
+ | </ | ||
+ | |||
+ | === Definition von Zeilennummern === | ||
+ | |||
+ | ([[https:// | ||
+ | |||
+ | < | ||
+ | reset: | ||
+ | .stabn N_SLINE, 0, 38, LM1 | ||
+ | LM1: | ||
+ | |||
+ | ... | ||
+ | |||
+ | .stabn N_SLINE, 0, 41, LM5 | ||
+ | LM6: | ||
+ | |||
+ | ... | ||
+ | |||
+ | .stabn N_SLINE, 0, 47, LM4 | ||
+ | LM4: | ||
+ | </ | ||
+ | |||
+ | |||
+ | |||
+ | === Definition von Registervariablen === | ||
+ | ([[https:// | ||
+ | Registervariablen müssen immer im gleichen Register bleiben. (" | ||
+ | |||
+ | < | ||
+ | .stabs " | ||
+ | </ | ||
+ | |||
+ | |||
+ | === Definition von Funktionen === | ||
+ | |||
+ | ([[https:// | ||
+ | |||
+ | < | ||
+ | .stabs " | ||
+ | .stabn N_SLINE, 0, 37, reset | ||
+ | .stabn N_LBRAC, 0, 0, LM1 | ||
+ | .stabn N_RBRAC, 0, 0, LM3 | ||
+ | </ | ||
+ | |||
+ | ==== Debuggen mit GDB ==== | ||
+ | |||
+ | Damit ein PowerPC Target debugged werden kann muss GDB mit PowerPC Support installiert werden: | ||
+ | |||
+ | < | ||
+ | $ sudo apt-get install gdb-multiarch | ||
+ | </ | ||
+ | |||
+ | Bevor GDB gestarted wird, muss das Image-File auf den MPC5200 geladen werden: | ||
+ | |||
+ | < | ||
+ | $ telnet bdi3000inf01 | ||
+ | pcm5200io> | ||
+ | pcm5200io> | ||
+ | </ | ||
+ | |||
+ | GDB starten: | ||
+ | < | ||
+ | $ gdb-multiarch | ||
+ | </ | ||
+ | |||
+ | PowerPC Architektur auswählen: | ||
+ | |||
+ | < | ||
+ | (gdb) set arch powerpc: | ||
+ | </ | ||
+ | |||
+ | ELF-File mit Debug-Informationen auswählen: | ||
+ | |||
+ | < | ||
+ | (gdb) file ./a.out | ||
+ | </ | ||
+ | |||
+ | GDB mit Abatron BDI3000 verbinden: | ||
+ | |||
+ | < | ||
+ | (gdb) target remote bdi3000inf01: | ||
+ | </ | ||
+ | |||
+ | GDB TUI aktivieren und Layout umstellen: | ||
+ | |||
+ | < | ||
+ | (gdb) layout split | ||
+ | (gdb) focus cmd | ||
+ | </ | ||
+ | |||
+ | Alternativ kann ein File (gdb.cmd) mit diesen GDB-Kommandos erstellt werden: | ||
+ | |||
+ | < | ||
+ | set arch powerpc: | ||
+ | file ./a.out | ||
+ | target remote bdi3000inf01: | ||
+ | layout split | ||
+ | focus cmd | ||
+ | </ | ||
+ | |||
+ | Beim Ausführen von GDB muss dieses File angegeben werden, damit alle Kommandos im File ausgeführt werden: | ||
+ | |||
+ | < | ||
+ | $ gdb-multiarch -x ./gdb.cmd | ||
+ | </ | ||
+ | |||
+ | Mit dem folgenden Befehl kann der Java-Sourcecode angezeigt werden: | ||
+ | |||
+ | < | ||
+ | (gdb) list | ||
+ | </ | ||
+ | |||
+ | Mit dem folgenden Befehl wird eine Assembler-Instruktion ausgeführt: | ||
+ | |||
+ | < | ||
+ | (gdb) stepi | ||
+ | </ | ||
+ | |||
+ | Mit dem folgenden Befehl wird Code ausgeführt, | ||
+ | |||
+ | < | ||
+ | (gdb) next | ||
+ | </ | ||
+ | |||
+ | Mit dem folgenden Befehl wird eine definierte Variable ausgegeben: | ||
+ | |||
+ | < | ||
+ | (gdb) print x | ||
+ | </ | ||
+ | |||
+ | Mit dem folgenden Befehl wird eine definierte Variable geändert: | ||
+ | |||
+ | < | ||
+ | (gdb) set var x = 12345 | ||
+ | </ | ||
+ | |||
+ | Mit dem folgenden Befehl kann im Memory geschrieben werden: | ||
+ | |||
+ | < | ||
+ | (gdb) set var *0x100000 = 12345 | ||
+ | </ |