* Unable to find dynamic linker breakpoint function.
@ 2005-02-25 8:04 Hareesh Nagarajan
2005-02-25 17:45 ` Kris Warkentin
0 siblings, 1 reply; 5+ messages in thread
From: Hareesh Nagarajan @ 2005-02-25 8:04 UTC (permalink / raw)
To: GDB
Hi,
I know this question has been posted before, but I am posting this again
because I don't know how to fix this warning;
1. warning: Unable to find dynamic linker breakpoint function.
GDB will be unable to debug shared library initializers
and track explicitly loaded dynamic code.
And then, how must I fix this problem;
2. The program being debugged stopped while in a function called from
GDB. When the function (std::string::at(unsigned) const) is done
executing, GDB will silently stop (instead of continuing to evaluate the
expression containing the function call).
My gdb run appears below.
Thanks,
Hareesh
PS: I'm running GDB 6.0. libstdc++ and glibc have been compiled with
DEBUG information.
(gdb) r
Starting program: /home/hareesh/new
warning: Unable to find dynamic linker breakpoint function.
GDB will be unable to debug shared library initializers
and track explicitly loaded dynamic code.
l
Program exited normally.
(gdb) l
1 #include <iostream>
2 #include <string>
3 using namespace std;
4
5 int main(void)
6 {
7 string x("heloo");
8 cout << x.at(2);
9 }
(gdb) b 8
Breakpoint 1 at 0x80488a6: file new.cc, line 8.
(gdb) r
Starting program: /home/hareesh/new
warning: Unable to find dynamic linker breakpoint function.
GDB will be unable to debug shared library initializers
and track explicitly loaded dynamic code.
Breakpoint 1, main () at new.cc:8
8 cout << x.at(2);
(gdb) inspect x
$1 = {static npos = 4294967295, _M_dataplus = {<allocator<char>> = {<No
data fields>}, _M_p = 0x804a05c "heloo"},
static _S_empty_rep_storage = {0, 0, 0, 0}}
(gdb) inspect x.at(2)
Breakpoint 1, main () at new.cc:8
8 cout << x.at(2);
The program being debugged stopped while in a function called from GDB.
When the function (std::string::at(unsigned) const) is done executing,
GDB will silently
stop (instead of continuing to evaluate the expression containing
the function call).
(gdb)
^ permalink raw reply [flat|nested] 5+ messages in thread* Re: Unable to find dynamic linker breakpoint function.
2005-02-25 8:04 Unable to find dynamic linker breakpoint function Hareesh Nagarajan
@ 2005-02-25 17:45 ` Kris Warkentin
2005-02-25 20:20 ` Hareesh Nagarajan
0 siblings, 1 reply; 5+ messages in thread
From: Kris Warkentin @ 2005-02-25 17:45 UTC (permalink / raw)
To: Hareesh Nagarajan; +Cc: GDB
I think you're seeing two different problems here but they may have the
same root. Gdb may be finding the wrong glibc - that is, not the same
one that the program is using. Try 'info shared' to see what gdb is using.
As far as the stop goes, string::at(2) may have been inlined in which
case the breakpoint may well be in that code. You might want to look at
the assembly. Try breaking on seven, nexting to 8 and see if you get
the same result. Or clear the breakpoint before calling x.at(2).
Possibly the weird break is due to the wrong libc as above though.
cheers,
Kris
Hareesh Nagarajan wrote:
>Hi,
>
>I know this question has been posted before, but I am posting this again
>
>because I don't know how to fix this warning;
>
>1. warning: Unable to find dynamic linker breakpoint function.
>GDB will be unable to debug shared library initializers
>and track explicitly loaded dynamic code.
>
>And then, how must I fix this problem;
>
>2. The program being debugged stopped while in a function called from
>GDB. When the function (std::string::at(unsigned) const) is done
>executing, GDB will silently stop (instead of continuing to evaluate the
>
>expression containing the function call).
>
>My gdb run appears below.
>
>Thanks,
>
>Hareesh
>
>PS: I'm running GDB 6.0. libstdc++ and glibc have been compiled with
>DEBUG information.
>
>(gdb) r
>Starting program: /home/hareesh/new
>warning: Unable to find dynamic linker breakpoint function.
>GDB will be unable to debug shared library initializers
>and track explicitly loaded dynamic code.
>l
>Program exited normally.
>(gdb) l
>1 #include <iostream>
>2 #include <string>
>3 using namespace std;
>4
>5 int main(void)
>6 {
>7 string x("heloo");
>8 cout << x.at(2);
>9 }
>(gdb) b 8
>Breakpoint 1 at 0x80488a6: file new.cc, line 8.
>(gdb) r
>Starting program: /home/hareesh/new
>warning: Unable to find dynamic linker breakpoint function.
>GDB will be unable to debug shared library initializers
>and track explicitly loaded dynamic code.
>
>Breakpoint 1, main () at new.cc:8
>8 cout << x.at(2);
>(gdb) inspect x
>$1 = {static npos = 4294967295, _M_dataplus = {<allocator<char>> = {<No
>data fields>}, _M_p = 0x804a05c "heloo"},
> static _S_empty_rep_storage = {0, 0, 0, 0}}
>(gdb) inspect x.at(2)
>
>Breakpoint 1, main () at new.cc:8
>8 cout << x.at(2);
>The program being debugged stopped while in a function called from GDB.
>When the function (std::string::at(unsigned) const) is done executing,
>GDB will silently
>stop (instead of continuing to evaluate the expression containing
>the function call).
>(gdb)
>
>
^ permalink raw reply [flat|nested] 5+ messages in thread* Re: Unable to find dynamic linker breakpoint function.
2005-02-25 17:45 ` Kris Warkentin
@ 2005-02-25 20:20 ` Hareesh Nagarajan
2005-02-25 21:00 ` Kris Warkentin
0 siblings, 1 reply; 5+ messages in thread
From: Hareesh Nagarajan @ 2005-02-25 20:20 UTC (permalink / raw)
To: GDB; +Cc: Kris Warkentin
Kris Warkentin wrote:
> I think you're seeing two different problems here but they may have the
> same root. Gdb may be finding the wrong glibc - that is, not the same
> one that the program is using. Try 'info shared' to see what gdb is using.
I don't know how 'info shared' helps, but this might:
hareesh: hareesh/ $ ldd new
linux-gate.so.1 => (0xffffe000)
libstdc++.so.5 =>
/usr/lib/gcc-lib/i686-pc-linux-gnu/3.3.4/libstdc++.so.5 (0xb7f0d000)
libm.so.6 => /lib/libm.so.6 (0xb7eeb000)
libgcc_s.so.1 =>
/usr/lib/gcc-lib/i686-pc-linux-gnu/3.3.4/libgcc_s.so.1 (0xb7ee2000)
libc.so.6 => /lib/libc.so.6 (0xb7dce000)
/lib/ld-linux.so.2 => /lib/ld-linux.so.2 (0xb7fea000)
I have compiled libstdc++ with '-g -fomit-frame-pointer'.
Additionally, I use Gentoo Linux and that this problem of mine affects
debugging member functions of C++ STL containers. So how could the wrong
glibc be the problem?
> As far as the stop goes, string::at(2) may have been inlined in which
> case the breakpoint may well be in that code. You might want to look at
> the assembly. Try breaking on seven, nexting to 8 and see if you get
> the same result. Or clear the breakpoint before calling x.at(2).
I did that. But that doesn't change anything as can be seen below.
Breakpoint 1, main () at new.cc:7
7 string x("heloo");
(gdb) n
8 cout << x.at(2);
(gdb) inspect x.at(2)
Breakpoint 1, main () at new.cc:7
7 string x("heloo");
The program being debugged stopped while in a function called from GDB.
When the function (std::string::at(unsigned) const) is done executing,
GDB will silently stop (instead of continuing to evaluate the expression
containing the function call).
I have no idea how to fix this problem and it is frankly driving me mad!
Thanks,
Hareesh
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2005-02-25 21:00 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-02-25 8:04 Unable to find dynamic linker breakpoint function Hareesh Nagarajan
2005-02-25 17:45 ` Kris Warkentin
2005-02-25 20:20 ` Hareesh Nagarajan
2005-02-25 21:00 ` Kris Warkentin
2005-02-28 16:05 ` Hareesh Nagarajan
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox