2016-08-16 01:19:07 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
2012-04-19 00:44:44 +08:00
|
|
|
; This test makes sure that shift instructions are properly eliminated
|
2007-03-24 05:57:47 +08:00
|
|
|
; even with arbitrary precision integers.
|
2012-04-19 01:01:26 +08:00
|
|
|
; RUN: opt < %s -instcombine -S | FileCheck %s
|
2007-03-24 05:57:47 +08:00
|
|
|
|
|
|
|
define i47 @test1(i47 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test1(
|
|
|
|
; CHECK-NEXT: ret i47 %A
|
|
|
|
;
|
|
|
|
%B = shl i47 %A, 0
|
|
|
|
ret i47 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i41 @test2(i7 %X) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test2(
|
|
|
|
; CHECK-NEXT: ret i41 0
|
|
|
|
;
|
|
|
|
%A = zext i7 %X to i41
|
|
|
|
%B = shl i41 0, %A
|
|
|
|
ret i41 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i41 @test3(i41 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test3(
|
|
|
|
; CHECK-NEXT: ret i41 %A
|
|
|
|
;
|
|
|
|
%B = ashr i41 %A, 0
|
|
|
|
ret i41 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i39 @test4(i7 %X) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test4(
|
|
|
|
; CHECK-NEXT: ret i39 0
|
|
|
|
;
|
|
|
|
%A = zext i7 %X to i39
|
|
|
|
%B = ashr i39 0, %A
|
|
|
|
ret i39 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i55 @test5(i55 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test5(
|
|
|
|
; CHECK-NEXT: ret i55 undef
|
|
|
|
;
|
|
|
|
%B = lshr i55 %A, 55
|
|
|
|
ret i55 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i32 @test5a(i32 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test5a(
|
|
|
|
; CHECK-NEXT: ret i32 undef
|
|
|
|
;
|
|
|
|
%B = shl i32 %A, 32
|
|
|
|
ret i32 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i55 @test6(i55 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test6(
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = mul i55 %A, 6
|
|
|
|
; CHECK-NEXT: ret i55 [[C]]
|
|
|
|
;
|
|
|
|
%B = shl i55 %A, 1
|
|
|
|
%C = mul i55 %B, 3
|
|
|
|
ret i55 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
Reapply r155136 after fixing PR12599.
Original commit message:
Defer some shl transforms to DAGCombine.
The shl instruction is used to represent multiplication by a constant
power of two as well as bitwise left shifts. Some InstCombine
transformations would turn an shl instruction into a bit mask operation,
making it difficult for later analysis passes to recognize the
constsnt multiplication.
Disable those shl transformations, deferring them to DAGCombine time.
An 'shl X, C' instruction is now treated mostly the same was as 'mul X, C'.
These transformations are deferred:
(X >>? C) << C --> X & (-1 << C) (When X >> C has multiple uses)
(X >>? C1) << C2 --> X << (C2-C1) & (-1 << C2) (When C2 > C1)
(X >>? C1) << C2 --> X >>? (C1-C2) & (-1 << C2) (When C1 > C2)
The corresponding exact transformations are preserved, just like
div-exact + mul:
(X >>?,exact C) << C --> X
(X >>?,exact C1) << C2 --> X << (C2-C1)
(X >>?,exact C1) << C2 --> X >>?,exact (C1-C2)
The disabled transformations could also prevent the instruction selector
from recognizing rotate patterns in hash functions and cryptographic
primitives. I have a test case for that, but it is too fragile.
llvm-svn: 155362
2012-04-24 01:39:52 +08:00
|
|
|
define i55 @test6a(i55 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test6a(
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = mul i55 %A, 6
|
|
|
|
; CHECK-NEXT: ret i55 [[C]]
|
|
|
|
;
|
|
|
|
%B = mul i55 %A, 3
|
|
|
|
%C = shl i55 %B, 1
|
|
|
|
ret i55 %C
|
Reapply r155136 after fixing PR12599.
Original commit message:
Defer some shl transforms to DAGCombine.
The shl instruction is used to represent multiplication by a constant
power of two as well as bitwise left shifts. Some InstCombine
transformations would turn an shl instruction into a bit mask operation,
making it difficult for later analysis passes to recognize the
constsnt multiplication.
Disable those shl transformations, deferring them to DAGCombine time.
An 'shl X, C' instruction is now treated mostly the same was as 'mul X, C'.
These transformations are deferred:
(X >>? C) << C --> X & (-1 << C) (When X >> C has multiple uses)
(X >>? C1) << C2 --> X << (C2-C1) & (-1 << C2) (When C2 > C1)
(X >>? C1) << C2 --> X >>? (C1-C2) & (-1 << C2) (When C1 > C2)
The corresponding exact transformations are preserved, just like
div-exact + mul:
(X >>?,exact C) << C --> X
(X >>?,exact C1) << C2 --> X << (C2-C1)
(X >>?,exact C1) << C2 --> X >>?,exact (C1-C2)
The disabled transformations could also prevent the instruction selector
from recognizing rotate patterns in hash functions and cryptographic
primitives. I have a test case for that, but it is too fragile.
llvm-svn: 155362
2012-04-24 01:39:52 +08:00
|
|
|
}
|
|
|
|
|
2007-03-24 05:57:47 +08:00
|
|
|
define i29 @test7(i8 %X) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test7(
|
|
|
|
; CHECK-NEXT: ret i29 -1
|
|
|
|
;
|
|
|
|
%A = zext i8 %X to i29
|
|
|
|
%B = ashr i29 -1, %A
|
|
|
|
ret i29 %B
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i7 @test8(i7 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test8(
|
|
|
|
; CHECK-NEXT: ret i7 0
|
|
|
|
;
|
|
|
|
%B = shl i7 %A, 4
|
|
|
|
%C = shl i7 %B, 3
|
|
|
|
ret i7 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i17 @test9(i17 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test9(
|
|
|
|
; CHECK-NEXT: [[B:%.*]] = and i17 %A, 1
|
|
|
|
; CHECK-NEXT: ret i17 [[B]]
|
|
|
|
;
|
|
|
|
%B = shl i17 %A, 16
|
|
|
|
%C = lshr i17 %B, 16
|
|
|
|
ret i17 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i19 @test10(i19 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test10(
|
|
|
|
; CHECK-NEXT: [[B:%.*]] = and i19 %A, -262144
|
|
|
|
; CHECK-NEXT: ret i19 [[B]]
|
|
|
|
;
|
|
|
|
%B = lshr i19 %A, 18
|
|
|
|
%C = shl i19 %B, 18
|
|
|
|
ret i19 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
Reapply r155136 after fixing PR12599.
Original commit message:
Defer some shl transforms to DAGCombine.
The shl instruction is used to represent multiplication by a constant
power of two as well as bitwise left shifts. Some InstCombine
transformations would turn an shl instruction into a bit mask operation,
making it difficult for later analysis passes to recognize the
constsnt multiplication.
Disable those shl transformations, deferring them to DAGCombine time.
An 'shl X, C' instruction is now treated mostly the same was as 'mul X, C'.
These transformations are deferred:
(X >>? C) << C --> X & (-1 << C) (When X >> C has multiple uses)
(X >>? C1) << C2 --> X << (C2-C1) & (-1 << C2) (When C2 > C1)
(X >>? C1) << C2 --> X >>? (C1-C2) & (-1 << C2) (When C1 > C2)
The corresponding exact transformations are preserved, just like
div-exact + mul:
(X >>?,exact C) << C --> X
(X >>?,exact C1) << C2 --> X << (C2-C1)
(X >>?,exact C1) << C2 --> X >>?,exact (C1-C2)
The disabled transformations could also prevent the instruction selector
from recognizing rotate patterns in hash functions and cryptographic
primitives. I have a test case for that, but it is too fragile.
llvm-svn: 155362
2012-04-24 01:39:52 +08:00
|
|
|
; Don't hide the shl from scalar evolution. DAGCombine will get it.
|
2007-03-24 05:57:47 +08:00
|
|
|
define i23 @test11(i23 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test11(
|
|
|
|
; CHECK-NEXT: [[A:%.*]] = mul i23 %A, 3
|
|
|
|
; CHECK-NEXT: [[B:%.*]] = lshr i23 [[A]], 11
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = shl i23 [[B]], 12
|
|
|
|
; CHECK-NEXT: ret i23 [[C]]
|
|
|
|
;
|
|
|
|
%a = mul i23 %A, 3
|
|
|
|
%B = lshr i23 %a, 11
|
|
|
|
%C = shl i23 %B, 12
|
|
|
|
ret i23 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i47 @test12(i47 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test12(
|
|
|
|
; CHECK-NEXT: [[B1:%.*]] = and i47 %A, -256
|
|
|
|
; CHECK-NEXT: ret i47 [[B1]]
|
|
|
|
;
|
|
|
|
%B = ashr i47 %A, 8
|
|
|
|
%C = shl i47 %B, 8
|
|
|
|
ret i47 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
Reapply r155136 after fixing PR12599.
Original commit message:
Defer some shl transforms to DAGCombine.
The shl instruction is used to represent multiplication by a constant
power of two as well as bitwise left shifts. Some InstCombine
transformations would turn an shl instruction into a bit mask operation,
making it difficult for later analysis passes to recognize the
constsnt multiplication.
Disable those shl transformations, deferring them to DAGCombine time.
An 'shl X, C' instruction is now treated mostly the same was as 'mul X, C'.
These transformations are deferred:
(X >>? C) << C --> X & (-1 << C) (When X >> C has multiple uses)
(X >>? C1) << C2 --> X << (C2-C1) & (-1 << C2) (When C2 > C1)
(X >>? C1) << C2 --> X >>? (C1-C2) & (-1 << C2) (When C1 > C2)
The corresponding exact transformations are preserved, just like
div-exact + mul:
(X >>?,exact C) << C --> X
(X >>?,exact C1) << C2 --> X << (C2-C1)
(X >>?,exact C1) << C2 --> X >>?,exact (C1-C2)
The disabled transformations could also prevent the instruction selector
from recognizing rotate patterns in hash functions and cryptographic
primitives. I have a test case for that, but it is too fragile.
llvm-svn: 155362
2012-04-24 01:39:52 +08:00
|
|
|
; Don't hide the shl from scalar evolution. DAGCombine will get it.
|
2007-03-24 05:57:47 +08:00
|
|
|
define i18 @test13(i18 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test13(
|
|
|
|
; CHECK-NEXT: [[A:%.*]] = mul i18 %A, 3
|
|
|
|
; CHECK-NEXT: [[B1:%.*]] = lshr i18 [[A]], 8
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = shl i18 [[B1]], 9
|
|
|
|
; CHECK-NEXT: ret i18 [[C]]
|
|
|
|
;
|
|
|
|
%a = mul i18 %A, 3
|
|
|
|
%B = ashr i18 %a, 8
|
|
|
|
%C = shl i18 %B, 9
|
|
|
|
ret i18 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i35 @test14(i35 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test14(
|
|
|
|
; CHECK-NEXT: [[B:%.*]] = and i35 %A, -19760
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = or i35 [[B]], 19744
|
|
|
|
; CHECK-NEXT: ret i35 [[C]]
|
|
|
|
;
|
|
|
|
%B = lshr i35 %A, 4
|
|
|
|
%C = or i35 %B, 1234
|
|
|
|
%D = shl i35 %C, 4
|
|
|
|
ret i35 %D
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i79 @test14a(i79 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test14a(
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = and i79 %A, 77
|
|
|
|
; CHECK-NEXT: ret i79 [[C]]
|
|
|
|
;
|
|
|
|
%B = shl i79 %A, 4
|
|
|
|
%C = and i79 %B, 1234
|
|
|
|
%D = lshr i79 %C, 4
|
|
|
|
ret i79 %D
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i45 @test15(i1 %C) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test15(
|
|
|
|
; CHECK-NEXT: [[A:%.*]] = select i1 %C, i45 12, i45 4
|
|
|
|
; CHECK-NEXT: ret i45 [[A]]
|
|
|
|
;
|
|
|
|
%A = select i1 %C, i45 3, i45 1
|
|
|
|
%V = shl i45 %A, 2
|
|
|
|
ret i45 %V
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i53 @test15a(i1 %X) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test15a(
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = select i1 %X, i53 512, i53 128
|
|
|
|
; CHECK-NEXT: ret i53 [[V]]
|
|
|
|
;
|
|
|
|
%A = select i1 %X, i8 3, i8 1
|
|
|
|
%B = zext i8 %A to i53
|
|
|
|
%V = shl i53 64, %B
|
|
|
|
ret i53 %V
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i1 @test16(i84 %X) {
|
2016-08-15 06:56:46 +08:00
|
|
|
; CHECK-LABEL: @test16(
|
|
|
|
; CHECK-NEXT: [[AND:%.*]] = and i84 %X, 16
|
|
|
|
; CHECK-NEXT: [[CMP:%.*]] = icmp ne i84 [[AND]], 0
|
|
|
|
; CHECK-NEXT: ret i1 [[CMP]]
|
|
|
|
;
|
|
|
|
%shr = ashr i84 %X, 4
|
|
|
|
%and = and i84 %shr, 1
|
|
|
|
%cmp = icmp ne i84 %and, 0
|
|
|
|
ret i1 %cmp
|
|
|
|
}
|
|
|
|
|
2016-08-16 01:55:39 +08:00
|
|
|
; FIXME: Vectors should fold too.
|
2016-08-15 06:56:46 +08:00
|
|
|
define <2 x i1> @test16vec(<2 x i84> %X) {
|
|
|
|
; CHECK-LABEL: @test16vec(
|
|
|
|
; CHECK-NEXT: [[SHR1:%.*]] = lshr <2 x i84> %X, <i84 4, i84 4>
|
|
|
|
; CHECK-NEXT: [[AND:%.*]] = and <2 x i84> [[SHR1]], <i84 1, i84 1>
|
|
|
|
; CHECK-NEXT: [[CMP:%.*]] = icmp ne <2 x i84> [[AND]], zeroinitializer
|
|
|
|
; CHECK-NEXT: ret <2 x i1> [[CMP]]
|
|
|
|
;
|
|
|
|
%shr = ashr <2 x i84> %X, <i84 4, i84 4>
|
|
|
|
%and = and <2 x i84> %shr, <i84 1, i84 1>
|
|
|
|
%cmp = icmp ne <2 x i84> %and, zeroinitializer
|
|
|
|
ret <2 x i1> %cmp
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i1 @test17(i106 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test17(
|
|
|
|
; CHECK-NEXT: [[B_MASK:%.*]] = and i106 %A, -8
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp eq i106 [[B_MASK]], 9872
|
|
|
|
; CHECK-NEXT: ret i1 [[C]]
|
|
|
|
;
|
|
|
|
%B = lshr i106 %A, 3
|
|
|
|
%C = icmp eq i106 %B, 1234
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
2016-08-16 01:55:39 +08:00
|
|
|
define <2 x i1> @test17vec(<2 x i106> %A) {
|
|
|
|
; CHECK-LABEL: @test17vec(
|
2016-08-25 06:22:06 +08:00
|
|
|
; CHECK-NEXT: [[B_MASK:%.*]] = and <2 x i106> %A, <i106 -8, i106 -8>
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp eq <2 x i106> [[B_MASK]], <i106 9872, i106 9872>
|
2016-08-16 01:55:39 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i1> [[C]]
|
|
|
|
;
|
|
|
|
%B = lshr <2 x i106> %A, <i106 3, i106 3>
|
|
|
|
%C = icmp eq <2 x i106> %B, <i106 1234, i106 1234>
|
|
|
|
ret <2 x i1> %C
|
|
|
|
}
|
|
|
|
|
2007-03-24 05:57:47 +08:00
|
|
|
define i1 @test18(i11 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test18(
|
|
|
|
; CHECK-NEXT: ret i1 false
|
|
|
|
;
|
|
|
|
%B = lshr i11 %A, 10
|
|
|
|
%C = icmp eq i11 %B, 123
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i1 @test19(i37 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test19(
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp ult i37 %A, 4
|
|
|
|
; CHECK-NEXT: ret i1 [[C]]
|
|
|
|
;
|
|
|
|
%B = ashr i37 %A, 2
|
|
|
|
%C = icmp eq i37 %B, 0
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
2016-08-16 01:55:39 +08:00
|
|
|
define <2 x i1> @test19vec(<2 x i37> %A) {
|
|
|
|
; CHECK-LABEL: @test19vec(
|
2016-08-25 06:22:06 +08:00
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp ult <2 x i37> %A, <i37 4, i37 4>
|
2016-08-16 01:55:39 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i1> [[C]]
|
|
|
|
;
|
|
|
|
%B = ashr <2 x i37> %A, <i37 2, i37 2>
|
|
|
|
%C = icmp eq <2 x i37> %B, zeroinitializer
|
|
|
|
ret <2 x i1> %C
|
|
|
|
}
|
|
|
|
|
2007-03-24 05:57:47 +08:00
|
|
|
define i1 @test19a(i39 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test19a(
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp ugt i39 %A, -5
|
|
|
|
; CHECK-NEXT: ret i1 [[C]]
|
|
|
|
;
|
|
|
|
%B = ashr i39 %A, 2
|
|
|
|
%C = icmp eq i39 %B, -1
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
2016-08-16 01:55:39 +08:00
|
|
|
; FIXME: Vectors should fold too.
|
|
|
|
define <2 x i1> @test19a_vec(<2 x i39> %A) {
|
|
|
|
; CHECK-LABEL: @test19a_vec(
|
2016-08-25 06:22:06 +08:00
|
|
|
; CHECK-NEXT: [[B_MASK:%.*]] = and <2 x i39> %A, <i39 -4, i39 -4>
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp eq <2 x i39> [[B_MASK]], <i39 -4, i39 -4>
|
2016-08-16 01:55:39 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i1> [[C]]
|
|
|
|
;
|
|
|
|
%B = ashr <2 x i39> %A, <i39 2, i39 2>
|
|
|
|
%C = icmp eq <2 x i39> %B, <i39 -1, i39 -1>
|
|
|
|
ret <2 x i1> %C
|
|
|
|
}
|
|
|
|
|
2007-03-24 05:57:47 +08:00
|
|
|
define i1 @test20(i13 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test20(
|
|
|
|
; CHECK-NEXT: ret i1 false
|
|
|
|
;
|
|
|
|
%B = ashr i13 %A, 12
|
|
|
|
%C = icmp eq i13 %B, 123
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i1 @test21(i12 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test21(
|
|
|
|
; CHECK-NEXT: [[B_MASK:%.*]] = and i12 %A, 63
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp eq i12 [[B_MASK]], 62
|
|
|
|
; CHECK-NEXT: ret i1 [[C]]
|
|
|
|
;
|
|
|
|
%B = shl i12 %A, 6
|
|
|
|
%C = icmp eq i12 %B, -128
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i1 @test22(i14 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test22(
|
|
|
|
; CHECK-NEXT: [[B_MASK:%.*]] = and i14 %A, 127
|
|
|
|
; CHECK-NEXT: [[C:%.*]] = icmp eq i14 [[B_MASK]], 0
|
|
|
|
; CHECK-NEXT: ret i1 [[C]]
|
|
|
|
;
|
|
|
|
%B = shl i14 %A, 7
|
|
|
|
%C = icmp eq i14 %B, 0
|
|
|
|
ret i1 %C
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i11 @test23(i44 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test23(
|
|
|
|
; CHECK-NEXT: [[D:%.*]] = trunc i44 %A to i11
|
|
|
|
; CHECK-NEXT: ret i11 [[D]]
|
|
|
|
;
|
|
|
|
%B = shl i44 %A, 33
|
|
|
|
%C = ashr i44 %B, 33
|
|
|
|
%D = trunc i44 %C to i11
|
|
|
|
ret i11 %D
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i37 @test25(i37 %tmp.2, i37 %AA) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test25(
|
|
|
|
; CHECK-NEXT: [[TMP_3:%.*]] = and i37 %tmp.2, -131072
|
|
|
|
; CHECK-NEXT: [[X2:%.*]] = add i37 [[TMP_3]], %AA
|
|
|
|
; CHECK-NEXT: [[TMP_6:%.*]] = and i37 [[X2]], -131072
|
|
|
|
; CHECK-NEXT: ret i37 [[TMP_6]]
|
|
|
|
;
|
|
|
|
%x = lshr i37 %AA, 17
|
|
|
|
%tmp.3 = lshr i37 %tmp.2, 17
|
|
|
|
%tmp.5 = add i37 %tmp.3, %x
|
|
|
|
%tmp.6 = shl i37 %tmp.5, 17
|
|
|
|
ret i37 %tmp.6
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define i40 @test26(i40 %A) {
|
2016-08-16 01:19:07 +08:00
|
|
|
; CHECK-LABEL: @test26(
|
|
|
|
; CHECK-NEXT: [[B:%.*]] = and i40 %A, -2
|
|
|
|
; CHECK-NEXT: ret i40 [[B]]
|
|
|
|
;
|
|
|
|
%B = lshr i40 %A, 1
|
|
|
|
%C = bitcast i40 %B to i40
|
|
|
|
%D = shl i40 %C, 1
|
|
|
|
ret i40 %D
|
2007-03-24 05:57:47 +08:00
|
|
|
}
|