diff options
author | Adrian Prantl <aprantl@apple.com> | 2017-04-17 17:57:01 +0000 |
---|---|---|
committer | Adrian Prantl <aprantl@apple.com> | 2017-04-17 17:57:01 +0000 |
commit | c26059f831d315dab3b9d87ba86cb3532302aa0b (patch) | |
tree | b035cace5ac5af1eb5f6aad5f295694420fc7c1a /debuginfo-tests | |
parent | 67caa192df4b8ac43421de4105d53251011251d3 (diff) |
Revert "Revert "Add a test for __block variables + asan.""
This reapplies commit r300228.
llvm-svn: 300467
Diffstat (limited to 'debuginfo-tests')
-rw-r--r-- | debuginfo-tests/asan.c | 32 | ||||
-rw-r--r-- | debuginfo-tests/llgdb.py | 4 |
2 files changed, 27 insertions, 9 deletions
diff --git a/debuginfo-tests/asan.c b/debuginfo-tests/asan.c index 71838cde295e..1407e01ed6b4 100644 --- a/debuginfo-tests/asan.c +++ b/debuginfo-tests/asan.c @@ -3,24 +3,38 @@ // REQUIRES: not_asan // Zorg configures the ASAN stage2 bots to not build the asan // compiler-rt. Only run this test on non-asanified configurations. -// -// DEBUGGER: break 24 -// DEBUGGER: r -// DEBUGGER: p s -// -// CHECK: a = ([0] = 0, [1] = 1, [2] = 2, [3] = 3, [4] = 4, [5] = 5, [6] = 6, [7] = 7) - +void b(); struct S { int a[8]; }; int f(struct S s, unsigned i) { + // DEBUGGER: break 16 + // DEBUGGER: r + // DEBUGGER: p s + // CHECK: a = ([0] = 0, [1] = 1, [2] = 2, [3] = 3, [4] = 4, [5] = 5, [6] = 6, [7] = 7) return s.a[i]; } int main(int argc, const char **argv) { struct S s = {{0, 1, 2, 3, 4, 5, 6, 7}}; - if (f(s, 4) == 4) - return f(s, 0); + if (f(s, 4) == 4) { + // DEBUGGER: break 26 + // DEBUGGER: c + // DEBUGGER: p s + // CHECK: a = ([0] = 0, [1] = 1, [2] = 2, [3] = 3, [4] = 4, [5] = 5, [6] = 6, [7] = 7) + b(); + } return 0; } + +void c() {} + +void b() { + // DEBUGGER: break 39 + // DEBUGGER: c + // DEBUGGER: p x + // CHECK: 42 + __block int x = 42; + c(); +} diff --git a/debuginfo-tests/llgdb.py b/debuginfo-tests/llgdb.py index ce8346259e24..7d4fdd64fd1b 100644 --- a/debuginfo-tests/llgdb.py +++ b/debuginfo-tests/llgdb.py @@ -139,6 +139,10 @@ NOTE: There are several reasons why this may happen: frame = thread.GetFrameAtIndex(0) print frame.EvaluateExpression(' '.join(cmd[1:])) + elif re.match('^n|(next)$', cmd[0]): + thread = process.GetThreadAtIndex(0) + thread.StepOver() + elif re.match('^q|(quit)$', cmd[0]): sys.exit(0) |