JosephTremoulet added a comment.

> I'm guessing on this Linux system, you've got a trap receiver function on the 
> stack that is on its first instruction or something? So backing up the pc 
> value for *that* frame is the problem you're solving.
> ...
>  Just just to check, we've got a backtrace like...

Yes, it's just like you describe.

> I think Unwind::GetFrameInfoAtIndex can take a new output argument, bool 
> behaves_like_zeroth_frame. It would be set to true if idx == 0 or if 
> m_frames[idx - 1].IsTrapHandlerFrame() is true.
> StackFrame.h would pick up a new ivar m_behaves_like_zeroth_frame and 
> accessor method BehavesLikeZerothFrame().
> StackFrameList::GetFramesUpTo will fetch the value via 
> unwinder->GetFrameInfoAtIndex() and pass it as an argument to the 
> StackFrame::StackFrame ctor.
> Then in StackFrame::GetSymbolContext we can use the 
> m_behaves_like_zeroth_frame to fix the symbol lookup logic.
> I'm not wedded to the behaves_like_zeroth_frame nomenclature. But I think 
> this approach makes sense.

Makes sense to me too, thanks for the pointers.  I think I'll upload that as a 
separate patch to keep the reviews incremental, but maybe commit them 
back-to-back since the second would improve any diagnostics if the first fails 
on other platforms.

> Anyway this looks fine to me.

Is that a green light to commit the change (modulo figuring out the issue that 
Jan reported which I'm not able to reproduce), or does that mean LGTY but I 
should get sign-off from someone else as well?  (Sorry if I'm being dense, just 
haven't committed changes to lldb before and want to make sure I understand the 
workflow, and noticed you didn't mark the Phab review as "accepted", wondering 
if that's significant)

Thanks!


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D63667/new/

https://reviews.llvm.org/D63667



_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to