CarlosAlbertoEnciso wrote:

As pointed out by @Michael137 

> If we're given the `_vtable$` artificial member, there's nothing useful we 
> can do with it right?
```
0x00000042:   DW_TAG_variable
                DW_AT_specification (0x0000005c "_vtable$")
                DW_AT_alignment     (8)
                DW_AT_location      (DW_OP_addrx 0x1)
                DW_AT_linkage_name  ("_ZTV8CDerived")

0x0000004c:   DW_TAG_structure_type ("CDerived")
                ...
0x0000005c:     DW_TAG_variable
                  DW_AT_name  ("_vtable$")
                  DW_AT_type  (0x00000041 "void *")
                  DW_AT_external    (true)
                  DW_AT_declaration (true)
                  DW_AT_artificial  (true)
                  DW_AT_accessibility     (DW_ACCESS_private)
                  DW_AT_containing_type <0x00000042>  --> VTable global variable
              ...

.debug_addr contents:
Addrs: [
0x0000000000000000
0x0000000000000000  <- DW_OP_addrx 0x1
0x0000000000000000
]
```
And taking a variation of what @tromey described, maybe we can add a 
`DW_AT_containing_type` pointing back to the global variable, providing 2 ways 
to use the new vtable information entry:
- Given the `_vtable$` artificial member: use the `DW_AT_containing_type` to 
find the vtable global variable.
- Given the vtable global variable: use the `DW_AT_specification` to find the 
object definition.


https://github.com/llvm/llvm-project/pull/130255
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to