| ; 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) |