; RUN: opt < %s -analyze -enable-new-pm=0 -scalar-evolution | FileCheck %s ; RUN: opt < %s -disable-output "-passes=print" 2>&1 | FileCheck %s ; Check that we convert ; trunc(C * a) -> trunc(C) * trunc(a) ; if C is a constant. ; CHECK-LABEL: @trunc_of_mul define i8 @trunc_of_mul(i32 %a) { %b = mul i32 %a, 100 ; CHECK: %c ; CHECK-NEXT: --> (100 * (trunc i32 %a to i8)) %c = trunc i32 %b to i8 ret i8 %c } ; Check that we convert ; trunc(C + a) -> trunc(C) + trunc(a) ; if C is a constant. ; CHECK-LABEL: @trunc_of_add define i8 @trunc_of_add(i32 %a) { %b = add i32 %a, 100 ; CHECK: %c ; CHECK-NEXT: --> (100 + (trunc i32 %a to i8)) %c = trunc i32 %b to i8 ret i8 %c } ; Check that we truncate to zero values assumed to have at least as many ; trailing zeros as the target type. ; CHECK-LABEL: @trunc_to_assumed_zeros define i8 @trunc_to_assumed_zeros(i32* %p) { %a = load i32, i32* %p %and = and i32 %a, 255 %cmp = icmp eq i32 %and, 0 tail call void @llvm.assume(i1 %cmp) ; CHECK: %c ; CHECK-NEXT: --> 0 %c = trunc i32 %a to i8 ; CHECK: %d ; CHECK-NEXT: --> false %d = trunc i32 %a to i1 ; CHECK: %e ; CHECK-NEXT: --> (trunc i32 %a to i16) %e = trunc i32 %a to i16 ret i8 %c } declare void @llvm.assume(i1 noundef) nofree nosync nounwind willreturn