Florian Hahn 99b3b8e5b9
[DemandedBits] Print function name when printing analysis.
Include the function name + analysis when printing the analysis for
testing.
2023-07-06 14:17:20 +01:00

28 lines
1.3 KiB
LLVM

; RUN: opt -S -disable-output -passes="print<demanded-bits>" < %s 2>&1 | FileCheck %s
; CHECK-LABEL: Printing analysis 'Demanded Bits Analysis' for function 'test_mul':
; CHECK-DAG: DemandedBits: 0xff for %1 = add nsw i32 %a, 5
; CHECK-DAG: DemandedBits: 0xff for %3 = trunc i32 %2 to i8
; CHECK-DAG: DemandedBits: 0xff for %2 = mul nsw i32 %1, %b
; CHECK-DAG: DemandedBits: 0x1 for %4 = trunc i32 %2 to i1
; CHECK-DAG: DemandedBits: 0xff for %5 = zext i1 %4 to i8
; CHECK-DAG: DemandedBits: 0xff for %6 = add nsw i8 %3, %5
; CHECK-DAG: DemandedBits: 0xff for %a in %1 = add nsw i32 %a, 5
; CHECK-DAG: DemandedBits: 0xff for 5 in %1 = add nsw i32 %a, 5
; CHECK-DAG: DemandedBits: 0xff for %1 in %2 = mul nsw i32 %1, %b
; CHECK-DAG: DemandedBits: 0xff for %b in %2 = mul nsw i32 %1, %b
; CHECK-DAG: DemandedBits: 0xff for %2 in %3 = trunc i32 %2 to i8
; CHECK-DAG: DemandedBits: 0x1 for %2 in %4 = trunc i32 %2 to i1
; CHECK-DAG: DemandedBits: 0x1 for %4 in %5 = zext i1 %4 to i8
; CHECK-DAG: DemandedBits: 0xff for %3 in %6 = add nsw i8 %3, %5
; CHECK-DAG: DemandedBits: 0xff for %5 in %6 = add nsw i8 %3, %5
define i8 @test_mul(i32 %a, i32 %b) {
%1 = add nsw i32 %a, 5
%2 = mul nsw i32 %1, %b
%3 = trunc i32 %2 to i8
%4 = trunc i32 %2 to i1
%5 = zext i1 %4 to i8
%6 = add nsw i8 %3, %5
ret i8 %6
}