forked from OSchip/llvm-project
[InstCombine] add more tests for udiv/urem narrowing; NFC
We don't currently limit these folds with hasOneUse() or shouldChangeType(). llvm-svn: 311390
This commit is contained in:
parent
bc11ca1a31
commit
5e3037cfc4
|
@ -1,6 +1,6 @@
|
|||
; RUN: opt < %s -instcombine -S | FileCheck %s
|
||||
|
||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
||||
target datalayout = "n8:32"
|
||||
|
||||
; PR4548
|
||||
define i8 @udiv_i8(i8 %a, i8 %b) {
|
||||
|
@ -15,64 +15,6 @@ define i8 @udiv_i8(i8 %a, i8 %b) {
|
|||
ret i8 %conv3
|
||||
}
|
||||
|
||||
define i8 @urem_i8(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @urem_i8(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, %b
|
||||
; CHECK-NEXT: ret i8 [[TMP1]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%udiv = urem i32 %za, %zb
|
||||
%conv3 = trunc i32 %udiv to i8
|
||||
ret i8 %conv3
|
||||
}
|
||||
|
||||
define i32 @udiv_i32(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @udiv_i32(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i8 %a, %b
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[DIV]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%udiv = udiv i32 %za, %zb
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define i32 @urem_i32(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @urem_i32(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, %b
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[TMP1]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%udiv = urem i32 %za, %zb
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define i32 @udiv_i32_c(i8 %a) {
|
||||
; CHECK-LABEL: @udiv_i32_c(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i8 %a, 10
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[DIV]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%udiv = udiv i32 %za, 10
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define i32 @urem_i32_c(i8 %a) {
|
||||
; CHECK-LABEL: @urem_i32_c(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, 10
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[TMP1]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%udiv = urem i32 %za, 10
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define <2 x i8> @udiv_i8_vec(<2 x i8> %a, <2 x i8> %b) {
|
||||
; CHECK-LABEL: @udiv_i8_vec(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv <2 x i8> %a, %b
|
||||
|
@ -85,6 +27,18 @@ define <2 x i8> @udiv_i8_vec(<2 x i8> %a, <2 x i8> %b) {
|
|||
ret <2 x i8> %conv3
|
||||
}
|
||||
|
||||
define i8 @urem_i8(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @urem_i8(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, %b
|
||||
; CHECK-NEXT: ret i8 [[TMP1]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%udiv = urem i32 %za, %zb
|
||||
%conv3 = trunc i32 %udiv to i8
|
||||
ret i8 %conv3
|
||||
}
|
||||
|
||||
define <2 x i8> @urem_i8_vec(<2 x i8> %a, <2 x i8> %b) {
|
||||
; CHECK-LABEL: @urem_i8_vec(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem <2 x i8> %a, %b
|
||||
|
@ -97,6 +51,18 @@ define <2 x i8> @urem_i8_vec(<2 x i8> %a, <2 x i8> %b) {
|
|||
ret <2 x i8> %conv3
|
||||
}
|
||||
|
||||
define i32 @udiv_i32(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @udiv_i32(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i8 %a, %b
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[DIV]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%udiv = udiv i32 %za, %zb
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define <2 x i32> @udiv_i32_vec(<2 x i8> %a, <2 x i8> %b) {
|
||||
; CHECK-LABEL: @udiv_i32_vec(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv <2 x i8> %a, %b
|
||||
|
@ -109,16 +75,99 @@ define <2 x i32> @udiv_i32_vec(<2 x i8> %a, <2 x i8> %b) {
|
|||
ret <2 x i32> %udiv
|
||||
}
|
||||
|
||||
define i32 @udiv_i32_multiuse(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @udiv_i32_multiuse(
|
||||
; CHECK-NEXT: [[ZA:%.*]] = zext i8 %a to i32
|
||||
; CHECK-NEXT: [[ZB:%.*]] = zext i8 %b to i32
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i8 %a, %b
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[DIV]] to i32
|
||||
; CHECK-NEXT: [[EXTRA_USES:%.*]] = add nuw nsw i32 [[ZA]], [[ZB]]
|
||||
; CHECK-NEXT: [[R:%.*]] = mul nuw nsw i32 [[EXTRA_USES]], [[UDIV]]
|
||||
; CHECK-NEXT: ret i32 [[R]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%udiv = udiv i32 %za, %zb
|
||||
%extra_uses = add i32 %za, %zb
|
||||
%r = mul i32 %udiv, %extra_uses
|
||||
ret i32 %r
|
||||
}
|
||||
|
||||
define i32 @udiv_illegal_type(i9 %a, i9 %b) {
|
||||
; CHECK-LABEL: @udiv_illegal_type(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i9 %a, %b
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i9 [[DIV]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i9 %a to i32
|
||||
%zb = zext i9 %b to i32
|
||||
%udiv = udiv i32 %za, %zb
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define i32 @urem_i32(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @urem_i32(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, %b
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext i8 [[TMP1]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UREM]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%urem = urem i32 %za, %zb
|
||||
ret i32 %urem
|
||||
}
|
||||
|
||||
define <2 x i32> @urem_i32_vec(<2 x i8> %a, <2 x i8> %b) {
|
||||
; CHECK-LABEL: @urem_i32_vec(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem <2 x i8> %a, %b
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext <2 x i8> [[TMP1]] to <2 x i32>
|
||||
; CHECK-NEXT: ret <2 x i32> [[UDIV]]
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext <2 x i8> [[TMP1]] to <2 x i32>
|
||||
; CHECK-NEXT: ret <2 x i32> [[UREM]]
|
||||
;
|
||||
%za = zext <2 x i8> %a to <2 x i32>
|
||||
%zb = zext <2 x i8> %b to <2 x i32>
|
||||
%udiv = urem <2 x i32> %za, %zb
|
||||
ret <2 x i32> %udiv
|
||||
%urem = urem <2 x i32> %za, %zb
|
||||
ret <2 x i32> %urem
|
||||
}
|
||||
|
||||
define i32 @urem_i32_multiuse(i8 %a, i8 %b) {
|
||||
; CHECK-LABEL: @urem_i32_multiuse(
|
||||
; CHECK-NEXT: [[ZA:%.*]] = zext i8 %a to i32
|
||||
; CHECK-NEXT: [[ZB:%.*]] = zext i8 %b to i32
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, %b
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext i8 [[TMP1]] to i32
|
||||
; CHECK-NEXT: [[EXTRA_USES:%.*]] = add nuw nsw i32 [[ZA]], [[ZB]]
|
||||
; CHECK-NEXT: [[R:%.*]] = mul nuw nsw i32 [[EXTRA_USES]], [[UREM]]
|
||||
; CHECK-NEXT: ret i32 [[R]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%zb = zext i8 %b to i32
|
||||
%urem = urem i32 %za, %zb
|
||||
%extra_uses = add i32 %za, %zb
|
||||
%r = mul i32 %urem, %extra_uses
|
||||
ret i32 %r
|
||||
}
|
||||
|
||||
define i32 @urem_illegal_type(i9 %a, i9 %b) {
|
||||
; CHECK-LABEL: @urem_illegal_type(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i9 %a, %b
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext i9 [[TMP1]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UREM]]
|
||||
;
|
||||
%za = zext i9 %a to i32
|
||||
%zb = zext i9 %b to i32
|
||||
%urem = urem i32 %za, %zb
|
||||
ret i32 %urem
|
||||
}
|
||||
|
||||
define i32 @udiv_i32_c(i8 %a) {
|
||||
; CHECK-LABEL: @udiv_i32_c(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i8 %a, 10
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[DIV]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%udiv = udiv i32 %za, 10
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define <2 x i32> @udiv_i32_c_vec(<2 x i8> %a) {
|
||||
|
@ -132,14 +181,75 @@ define <2 x i32> @udiv_i32_c_vec(<2 x i8> %a) {
|
|||
ret <2 x i32> %udiv
|
||||
}
|
||||
|
||||
define i32 @udiv_i32_c_multiuse(i8 %a) {
|
||||
; CHECK-LABEL: @udiv_i32_c_multiuse(
|
||||
; CHECK-NEXT: [[ZA:%.*]] = zext i8 %a to i32
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i8 %a, 10
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i8 [[DIV]] to i32
|
||||
; CHECK-NEXT: [[EXTRA_USE:%.*]] = add nuw nsw i32 [[ZA]], [[UDIV]]
|
||||
; CHECK-NEXT: ret i32 [[EXTRA_USE]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%udiv = udiv i32 %za, 10
|
||||
%extra_use = add i32 %za, %udiv
|
||||
ret i32 %extra_use
|
||||
}
|
||||
|
||||
define i32 @udiv_illegal_type_c(i9 %a) {
|
||||
; CHECK-LABEL: @udiv_illegal_type_c(
|
||||
; CHECK-NEXT: [[DIV:%.*]] = udiv i9 %a, 10
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = zext i9 [[DIV]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UDIV]]
|
||||
;
|
||||
%za = zext i9 %a to i32
|
||||
%udiv = udiv i32 %za, 10
|
||||
ret i32 %udiv
|
||||
}
|
||||
|
||||
define i32 @urem_i32_c(i8 %a) {
|
||||
; CHECK-LABEL: @urem_i32_c(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, 10
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext i8 [[TMP1]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UREM]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%urem = urem i32 %za, 10
|
||||
ret i32 %urem
|
||||
}
|
||||
|
||||
define <2 x i32> @urem_i32_c_vec(<2 x i8> %a) {
|
||||
; CHECK-LABEL: @urem_i32_c_vec(
|
||||
; CHECK-NEXT: [[ZA:%.*]] = zext <2 x i8> %a to <2 x i32>
|
||||
; CHECK-NEXT: [[UDIV:%.*]] = urem <2 x i32> [[ZA]], <i32 10, i32 17>
|
||||
; CHECK-NEXT: ret <2 x i32> [[UDIV]]
|
||||
; CHECK-NEXT: [[UREM:%.*]] = urem <2 x i32> [[ZA]], <i32 10, i32 17>
|
||||
; CHECK-NEXT: ret <2 x i32> [[UREM]]
|
||||
;
|
||||
%za = zext <2 x i8> %a to <2 x i32>
|
||||
%udiv = urem <2 x i32> %za, <i32 10, i32 17>
|
||||
ret <2 x i32> %udiv
|
||||
%urem = urem <2 x i32> %za, <i32 10, i32 17>
|
||||
ret <2 x i32> %urem
|
||||
}
|
||||
|
||||
define i32 @urem_i32_c_multiuse(i8 %a) {
|
||||
; CHECK-LABEL: @urem_i32_c_multiuse(
|
||||
; CHECK-NEXT: [[ZA:%.*]] = zext i8 %a to i32
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i8 %a, 10
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext i8 [[TMP1]] to i32
|
||||
; CHECK-NEXT: [[EXTRA_USE:%.*]] = add nuw nsw i32 [[ZA]], [[UREM]]
|
||||
; CHECK-NEXT: ret i32 [[EXTRA_USE]]
|
||||
;
|
||||
%za = zext i8 %a to i32
|
||||
%urem = urem i32 %za, 10
|
||||
%extra_use = add i32 %za, %urem
|
||||
ret i32 %extra_use
|
||||
}
|
||||
|
||||
define i32 @urem_illegal_type_c(i9 %a) {
|
||||
; CHECK-LABEL: @urem_illegal_type_c(
|
||||
; CHECK-NEXT: [[TMP1:%.*]] = urem i9 %a, 10
|
||||
; CHECK-NEXT: [[UREM:%.*]] = zext i9 [[TMP1]] to i32
|
||||
; CHECK-NEXT: ret i32 [[UREM]]
|
||||
;
|
||||
%za = zext i9 %a to i32
|
||||
%urem = urem i32 %za, 10
|
||||
ret i32 %urem
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue