Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: Richard Earnshaw <rearnsha@arm.com>
To: Daniel Jacobowitz <drow@mvista.com>
Cc: Richard.Earnshaw@buzzard.freeserve.co.uk,
	gdb-patches@sources.redhat.com, Richard.Earnshaw@arm.com
Subject: Re: [RFA] Repost ARM frame patches
Date: Fri, 05 Sep 2003 09:50:00 -0000	[thread overview]
Message-ID: <200309050950.h859oNV23553@pc960.cambridge.arm.com> (raw)
In-Reply-To: Your message of "Wed, 03 Sep 2003 16:41:40 EDT." <20030903204139.GA9605@nevyn.them.org>

> On Tue, Sep 02, 2003 at 11:52:26PM +0100, Richard Earnshaw wrote:
> > Daniel,
> > 
> > My appologies for not reviewing this before.  Just way too much day job...
> > 
> > It looks fine to me (at least, it seems better than what's there at 
> > present).
> > 
> > My only question is, once we start using the dwarf2 unwinder, can it cope 
> > with the fact that gcc currently does not emit frame unwind information 
> > for Thumb code? (ie can it handle a mix of code that uses dwarf2 and 
> > traditional unwinding?)
> 
> I was going to say yes, but...
> 
> drow@nevyn:/big/fsf/projects/arm/obj/gdb/testsuite/interwork% readelf -wf test1.o
> The section .debug_frame contains:
> 
> 00000000 0000000c ffffffff CIE
>   Version:               1
>   Augmentation:          ""
>   Code alignment factor: 1
>   Data alignment factor: -4
>   Return address column: 14
> 
>   DW_CFA_def_cfa: r13 ofs 0
> 
> 00000010 0000000c 00000000 FDE cie=00000000 pc=00000000..0000001c
> 
> 00000020 0000000c 00000000 FDE cie=00000000 pc=0000001c..00000046
> 
> 
> i.e. GCC emits _empty_ dwarf unwind information for thumb functions,
> rather than none at all.  That's unlikely to work.  We'd need to modify
> the dwarf2 unwinder to ignore empty FDEs.
> 
> I'll check in the non-dwarf parts now, and then we can figure out what
> to do about that.

Though of course a trivial leaf function *will* have an empty FDE.  
Consider

int func(void) { return 0;}

Which compiles to 

	mov	r0, #0
	bx	lr

I would have thought that wouldn't need any frame unwind information.  So 
we would have a problem distinguishing trivial cases from "not generated" 
cases.

R.


  reply	other threads:[~2003-09-05  9:50 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2003-08-29  1:50 Daniel Jacobowitz
2003-09-02 22:56 ` Richard Earnshaw
2003-09-03 20:41   ` Daniel Jacobowitz
2003-09-05  9:50     ` Richard Earnshaw [this message]
2003-09-05 20:43       ` Andrew Cagney
2004-02-08  4:11       ` Daniel Jacobowitz
2004-02-09 12:12         ` Richard Earnshaw

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=200309050950.h859oNV23553@pc960.cambridge.arm.com \
    --to=rearnsha@arm.com \
    --cc=Richard.Earnshaw@arm.com \
    --cc=Richard.Earnshaw@buzzard.freeserve.co.uk \
    --cc=drow@mvista.com \
    --cc=gdb-patches@sources.redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox