mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-05-13 17:37:00 +00:00

[VarBypassDetector.cpp](https://github.com/llvm/llvm-project/blob/main/clang/lib/CodeGen/VarBypassDetector.cpp) lacks test coverage for handling init statements and condition variables in switch clauses, as is shown in: https://lab.llvm.org/coverage/coverage-reports/coverage/Users/buildslave/jenkins/workspace/coverage/llvm-project/clang/lib/CodeGen/VarBypassDetector.cpp.html#L70 This patch adds test coverage for uncovered lines. Reviewed By: vitalybuka Differential Revision: https://reviews.llvm.org/D152412
44 lines
1.3 KiB
C++
44 lines
1.3 KiB
C++
// RUN: %clang_cc1 -S -emit-llvm -o - -O2 -disable-llvm-passes %s | FileCheck %s --implicit-check-not="call void @llvm.lifetime" --check-prefixes=CHECK,O2
|
|
// RUN: %clang_cc1 -S -emit-llvm -o - -O2 -disable-lifetime-markers %s | FileCheck %s --implicit-check-not="call void @llvm.lifetime" --check-prefixes=CHECK
|
|
// RUN: %clang_cc1 -S -emit-llvm -o - -O0 %s | FileCheck %s --implicit-check-not="call void @llvm.lifetime" --check-prefixes=CHECK
|
|
|
|
extern int bar(char *A, int n);
|
|
|
|
// CHECK-LABEL: @no_switch_bypass
|
|
extern "C" void no_switch_bypass(int n) {
|
|
// O2: call void @llvm.lifetime.start.p0(i64 4,
|
|
switch (n += 1; int b=n) {
|
|
case 1: {
|
|
// O2: call void @llvm.lifetime.start.p0(i64 1,
|
|
// O2: call void @llvm.lifetime.end.p0(i64 1,
|
|
char x;
|
|
bar(&x, 1);
|
|
break;
|
|
}
|
|
case 2:
|
|
n = n;
|
|
// O2: call void @llvm.lifetime.start.p0(i64 5,
|
|
// O2: call void @llvm.lifetime.end.p0(i64 5,
|
|
char y[5];
|
|
bar(y, 5);
|
|
break;
|
|
}
|
|
// O2: call void @llvm.lifetime.end.p0(i64 4,
|
|
}
|
|
|
|
// CHECK-LABEL: @switch_bypass
|
|
extern "C" void switch_bypass(int n) {
|
|
// O2: call void @llvm.lifetime.start.p0(i64 4,
|
|
// O2: call void @llvm.lifetime.end.p0(i64 4,
|
|
switch (n += 1; int b=n) {
|
|
case 1:
|
|
n = n;
|
|
char x;
|
|
bar(&x, 1);
|
|
break;
|
|
case 2:
|
|
bar(&x, 1);
|
|
break;
|
|
}
|
|
}
|