1
Class #509 The Heisenberg Principal of Debugging
A Method for Recording Execution and Program State in a Live Embedded System, for Later Playback and Debugging.
Michael Snyder msnyder@cygnus.com Jim Blandy jimb@cygnus.com
Class #509 The Heisenberg Principal of Debugging A Method for - - PowerPoint PPT Presentation
Class #509 The Heisenberg Principal of Debugging A Method for Recording Execution and Program State in a Live Embedded System, for Later Playback and Debugging. Michael Snyder msnyder@cygnus.com Jim Blandy jimb@cygnus.com 1 W hy Trace
1
Michael Snyder msnyder@cygnus.com Jim Blandy jimb@cygnus.com
2
Embedded Systems Conference - September 1999
3
Embedded Systems Conference - September 1999
4
Embedded Systems Conference - September 1999
5
Embedded Systems Conference - September 1999
(gdb) break tree.c:find (gdb) com m ands > print tree->vector.p[0] @ 3 > print key == tree->key > info registers > info locals > info args > continue > end W hen a breakpoint is executed, the debugger takes control. C om m ands m ay be associated w ith a breakpoint, to be perform ed by the debugger w hen the breakpoint executes. The results of the com m ands go to the debugger’s console. (gdb) trace tree.c:find (gdb) actions > collect tree->vector.p[0] @ 3 > collect tree, tree->key > collect $regs > collect $locals > collect $args > end W hen a tracepoint is executed, the debugger does N O T take control or becom e involved. A ctions m ay be associated w ith a tracepoint, to be perform ed on the target (w ithout any interaction w ith the debugger) w hen the tracepoint executes. The results of the collection actions go into a trace buffer on the target, and are available for later review by the debugger or by autom ated tools.
6
Embedded Systems Conference - September 1999
7
Embedded Systems Conference - September 1999
(gdb) continue Breakpoint #12 at tree.c line 144 (gdb) print key $1 = 12 (gdb) step tree.c line 145 (gdb) print key == tree->key $2 = 0 (gdb) until tree.c:200 tree.c line 200 (gdb) print tree->vector.p[0] @ 3 $3 = {{1,2}, {3,4}, {5,6}} Using the traditional execution commands to stop and start program execution while examining current program state. (gdb) tfind start Tracepoint #12 at tree.c line 144 (gdb) print key $1 = 12 (gdb) tfind next tree.c line 145 (gdb) print key == tree->key $2 = 0 (gdb) tfind line tree.c:200 Tracepoint #3 at tree.c:200 (gdb) print tree->vector.p[0] @ 3 $3 = {{1,2}, {3,4}, {5,6}} Using the ‘tfind’ command to navigate through the trace event records in a trace buffer (collected earlier), while examining recorded program state. Only variables that were collected can be examined. All expressions will evaluate in terms of their past values.
8
Embedded Systems Conference - September 1999
9
Embedded Systems Conference - September 1999
10
Embedded Systems Conference - September 1999
11
Embedded Systems Conference - September 1999
12
Embedded Systems Conference - September 1999
13
Embedded Systems Conference - September 1999
14
Embedded Systems Conference - September 1999
15
Embedded Systems Conference - September 1999
16
Embedded Systems Conference - September 1999
17
Embedded Systems Conference - September 1999
18
Embedded Systems Conference - September 1999
19
Embedded Systems Conference - September 1999
20
Embedded Systems Conference - September 1999
21
Embedded Systems Conference - September 1999
22
Embedded Systems Conference - September 1999
23
Embedded Systems Conference - September 1999
24
Embedded Systems Conference - September 1999
25
Embedded Systems Conference - September 1999
26
Embedded Systems Conference - September 1999
27
Embedded Systems Conference - September 1999
28
Embedded Systems Conference - September 1999
29
Embedded Systems Conference - September 1999