53 lines
2.2 KiB
LLVM
53 lines
2.2 KiB
LLVM
; Check that MC/DC intrinsics are properly lowered
|
|
; RUN: opt < %s -passes=instrprof -S | FileCheck %s
|
|
; RUN: opt < %s -passes=instrprof -runtime-counter-relocation -S 2>&1 | FileCheck %s --check-prefix RELOC
|
|
|
|
; RELOC: Runtime counter relocation is presently not supported for MC/DC bitmaps
|
|
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
@__profn_test = private constant [4 x i8] c"test"
|
|
|
|
; CHECK: @__profbm_test = private global [1 x i8] zeroinitializer, section "__llvm_prf_bits", comdat, align 1
|
|
|
|
define dso_local void @test(i32 noundef %A) {
|
|
entry:
|
|
%A.addr = alloca i32, align 4
|
|
%mcdc.addr = alloca i32, align 4
|
|
call void @llvm.instrprof.cover(ptr @__profn_test, i64 99278, i32 5, i32 0)
|
|
; CHECK: store i8 0, ptr @__profc_test, align 1
|
|
|
|
call void @llvm.instrprof.mcdc.parameters(ptr @__profn_test, i64 99278, i32 1)
|
|
store i32 0, ptr %mcdc.addr, align 4
|
|
%0 = load i32, ptr %A.addr, align 4
|
|
%tobool = icmp ne i32 %0, 0
|
|
|
|
call void @llvm.instrprof.mcdc.condbitmap.update(ptr @__profn_test, i64 99278, i32 0, ptr %mcdc.addr, i1 %tobool)
|
|
; CHECK: %mcdc.temp = load i32, ptr %mcdc.addr, align 4
|
|
; CHECK-NEXT: %1 = zext i1 %tobool to i32
|
|
; CHECK-NEXT: %2 = shl i32 %1, 0
|
|
; CHECK-NEXT: %3 = or i32 %mcdc.temp, %2
|
|
; CHECK-NEXT: store i32 %3, ptr %mcdc.addr, align 4
|
|
|
|
call void @llvm.instrprof.mcdc.tvbitmap.update(ptr @__profn_test, i64 99278, i32 1, i32 0, ptr %mcdc.addr)
|
|
; CHECK: %mcdc.temp1 = load i32, ptr %mcdc.addr, align 4
|
|
; CHECK-NEXT: %4 = lshr i32 %mcdc.temp1, 3
|
|
; CHECK-NEXT: %5 = zext i32 %4 to i64
|
|
; CHECK-NEXT: %6 = add i64 ptrtoint (ptr @__profbm_test to i64), %5
|
|
; CHECK-NEXT: %7 = inttoptr i64 %6 to ptr
|
|
; CHECK-NEXT: %8 = and i32 %mcdc.temp1, 7
|
|
; CHECK-NEXT: %9 = trunc i32 %8 to i8
|
|
; CHECK-NEXT: %10 = shl i8 1, %9
|
|
; CHECK-NEXT: %mcdc.bits = load i8, ptr %7, align 1
|
|
; CHECK-NEXT: %11 = or i8 %mcdc.bits, %10
|
|
; CHECK-NEXT: store i8 %11, ptr %7, align 1
|
|
ret void
|
|
}
|
|
|
|
declare void @llvm.instrprof.cover(ptr, i64, i32, i32)
|
|
|
|
declare void @llvm.instrprof.mcdc.parameters(ptr, i64, i32)
|
|
|
|
declare void @llvm.instrprof.mcdc.condbitmap.update(ptr, i64, i32, ptr, i1)
|
|
|
|
declare void @llvm.instrprof.mcdc.tvbitmap.update(ptr, i64, i32, i32, ptr)
|