summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGenCoroutines/coro-await-domination.cpp
diff options
context:
space:
mode:
authorGor Nishanov <GorNishanov@gmail.com>2017-06-01 01:15:25 +0000
committerGor Nishanov <GorNishanov@gmail.com>2017-06-01 01:15:25 +0000
commit050e79e958caa6583af15dae5768d9894e62e1c5 (patch)
tree6c48ad815e12a2f45854de76ecadec83fbab4d6a /clang/test/CodeGenCoroutines/coro-await-domination.cpp
parentab194a26da64f372eeb0becbcf2264860ff9135e (diff)
downloadbcm5719-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.cpp38
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);
+}
+
OpenPOWER on IntegriCloud