Files
clang-p2996/debuginfo-tests/dexter-tests/memvars/implicit-ptr.c
OCHyams 66d03af88c [DebugInfo][dexter] Add dexter tests for escaped locals
Recently there has been renewed interest in improving debug-info for variables
that (partially or otherwise) live on the stack in optimised code.

At the moment instcombine speculates that stack slots are probably going to be
promoted to registers, and prepares the debug-info accordingly. It runs a
function called LowerDbgDeclare which converts dbg.declares to a set of
dbg.values after loads, and before stores and calls. Sometimes the stack
location remains (e.g. for escaped locals). If any dbg.values become undef
where the stack location is still valid we end up unnecessarily reducing
variable location coverage due to our inability to track multiple locations
simultaneously. There is a flag to disable this feature
(-instcombine-lower-dbg-declare=0), which prevents this conversion at the cost
of sometimes providing incorrect location info in the face of DSE, DCE, GVN,
CSE etc.

This has been discussed fairly extensively on PR34136.

The idea of these tests is to provide examples of situations that we should
consider when designing a new system, to aid discussions and eventually help
evaluate the implementation.

Dexter isn't ideal for observing specific optimisation behaviour. Writing an
exaustive test suite would be difficult, and the resultant suite would be
fragile. However, I think having some concrete executable examples is useful
at least as a reference.

Differential Revision: https://reviews.llvm.org/D89543
2020-10-26 10:57:36 +00:00

46 lines
1.3 KiB
C

// XFAIL:*
//// We don't yet support DW_OP_implicit_pointer in llvm.
// REQUIRES: lldb
// UNSUPPORTED: system-windows
// RUN: %dexter --fail-lt 1.0 -w --debugger lldb \
// RUN: --builder 'clang-c' --cflags "-O3 -glldb" -- %s
//// Check that 'param' in 'fun' can be read throughout, and that 'pa' and 'pb'
//// can be dereferenced in the debugger even if we can't provide the pointer
//// value itself.
int globa;
int globb;
//// A no-inline, read-only function with internal linkage is a good candidate
//// for arg promotion.
__attribute__((__noinline__))
static void use_promote(const int* pa) {
//// Promoted args would be a good candidate for an DW_OP_implicit_pointer.
globa = *pa; // DexLabel('s2')
}
__attribute__((__always_inline__))
static void use_inline(const int* pb) {
//// Inlined pointer to callee local would be a good candidate for an
//// DW_OP_implicit_pointer.
globb = *pb; // DexLabel('s3')
}
__attribute__((__noinline__))
int fun(int param) {
volatile int step = 0; // DexLabel('s1')
use_promote(&param);
use_inline(&param);
return step; // DexLabel('s4')
}
int main() {
return fun(5);
}
// DexExpectWatchValue('param', 5, from_line='s1', to_line='s4')
// DexExpectWatchValue('*pa', 5, on_line='s2')
// DexExpectWatchValue('*pb', 5, on_line='s3')