Programming This forum is for all programming questions.
The question does not have to be directly related to Linux and any language is fair game. |
Notices |
Welcome to LinuxQuestions.org, a friendly and active Linux Community.
You are currently viewing LQ as a guest. By joining our community you will have the ability to post topics, receive our newsletter, use the advanced search, subscribe to threads and access many other special features. Registration is quick, simple and absolutely free. Join our community today!
Note that registered members see fewer ads, and ContentLink is completely disabled once you log in.
Are you new to LinuxQuestions.org? Visit the following links:
Site Howto |
Site FAQ |
Sitemap |
Register Now
If you have any problems with the registration process or your account login, please contact us. If you need to reset your password, click here.
Having a problem logging in? Please visit this page to clear all LQ-related cookies.
Get a virtual cloud desktop with the Linux distro that you want in less than five minutes with Shells! With over 10 pre-installed distros to choose from, the worry-free installation life is here! Whether you are a digital nomad or just looking for flexibility, Shells can put your Linux machine on the device that you want to use.
Exclusive for LQ members, get up to 45% off per month. Click here for more info.
|
 |
03-03-2007, 05:35 PM
|
#1
|
Member
Registered: Apr 2006
Posts: 81
Rep:
|
Debugger selectively not using symbols in library with symbols
I am using DDD (and also kdbg) with GDB. My programming is segfaulting in a function. When I try to debug, I can get to the function that calls that function, but in the stack window the debugger shows the function that actually has the problem as being in a library without debug symbols. It will not show the code for it. The rest of my functions in the stack show up fine, including functions in the same library that won't show up for the problem function.
One thing to note is that there is a small change the library could be dynamically loaded at that point, rather than just dynamically linked. But I would think dl_open()ed libraries would work properly in the debugger.
Is there any likely cause of this?
This is in C/C++.
|
|
|
03-05-2007, 02:56 PM
|
#2
|
Member
Registered: May 2002
Posts: 964
Rep:
|
What you see is expected debugger behavior.
What you passed to the library is highly suspect. Unless you wrote it as well.
You can see this with non-null terminated strings going into string.h library routines like strcmp() or strchr().
|
|
|
03-08-2007, 05:19 PM
|
#3
|
Member
Registered: Apr 2006
Posts: 81
Original Poster
Rep:
|
Quote:
Originally Posted by jim mcnamara
What you passed to the library is highly suspect.
|
What do you mean by this, and why would it make the debugger do this?
I'd like to add that this is the only C++ function in the stack, if that could be an issue.
|
|
|
03-09-2007, 01:03 PM
|
#4
|
Member
Registered: May 2002
Posts: 964
Rep:
|
You didn't mention C++.
The 'suspect' thing is: let's assume you are calling a well-tested library module that is stack dumping. The most common cause for a stack dump in this case is a bad pointer. If you are calling a brand-new library that you wrote, then you can compile the library so that symbols are retained. And since the library is untested, it could likely be a problem in the library code as well.
C++ links code to some different base run-time libraries as well as stdc libraries.
|
|
|
03-25-2007, 09:14 AM
|
#5
|
Member
Registered: Apr 2006
Posts: 81
Original Poster
Rep:
|
The library is not brand new, and has been extensively tested, but not on linux. There could be a bad pointer.
As I understand it, you're saying some problems prevent the debugger from showing code for a function?
How can this be remedied?
|
|
|
03-25-2007, 09:44 AM
|
#6
|
HCL Maintainer
Registered: Jan 2006
Distribution: (H)LFS, Gentoo
Posts: 2,450
Rep:
|
Quote:
Originally Posted by Millenniumman
The library is not brand new, and has been extensively tested, but not on linux. There could be a bad pointer.
As I understand it, you're saying some problems prevent the debugger from showing code for a function?
How can this be remedied?
|
Recompile the said library with debugging symbols.
|
|
|
All times are GMT -5. The time now is 10:49 AM.
|
LinuxQuestions.org is looking for people interested in writing
Editorials, Articles, Reviews, and more. If you'd like to contribute
content, let us know.
|
Latest Threads
LQ News
|
|