Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen RevisionVorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
Nächste ÜberarbeitungBeide Seiten der Revision
software:gdb:start [2016-02-17 12:30] abajricsoftware:gdb:start [2016-02-17 13:34] abajric
Zeile 143: Zeile 143:
  
 .stabs "void:t1=1",N_LSYM,0,0,0 .stabs "void:t1=1",N_LSYM,0,0,0
-.stabs "int:t2=r2;-2147483648;2147483647;",128,0,0,0+.stabs "int:t2=r2;-2147483648;2147483647;",N_LSYM,0,0,0
  
 .data .data
Zeile 275: Zeile 275:
 </code> </code>
  
 +
 +==== Beschreibung der STABS ====
 +
 +Online Doku von GDB:
 +  * [[https://sourceware.org/gdb/current/onlinedocs/gdb/| GDB User Manual]]
 +  * [[https://www.sourceware.org/gdb/onlinedocs/stabs.html| STABS Doku]]
 +  * [[https://sourceware.org/gdb/onlinedocs/stabs/Stab-Symbol-Types.html#Stab-Symbol-Types| STABS Symboltypen]]
 +
 +=== Definition von Typen ===
 +([[https://www.sourceware.org/gdb/onlinedocs/stabs.html#String-Field|String-Field]])
 +Type 1 = void und Type 2 = int.
 +
 +<code>
 +.stabs "void:t1=1",N_LSYM,0,0,0
 +.stabs "int:t2=r2;-2147483648;2147483647;",N_LSYM,0,0,0
 +</code>
 +
 +=== Definition von globalen Variablen ===
 +
 +([[https://www.sourceware.org/gdb/onlinedocs/stabs.html#Global-Variables|Global Variables]])
 +Variable targetCommand an Adresse 0x100000 vom Type 2 = int.
 +
 +<code>
 +.data
 +.org 0x100000
 +.stabs "targetCommand:G2",N_GSYM,0,0,0
 +.global targetCommand
 +targetCommand:
 +.int 0
 +</code>
 +
 +=== Definition vom Java-Sourcecode ===
 +
 +([[https://www.sourceware.org/gdb/onlinedocs/stabs.html#Source-Files|Source Files]])
 +Der erste STABS mit N_SO ist der Build-Ordner. Der Zweite ist der relative Pfad zum Source-File.
 +
 +<code>
 +.org 0x400100
 +.stabs "/home/abajric/ntb/deep/ws/runtime-library/",N_SO,0,0,Ltext0
 +.stabs "src/ch/ntb/inf/deep/runtime/mpc555/Reset.java",N_SO,0,0,Ltext0
 +.text
 +Ltext0:
 +</code>
 +
 +=== Definition von Zeilennummern ===
 +
 +([[https://www.sourceware.org/gdb/onlinedocs/stabs.html#Line-Numbers|Line Numbers]])
 +
 +<code>
 +reset:
 +.stabn N_SLINE, 0, 38, LM1
 +LM1:
 +
 +...
 +
 +.stabn N_SLINE, 0, 41, LM5
 +LM6:
 +
 +...
 +
 +.stabn N_SLINE, 0, 47, LM4
 +LM4:
 +</code>
 +
 +
 +
 +=== Definition von Registervariablen ===
 +([[https://www.sourceware.org/gdb/onlinedocs/stabs.html#Register-Variables|Register Variables]])
 +Registervariablen müssen immer im gleichen Register bleiben. ("r2" => Registervariable vom Type 2 und nicht Register R2, Registernummer ist der letzte Parameter!)
 +
 +<code>
 +.stabs "x:r2;-2147483648;2147483647;",N_RSYM,0,4,2
 +</code>
 +
 +
 +=== Definition von Funktionen ===
 +
 +([[https://www.sourceware.org/gdb/onlinedocs/stabs.html#Procedures|Procedures]]) N_LBRAC und N_RBRAC ist die Position der öffnenden/schliessenden geschweiften Klammern der Funktion.
 +
 +<code>
 +.stabs "ch::ntb::inf::deep::runtime::mpc555::Reset::reset:F1",N_FUN,0,0,reset
 +.stabn N_SLINE, 0, 37, reset
 +.stabn N_LBRAC, 0, 0, LM1
 +.stabn N_RBRAC, 0, 0, LM3
 +</code>
 +
 +==== Debuggen mit GDB ====
 +
 +Damit ein PowerPC Target debugged werden kann muss GDB mit PowerPC Support installiert werden:
 +
 +<code>
 +$ sudo apt-get install gdb-multiarch
 +</code>
 +
 +Bevor GDB gestarted wird, muss das Image-File auf den MPC5200 geladen werden:
 +
 +<code>
 +$ telnet bdi3000inf01
 +pcm5200io> load 0x400000 pub/abajric/test.bin bin
 +pcm5200io> rm pc 0x400100
 +</code>
 +
 +GDB starten:
 +<code>
 +$ gdb-multiarch
 +</code>
 +
 +PowerPC Architektur auswählen:
 +
 +<code>
 +(gdb) set arch powerpc:common
 +</code>
 +
 +ELF-File mit Debug-Informationen auswählen:
 +
 +<code>
 +(gdb) file ./a.out
 +</code>
 +
 +GDB mit Abatron BDI3000 verbinden:
 +
 +<code>
 +(gdb) target remote bdi3000inf01:2001
 +</code>
 +
 +GDB TUI aktivieren und Layout umstellen:
 +
 +<code>
 +(gdb) layout split
 +(gdb) focus cmd
 +</code>
 +
 +Alternativ kann ein File (gdb.cmd) mit diesen GDB-Kommandos erstellt werden:
 +
 +<code>
 +set arch powerpc:common
 +file ./a.out
 +target remote bdi3000inf01:2001
 +layout split
 +focus cmd
 +</code>
 +
 +Beim Ausführen von GDB muss dieses File angegeben werden, damit alle Kommandos im File ausgeführt werden:
 +
 +<code>
 +$ gdb-multiarch -x ./gdb.cmd
 +</code>
 +
 +Mit dem folgenden Befehl kann der Java-Sourcecode angezeigt werden:
 +
 +<code>
 +(gdb) list
 +</code>
 +
 +Mit dem folgenden Befehl wird eine Assembler-Instruktion ausgeführt:
 +
 +<code>
 +(gdb) stepi
 +</code>
 +
 +Mit dem folgenden Befehl wird Code ausgeführt, bis eine neue Source-Zeile erreicht wurde:
 +
 +<code>
 +(gdb) next
 +</code>
 +
 +Mit dem folgenden Befehl wird eine definierte Variable ausgegeben:
 +
 +<code>
 +(gdb) print x
 +</code>
 +
 +Mit dem folgenden Befehl wird eine definierte Variable geändert:
 +
 +<code>
 +(gdb) set var x = 12345
 +</code>
 +
 +Mit dem folgenden Befehl kann im Memory geschrieben werden:
 +
 +<code>
 +(gdb) set var *0x100000 = 12345
 +</code>