llvm-project/lldb/unittests/Expression
Pavel Labath 4edb7e34f8 [lldb/DWARF] Fix sizes of DW_OP_const[1248][us] and DW_OP_litN results
Dwarf says (Section 2.5.1.1. of DWARF v5) that these operations should
push "generic" (pointer-sized) values. This was not the case for
DW_OP_const operations (which were pushing values based on the size of
arguments), nor DW_OP_litN (which were always pushing 64-bit values).

The practical effect of this that were were unable to display the values
of variables if the size of the DW_OP_const opcode was smaller than the
value of the variable it was describing. This would happen because we
would store this (small) result into a buffer and then would not be able
to read sufficient data out of it (in Value::GetValueAsData). Gcc emits
debug info like this.

Other (more subtle) effects are also possible.

The same fix should be applied to DW_OP_const[us] (leb128 versions), but
I'm not doing that right now, because that would cause us to display
wrong (truncated) values of variables on 32-bit targets (pr48087).

Differential Revision: https://reviews.llvm.org/D90840
2020-11-10 16:10:08 +01:00
..
CMakeLists.txt [lldb/cmake] Fix testing support library dependencies 2020-09-15 13:32:08 +02:00
ClangExpressionDeclMapTest.cpp [lldb][NFC] Move NameSearchContext to own header/source files 2020-02-25 12:25:36 +01:00
ClangParserTest.cpp fix lldb test on lib64 systems 2020-08-03 11:19:07 +02:00
CppModuleConfigurationTest.cpp [lldb] Replace SmallStr.str().str() with std::string conversion operator. 2020-01-29 21:34:19 -08:00
DWARFExpressionTest.cpp [lldb/DWARF] Fix sizes of DW_OP_const[1248][us] and DW_OP_litN results 2020-11-10 16:10:08 +01:00
DiagnosticManagerTest.cpp [lldb][NFC] Fix all formatting errors in .cpp file headers 2020-01-24 08:52:55 +01:00