jwnhy added a comment.

Hi, guys, I have met this issue #61706 
<https://github.com/llvm/llvm-project/issues/61706>.

The case I provided shows that even without DWARF v2, this problem still exists.

I wonder if such modification is really needed or not.

Also, I am not sure changing all these to `int` actually fixes the issue here.

In fact, in `UpdateValue`, the `m_byte_offset` also changed by the 
`overhang_bytes` in line .
For a bitfield not aligned to `*type_bit_size`, moving `overhang_bytes` will 
cause truncation in the bitfield.

  #pragma pack(1)
  struct  {
    signed f0 : 27;
    unsigned f5 : 30;
  } g_96 = {5070, 1795821};
  int main() {return 0;}

The structure in memory is represented as `0xdb37680013ce`, adding 
`m_byte_offset` with `overhang_bytes` results in `0xdb37`, with last five bits 
lost.

This patchset may fix the underflow problem of `m_bitfield_bit_offset`, but 
does not fix the truncation issue...

Not knowing there is a WIP patch, I have created another smaller patch, which 
just checks... (if it's not ok to hijack the thread, plz tell me...I am really 
newbie...)
https://reviews.llvm.org/D146919

I wonder if it's ok I take over this issue?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D138197

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

Reply via email to