diff options
author | Gor Nishanov <GorNishanov@gmail.com> | 2017-06-01 01:15:25 +0000 |
---|---|---|
committer | Gor Nishanov <GorNishanov@gmail.com> | 2017-06-01 01:15:25 +0000 |
commit | 050e79e958caa6583af15dae5768d9894e62e1c5 (patch) | |
tree | 6c48ad815e12a2f45854de76ecadec83fbab4d6a /clang/test/CodeGenCoroutines/coro-await-domination.cpp | |
parent | ab194a26da64f372eeb0becbcf2264860ff9135e (diff) | |
download | bcm5719-llvm-050e79e958caa6583af15dae5768d9894e62e1c5.tar.gz bcm5719-llvm-050e79e958caa6583af15dae5768d9894e62e1c5.zip |
CGCleanup: (NFC) add another test for r304335 - Don't try to spill static allocas
Summary:
Coroutine related test that used to trigger broken IR prior to r304335.
```
%x = alloca i32, align 4
store i32* %x, i32** %tmp.exprcleanup, align 4 ; <===== HERE
%ref.tmp3 = alloca %struct.A, align 1
%agg.tmp5 = alloca %"struct.std::experimental::coroutines_v1::coroutine_handle.0", align 4
%tmp.exprcleanup = alloca i32*, align 4
%allocapt = bitcast i32 undef to i32
store i32 %0, i32* %.addr, align 4
```
Fixed with r304335
Subscribers: cfe-commits
Differential Revision: https://reviews.llvm.org/D33750
llvm-svn: 304380
Diffstat (limited to 'clang/test/CodeGenCoroutines/coro-await-domination.cpp')
-rw-r--r-- | clang/test/CodeGenCoroutines/coro-await-domination.cpp | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/clang/test/CodeGenCoroutines/coro-await-domination.cpp b/clang/test/CodeGenCoroutines/coro-await-domination.cpp new file mode 100644 index 00000000000..5df22374a6e --- /dev/null +++ b/clang/test/CodeGenCoroutines/coro-await-domination.cpp @@ -0,0 +1,38 @@ +// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fcoroutines-ts -std=c++14 -emit-llvm %s -o - | FileCheck %s +#include "Inputs/coroutine.h" + +using namespace std::experimental; + +struct coro { + struct promise_type { + coro get_return_object(); + suspend_never initial_suspend(); + suspend_never final_suspend(); + void return_void(); + static void unhandled_exception(); + }; +}; + +struct A { + ~A(); + bool await_ready(); + int await_resume() { return 8; } + template <typename F> void await_suspend(F); +}; + +extern "C" void consume(int); + +// Verifies that domination is properly built during cleanup. +// Without CGCleanup.cpp fix verifier was reporting: +// Instruction does not dominate all uses! +// %tmp.exprcleanup = alloca i32*, align 8 +// store i32* %x, i32** %tmp.exprcleanup, align 8 + + +// CHECK-LABEL: f( +extern "C" coro f(int) { + int x = 42; + x = co_await A{}; + consume(x); +} + |