summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGenCoroutines
diff options
context:
space:
mode:
authorGor Nishanov <GorNishanov@gmail.com>2017-11-11 17:00:43 +0000
committerGor Nishanov <GorNishanov@gmail.com>2017-11-11 17:00:43 +0000
commit04491bd8f324bce9d2adbc9cc6e45f0d1659ac41 (patch)
tree3fe744167112646b34709aad1180d71b90eab244 /clang/test/CodeGenCoroutines
parentd0ef19ef9b2c4c61ecd10b133632c795c3bc2d31 (diff)
downloadbcm5719-llvm-04491bd8f324bce9d2adbc9cc6e45f0d1659ac41.tar.gz
bcm5719-llvm-04491bd8f324bce9d2adbc9cc6e45f0d1659ac41.zip
[coroutines] Promote cleanup.dest.slot allocas to registers to avoid storing it in the coroutine frame
Summary: We don't want to store cleanup dest slot saved into the coroutine frame (as some of the cleanup code may access them after coroutine frame destroyed). This is an alternative to https://reviews.llvm.org/D37093 It is possible to do this for all functions, but, cursory check showed that in -O0, we get slightly longer function (by 1-3 instructions), thus, we are only limiting cleanup.dest.slot elimination to coroutines. Reviewers: rjmccall, hfinkel, eric_niebler Reviewed By: eric_niebler Subscribers: EricWF, cfe-commits Differential Revision: https://reviews.llvm.org/D39768 llvm-svn: 317981
Diffstat (limited to 'clang/test/CodeGenCoroutines')
-rw-r--r--clang/test/CodeGenCoroutines/coro-dest-slot.cpp26
1 files changed, 26 insertions, 0 deletions
diff --git a/clang/test/CodeGenCoroutines/coro-dest-slot.cpp b/clang/test/CodeGenCoroutines/coro-dest-slot.cpp
new file mode 100644
index 00000000000..4c7395ba608
--- /dev/null
+++ b/clang/test/CodeGenCoroutines/coro-dest-slot.cpp
@@ -0,0 +1,26 @@
+// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fcoroutines-ts -std=c++14 -emit-llvm %s -o - -disable-llvm-passes | FileCheck %s
+
+#include "Inputs/coroutine.h"
+
+using namespace std::experimental;
+
+struct coro {
+ struct promise_type {
+ coro get_return_object();
+ suspend_always initial_suspend();
+ suspend_never final_suspend();
+ void return_void();
+ static void unhandled_exception();
+ };
+};
+
+extern "C" coro f(int) { co_return; }
+// Verify that cleanup.dest.slot is eliminated in a coroutine.
+// CHECK-LABEL: f(
+// CHECK: call void @_ZNSt12experimental13coroutines_v113suspend_never12await_resumeEv(
+// CHECK: %[[CLEANUP_DEST:.+]] = phi i32 [ 0, %{{.+}} ], [ 2, %{{.+}} ], [ 2, %{{.+}} ]
+// CHECK: call i8* @llvm.coro.free(
+// CHECK: switch i32 %cleanup.dest.slot.0, label %{{.+}} [
+// CHECK-NEXT: i32 0
+// CHECK-NEXT: i32 2
+// CHECK-NEXT: ]
OpenPOWER on IntegriCloud