http://gcc.gnu.org/bugzilla/show_bug.cgi?id=54572



--- Comment #12 from Janne Blomqvist <jb at gcc dot gnu.org> 2012-11-30 
21:56:29 UTC ---

(In reply to comment #9)

> (In reply to comment #7)

> > Why are there no line numbers in the backtrace from gdb?  You said you 
> > compiled

> > with -g.  Are you sure that libbacktrace itself was compiled with -g?

> 

> I meant that I compiled the Fortran testcase with -g; GCC itself, including

> libbacktrace, was built with default flags which ought to be "-O2 -g", but I

> didn't specifically check how libbacktrace was built. Now that you mention it,

> it does indeed seem like libbacktrace doesn't have debug symbols for some

> reason.



So yes, libbacktrace is compiled with debug information, however, the issue was

that gdb 7.4 couldn't handle some DWARF-4 specific stuff which for some reason

were generated for the libbacktrace object files (??). I upgraded to GDB 7.5,

and now I get the following backtrace:



(gdb) r

Starting program:

/home/janne/src/gfortran/my-patches/pr54572-libbacktrace/bt2.g 



Program received signal SIGFPE, Arithmetic exception.

0x000000000040086b in test::c (num=1, denum=0, res=32767) at bt2.f90:5

5           res = num / denum

(gdb) c

Continuing.



Program received signal SIGFPE: Floating-point exception - erroneous arithmetic

operation.



Backtrace for this error:



Program received signal SIGSEGV, Segmentation fault.

read_uint32 (buf=buf@entry=0x7fffffffc730) at

../../../trunk-git/libbacktrace/dwarf.c:458

458         return (((uint32_t) p[3] << 24) | ((uint32_t) p[2] << 16)

(gdb) bt

#0  read_uint32 (buf=buf@entry=0x7fffffffc730) at

../../../trunk-git/libbacktrace/dwarf.c:458

#1  0x00007ffff7bb53be in build_address_map (addrs=0x7fffffffc710,

data=0x7fffffffcf1c, 

    error_callback=0x7ffff7ad51f0 <error_callback>, is_bigendian=0,

dwarf_str_size=360, 

    dwarf_str=0x7ffff7ff71e3 "integer(kind=4)", dwarf_ranges_size=0, 

    dwarf_ranges=0x7ffff7ff6000 <Address 0x7ffff7ff6000 out of bounds>,

dwarf_abbrev_size=253, 

    dwarf_abbrev=0x7ffff7ff708f

"\001\021\001%\016\023\vB\v\003\016\033\016\021\001\022\001\020\006", 

    dwarf_info_size=484, dwarf_info=0x7ffff7ff6eab <Address 0x7ffff7ff6eab out

of bounds>, 

    base_address=<optimized out>, state=<optimized out>) at

../../../trunk-git/libbacktrace/dwarf.c:1299

#2  build_dwarf_data (data=0x7fffffffcf1c, error_callback=0x7ffff7ad51f0

<error_callback>, is_bigendian=0, 

    dwarf_str_size=360, dwarf_str=0x7ffff7ff71e3 "integer(kind=4)",

dwarf_ranges_size=0, 

    dwarf_ranges=0x7ffff7ff6000 <Address 0x7ffff7ff6000 out of bounds>,

dwarf_abbrev_size=253, 

    dwarf_abbrev=0x7ffff7ff708f

"\001\021\001%\016\023\vB\v\003\016\033\016\021\001\022\001\020\006", 

    dwarf_line_size=<optimized out>, dwarf_line=<optimized out>,

dwarf_info_size=484, 

    dwarf_info=0x7ffff7ff6eab <Address 0x7ffff7ff6eab out of bounds>,

base_address=<optimized out>, 

    state=<optimized out>) at ../../../trunk-git/libbacktrace/dwarf.c:2822

#3  backtrace_dwarf_add (state=state@entry=0x7ffff7ff8000,

base_address=base_address@entry=0, 

    dwarf_info=0x7ffff7ff6eab <Address 0x7ffff7ff6eab out of bounds>,

dwarf_info_size=484, 

    dwarf_line=0x7ffff7ff718c "S", dwarf_line_size=87, 

    dwarf_abbrev=0x7ffff7ff708f

"\001\021\001%\016\023\vB\v\003\016\033\016\021\001\022\001\020\006", 

    dwarf_abbrev_size=253, dwarf_ranges=0x7ffff7ff6000 <Address 0x7ffff7ff6000

out of bounds>, dwarf_ranges_size=0, 

    dwarf_str=0x7ffff7ff71e3 "integer(kind=4)", dwarf_str_size=360,

is_bigendian=0, 

    error_callback=error_callback@entry=0x7ffff7ad51f0 <error_callback>,

data=data@entry=0x7fffffffcf1c, 

    fileline_fn=fileline_fn@entry=0x7fffffffcb18) at

../../../trunk-git/libbacktrace/dwarf.c:2881

#4  0x00007ffff7bb72a7 in elf_add (state=state@entry=0x7ffff7ff8000,

descriptor=<optimized out>, 

    base_address=base_address@entry=0,

error_callback=error_callback@entry=0x7ffff7ad51f0 <error_callback>, 

    data=data@entry=0x7fffffffcf1c,

fileline_fn=fileline_fn@entry=0x7fffffffcb18, 

    found_sym=found_sym@entry=0x7fffffffcb10,

found_dwarf=found_dwarf@entry=0x7fffffffcb14)

    at ../../../trunk-git/libbacktrace/elf.c:757

#5  0x00007ffff7bb7696 in backtrace_initialize

(state=state@entry=0x7ffff7ff8000, descriptor=<optimized out>, 

    error_callback=error_callback@entry=0x7ffff7ad51f0 <error_callback>,

data=data@entry=0x7fffffffcf1c, 

    fileline_fn=fileline_fn@entry=0x7fffffffcb98) at

../../../trunk-git/libbacktrace/elf.c:858

#6  0x00007ffff7bb630d in fileline_initialize

(state=state@entry=0x7ffff7ff8000, 

    error_callback=error_callback@entry=0x7ffff7ad51f0 <error_callback>,

data=data@entry=0x7fffffffcf1c)

    at ../../../trunk-git/libbacktrace/fileline.c:144

#7  0x00007ffff7bb6427 in backtrace_pcinfo (state=0x7ffff7ff8000,

pc=140737348719229, 

    callback=0x7ffff7ad5170 <full_callback>, error_callback=0x7ffff7ad51f0

<error_callback>, data=0x7fffffffcf1c)

    at ../../../trunk-git/libbacktrace/fileline.c:184

#8  0x00007ffff7bb6831 in unwind (context=<optimized out>,

vdata=0x7fffffffced0)

    at ../../../trunk-git/libbacktrace/backtrace.c:83

#9  0x00007ffff75b9f49 in _Unwind_Backtrace (trace=trace@entry=0x7ffff7bb67e0

<unwind>, 

    trace_argument=trace_argument@entry=0x7fffffffced0) at

../../../trunk-git/libgcc/unwind.inc:295

#10 0x00007ffff7bb6885 in backtrace_full (state=state@entry=0x7ffff7ff8000,

skip=skip@entry=0, 

    callback=callback@entry=0x7ffff7ad5170 <full_callback>, 

    error_callback=error_callback@entry=0x7ffff7ad51f0 <error_callback>,

data=data@entry=0x7fffffffcf1c)

    at ../../../trunk-git/libbacktrace/backtrace.c:106

#11 0x00007ffff7ad527e in _gfortrani_show_backtrace

(in_signal_handler=in_signal_handler@entry=1)

    at ../../../trunk-git/libgfortran/runtime/backtrace.c:92

#12 0x00007ffff7ad5888 in _gfortrani_backtrace_handler (signum=8)

    at ../../../trunk-git/libgfortran/runtime/compile_options.c:129

#13 <signal handler called>

#14 0x000000000040086b in test::c (num=1, denum=0, res=32767) at bt2.f90:5

#15 0x0000000000400848 in test::b (n=1, d=0, r=32767) at bt2.f90:10

---Type <return> to continue, or q <return> to quit---

#16 0x000000000040081b in test::a (n=1, d=0, r=32767) at bt2.f90:15

#17 0x0000000000400898 in bt () at bt2.f90:22

#18 0x0000000000400930 in main (argc=1, argv=0x7fffffffdac1) at bt2.f90:20

#19 0x00007ffff6fd176d in __libc_start_main (main=0x4008fc <main>, argc=1,

ubp_av=0x7fffffffd718, init=<optimized out>, 

    fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7fffffffd708)

at libc-start.c:226

#20 0x0000000000400709 in _start ()





As an aside, my binutils is also old enough (2.22) to not handle DWARF-4 fully

(e.g. addr2line doesn't understand it, objdump -W complains..), but as I

understand it libbacktrace has a self-contained dwarf parser so it shouldn't

matter, right?



> (In reply to comment #8)

> > The crash within libbacktrace is occurring as it tries to read the debug 
> > info. 

> > This is presumably a bug in libbacktrace, but I don't know what the problem 
> > is

> > without more information.  libbacktrace is pretty careful to only read 
> > memory

> > that was explicitly read.  There is presumably a bug there, but I don't know

> > what it is.

> > 

> > I doubt the fact that a signal occurred has anything to do with this.  There

> > seems to be something odd about the debug info, as shown both by the fact 
> > that

> > libbacktrace crashes trying to read it and that gdb does not display 
> > file/line

> > information.

> 

> I forgot to mention, that I'm able to get a symbolic backtrace from outside a

> signal handler. Though in that case my testcase used external procedures 
> rather

> than module procedures, so I guess it's possible there's a bug in handling

> debug info for module procedures. I'll recheck this..



Another strange thing, if I compile the test example from #c5 with "-g

-static", then it works as expected. As a summary, 



1) -g => fails with backtrace above



2) -g -static => success, symbolic backtrace



3) Without -g => success, non-symbolic backtrace





I'm baffled..

Reply via email to