[llvm-commits] PATCH: DebugInfo lib: fix instruction address lookup in line table

Benjamin Kramer benny.kra at gmail.com
Tue Aug 7 04:34:49 PDT 2012


On 07.08.2012, at 13:24, Alexey Samsonov <samsonov at google.com> wrote:

> On Mon, Aug 6, 2012 at 2:50 PM, Benjamin Kramer <benny.kra at gmail.com> wrote:
> 
> On 06.08.2012, at 10:39, Alexey Samsonov <samsonov at google.com> wrote:
> 
> > Benjamin,
> >
> > Could you take a look at this? (or redirect me to someone else for review).
> 
> Sorry, for the delay, been crazy busy over the last weeks.
> 
> This looks good to me.
> 
> Can I submit this?

Sure, go ahead :)

- Ben
>  
> I'm a bit worried because the lookup code was taken pretty much 1:1 from lldb (see source/Plugins/SymbolFile/DWARF/DWARFDebugLine.cpp). Does it have the same bugs?
> 
> - Ben
> 
> >
> > On Wed, Jul 25, 2012 at 9:15 PM, Alexey Samsonov <samsonov at google.com> wrote:
> > Could you please take a look?
> >
> > (re-attaching the patch just in case)
> >
> > On Fri, Jul 20, 2012 at 4:35 PM, Alexey Samsonov <samsonov at google.com> wrote:
> > Hi!
> >
> > This patch fixes the representation of debug line table in DebugInfo LLVM library. Instead of just collection of rows, debug line table for compilation unit is now
> > treated as the number of row ranges, describing sequences [1]. The sequences are not always listed in the order of increasing address, so
> > the previously used std::lower_bound() sometimes produced wrong results. Now the instruction address lookup consists of two stages: finding the
> > correct sequence, and searching for address in range of rows for this sequence.
> >
> > [1] dwarfstd: "Sequence - A series of contiguous target machine instructions. One compilation unit may emit multiple sequences
> > (that is, not all instructions within a compilation unit are assumed to be contiguous)"
> >
> > Code review: http://codereview.appspot.com/6423064/
> >
> > --
> > Alexey Samsonov, MSK
> >
> >
> >
> >
> > --
> > Alexey Samsonov, MSK
> >
> 
> 
> 
> 
> -- 
> Alexey Samsonov, MSK
> 





More information about the llvm-commits mailing list