; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3 ; RUN: opt < %s -passes=instcombine -S | FileCheck %s define i8 @avg_lsb(i8 %a, i8 %b) { ; CHECK-LABEL: define i8 @avg_lsb( ; CHECK-SAME: i8 [[A:%.*]], i8 [[B:%.*]]) { ; CHECK-NEXT: [[REM:%.*]] = and i8 [[A]], 1 ; CHECK-NEXT: [[DIV2:%.*]] = and i8 [[B]], [[REM]] ; CHECK-NEXT: ret i8 [[DIV2]] ; %rem = and i8 %a, 1 %rem1 = and i8 %b, 1 %add = add nuw nsw i8 %rem1, %rem %div2 = lshr i8 %add, 1 ret i8 %div2 } define i8 @avg_lsb_mismatch(i8 %a, i8 %b) { ; CHECK-LABEL: define i8 @avg_lsb_mismatch( ; CHECK-SAME: i8 [[A:%.*]], i8 [[B:%.*]]) { ; CHECK-NEXT: [[REM:%.*]] = and i8 [[A]], 1 ; CHECK-NEXT: [[REM1:%.*]] = and i8 [[B]], 3 ; CHECK-NEXT: [[ADD:%.*]] = add nuw nsw i8 [[REM1]], [[REM]] ; CHECK-NEXT: [[DIV2:%.*]] = lshr i8 [[ADD]], 1 ; CHECK-NEXT: ret i8 [[DIV2]] ; %rem = and i8 %a, 1 %rem1 = and i8 %b, 3 %add = add nuw nsw i8 %rem1, %rem %div2 = lshr i8 %add, 1 ret i8 %div2 } define <2 x i8> @avg_lsb_vector(<2 x i8> %a, <2 x i8> %b) { ; CHECK-LABEL: define <2 x i8> @avg_lsb_vector( ; CHECK-SAME: <2 x i8> [[A:%.*]], <2 x i8> [[B:%.*]]) { ; CHECK-NEXT: [[REM:%.*]] = and <2 x i8> [[A]], splat (i8 1) ; CHECK-NEXT: [[DIV2:%.*]] = and <2 x i8> [[B]], [[REM]] ; CHECK-NEXT: ret <2 x i8> [[DIV2]] ; %rem = and <2 x i8> %a, %rem1 = and <2 x i8> %b, %add = add nuw nsw <2 x i8> %rem1, %rem %div2 = lshr <2 x i8> %add, ret <2 x i8> %div2 }