
Attempted fix for errors observed on: https://luci-milo.appspot.com/ui/p/fuchsia/builders/toolchain.ci/clang-windows-x64/b8724466517233166081/overview Following the previous fixes, one test that needed an explicit triple was missed; this commit adds that triple.
35 lines
1.4 KiB
C++
35 lines
1.4 KiB
C++
// 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;
|
|
}
|
|
}
|