* [U-Boot-Users] Debugging U-boot after relocation
@ 2003-02-06 1:16 Vladimir Gurevich
2003-02-06 7:10 ` Wolfgang Denk
0 siblings, 1 reply; 3+ messages in thread
From: Vladimir Gurevich @ 2003-02-06 1:16 UTC (permalink / raw)
To: u-boot
Hello,
I am trying to debug U-boot after the code has been relocated and
I got some problems. Maybe I don't know gdb well enough...
BTW, I use ELDK tools and BDI-2000 on PPC405GP-based board.
I can debug U-boot before the relocation step easily. So I
put a breakpoint at the "blr" instruction that preceeds the
"in_ram" label. After it occurs, I issue the following gdb
commands:
(gdb) info line *(&in_ram)
Line 1310 of "/home/vgurevic/vag/u-boot-0.2.0/cpu/ppc4xx/start.S"
starts at address 0xfffc25a8 <in_ram> and ends at 0xfffc25ac <in_ram+4>.
(gdb) file
(gdb) add-symbol-file u-boot 0x7fd0000 <- That's the reloc. addr
(gdb) target remote bdi:2001
(gdb) info line *(&in_ram)
Line 510 of "/home/vgurevic/vag/u-boot-0.2.0/cpu/ppc4xx/start.S"
starts@address 0x7fd26e8 <ext_bus_cntlr_init> and ends at 0xfffc0100.
^^^^^^^^^^^
So that's where the isue is: gdb can't interpret line numbers
correctly anymore and can't show (via ddd or emacs interface)
where you are. It is still possible to step through the code
using "stepi" but not much more.
Does anyone know how to deal with this issue or maybe there is
a totally different way to debug U-boot?
Thanks,
Vladimir
^ permalink raw reply [flat|nested] 3+ messages in thread
* [U-Boot-Users] Debugging U-boot after relocation
2003-02-06 1:16 [U-Boot-Users] Debugging U-boot after relocation Vladimir Gurevich
@ 2003-02-06 7:10 ` Wolfgang Denk
2003-02-07 1:01 ` Vladimir Gurevich
0 siblings, 1 reply; 3+ messages in thread
From: Wolfgang Denk @ 2003-02-06 7:10 UTC (permalink / raw)
To: u-boot
In message <3E41B76C.8060207@paulidav.org> you wrote:
>
> I can debug U-boot before the relocation step easily. So I
> put a breakpoint at the "blr" instruction that preceeds the
> "in_ram" label. After it occurs, I issue the following gdb
> commands:
>
> (gdb) info line *(&in_ram)
> Line 1310 of "/home/vgurevic/vag/u-boot-0.2.0/cpu/ppc4xx/start.S"
> starts at address 0xfffc25a8 <in_ram> and ends at 0xfffc25ac <in_ram+4>.
> (gdb) file
>
> (gdb) add-symbol-file u-boot 0x7fd0000 <- That's the reloc. addr
> (gdb) target remote bdi:2001
>
> (gdb) info line *(&in_ram)
> Line 510 of "/home/vgurevic/vag/u-boot-0.2.0/cpu/ppc4xx/start.S"
> starts at address 0x7fd26e8 <ext_bus_cntlr_init> and ends at 0xfffc0100.
> ^^^^^^^^^^^
>
> So that's where the isue is: gdb can't interpret line numbers
> correctly anymore and can't show (via ddd or emacs interface)
> where you are. It is still possible to step through the code
> using "stepi" but not much more.
Did you use "symbol-file" without argument to delete the old,
flash-based symbol table first? Otherwise GDB may get confused
because there are two sym,bol tables loaded which contain the same
symbols at different addresses.
> Does anyone know how to deal with this issue or maybe there is
> a totally different way to debug U-boot?
Except for the missing (?) "symbol-file" command everything looks OK
to me. And it works here (although I never used "info line" yet).
Best regards,
Wolfgang Denk
--
Software Engineering: Embedded and Realtime Systems, Embedded Linux
Phone: (+49)-8142-4596-87 Fax: (+49)-8142-4596-88 Email: wd at denx.de
If it's working, the diagnostics say it's fine. If it's not working,
the diagnostics say it's fine.
- A proposed addition to rules for realtime programming
^ permalink raw reply [flat|nested] 3+ messages in thread
* [U-Boot-Users] Debugging U-boot after relocation
2003-02-06 7:10 ` Wolfgang Denk
@ 2003-02-07 1:01 ` Vladimir Gurevich
0 siblings, 0 replies; 3+ messages in thread
From: Vladimir Gurevich @ 2003-02-07 1:01 UTC (permalink / raw)
To: u-boot
Hello Wolfgang,
Wolfgang Denk wrote:
> Did you use "symbol-file" without argument to delete the old,
> flash-based symbol table first? Otherwise GDB may get confused
> because there are two sym,bol tables loaded which contain the same
> symbols at different addresses.
Actually, the empty "file" command that I used is supposed to
have the same effect. Anyway, I tried your suggestion, and
problems are still there.
A good example might be:
(gdb) symbol-file
No symbol file now.
(gdb) add-symbol-file u-boot 0x7fd0000
add symbol table from file "u-boot" at
.text_addr = 0x7fd0000
(y or n) y
Reading symbols from u-boot...done.
(gdb) break start.S:1338
Breakpoint 1 at 0xfffc2600: file /home/vgurevic/vag/u-boot-0.2.0/cpu/ppc4xx/start.S, line 1338.
^^^^^^^^^^
(gdb) list 1338
1333 add r0,r0,r11
1334 stw r10,0(r3)
1335 stw r0,0(r4)
1336 bdnz 3b
1337 4:
1338 clear_bss:
1339 /*
1340 * Now clear BSS segment
1341 */
1342 lwz r3,GOT(.bss)
(gdb) p &clear_bss
$1 = (<text variable, no debug info> *) 0x7fd2600 <clear_bss>
As you can see, gdb relocated the address for the
symbol in .text session (clear_bss), but failed to
relocate addresses associated with line numbers.
This completely screwes up ddd and Emacs gdb interfaces,
since they (often) don't know which line to show. This
also screwes up next, step and "execute-till-here"
(implemented via tbreak at a line number).
Can it be a gdb "feature" or there is a way to tell it about
line numbers?
Could you tell me in more details how do you debug U-boot then?
Thanks,
Vladimir
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2003-02-07 1:01 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-02-06 1:16 [U-Boot-Users] Debugging U-boot after relocation Vladimir Gurevich
2003-02-06 7:10 ` Wolfgang Denk
2003-02-07 1:01 ` Vladimir Gurevich
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox