Stephen Tozer 45a40c1639 Re-reapply "[Dexter] Remove builder from Dexter"
This patch makes a further attempt to fix the tests broken by the
previous revision by ensuring that the command line for the modified
Dexter tests use -std=gnu++11, in keeping with the old build script.

This reverts commit 5647f2908de90fe07b0805e988cd2e91a1751928.
2023-09-06 15:06:07 +01:00

53 lines
1.2 KiB
C

// XFAIL:*
//// See PR47946.
// REQUIRES: lldb
// UNSUPPORTED: system-windows
// RUN: %clang -std=gnu11 -O2 -glldb %s -o %t
// RUN: %dexter --fail-lt 1.0 -w --debugger lldb --binary %t -- %s
//
//// Check that once-escaped variable 'param' can still be read after we
//// perform inlining + mem2reg, and that we see the DSE'd value 255.
int g;
__attribute__((__always_inline__))
static void use(int* p) {
g = *p;
*p = 255;
volatile int step = 0; // DexLabel('use1')
}
__attribute__((__noinline__))
void fun(int param) {
//// Make sure first step is in 'fun'.
volatile int step = 0; // DexLabel('fun1')
use(&param);
return; // DexLabel('fun2')
}
int main() {
fun(5);
}
/*
# Expect param == 5 before stepping through inlined 'use'.
DexExpectWatchValue('param', '5', on_line=ref('fun1'))
# Expect param == 255 after assignment in inlined frame 'use'.
DexExpectProgramState({
'frames': [
{ 'function': 'use',
'location': { 'lineno': ref('use1') },
},
{ 'function': 'fun',
'location': { 'lineno': 20 },
'watches': { 'param': '255' }
},
]
})
# Expect param == 255 after inlined call to 'use'.
DexExpectWatchValue('param', '255', on_line=ref('fun2'))
*/