blob: c3a29f57bdae54abcf5ca331face21a1b8036d53 [file] [log] [blame]
// RUN: %clang_cc1 %s -triple %itanium_abi_triple -emit-llvm -fextend-variable-liveness -fcxx-exceptions -fexceptions -o - | FileCheck %s
// This test checks that the fake uses can be generated in exception handling
// blocks and that we can emit fake uses for the __int128 data type.
extern int bar();
/// Try block: fake use ends at try-block scope.
// [[BAR_VAL::%[a-zA-Z0-9\.]+]] = invoke{{.*}} i32 @_Z3barv()
// store i32 %[[BAR_VAL]], ptr [[K_ALLOC_VAL:%[a-zA-Z0-9\.]+]], align 4
// [[K_FAKE_USE:%[a-zA-Z0-9\.]+]] = load i32, ptr [[K_ALLOC_VAL]], align 4
// call void (...) @llvm.fake.use(i32 [[K_FAKE_USE]]) #2
// br label
/// Catch block: fetching the caught value...
// CHECK: [[CATCH_PTR:%[a-zA-Z0-9\.]+]] = call ptr @__cxa_begin_catch(
// CHECK: [[L_VAL:%[a-zA-Z0-9\.]+]] = load i32, ptr [[CATCH_PTR]], align 4
/// Storing to allocas...
// CHECK-DAG: store i32 8, ptr [[M_ALLOC_VAL:%[a-zA-Z0-9\.]+]]
// CHECK-DAG: store i32 [[L_VAL]], ptr [[L_ALLOC_VAL:%[a-zA-Z0-9\.]+]], align 4
/// Load into fake uses - expect M to precede L.
// CHECK: [[M_FAKE_VAL:%[a-zA-Z0-9\.]+]] = load i32, ptr [[M_ALLOC_VAL]]
// CHECK: call void (...) @llvm.fake.use(i32 [[M_FAKE_VAL]])
// CHECK: [[L_FAKE_VAL:%[a-zA-Z0-9\.]+]] = load i32, ptr [[L_ALLOC_VAL]]
// CHECK: call void (...) @llvm.fake.use(i32 [[L_FAKE_VAL]])
void foo() {
try {
int k = bar();
} catch (int l) {
/// The catch block contains a fake use for the local within its scope.
int m = 8;
}
}