summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorSimon Pilgrim <llvm-dev@redking.me.uk>2016-09-13 17:15:28 +0000
committerSimon Pilgrim <llvm-dev@redking.me.uk>2016-09-13 17:15:28 +0000
commitbd28a85d14aedd38fd9b1bd5fba45efbccc5a5cf (patch)
tree564f2ac8492cab9b9b5478899d5d3398142668e0 /llvm/test
parent3569eb52670f538d2d7512659f862e3faf44702a (diff)
downloadbcm5719-llvm-bd28a85d14aedd38fd9b1bd5fba45efbccc5a5cf.tar.gz
bcm5719-llvm-bd28a85d14aedd38fd9b1bd5fba45efbccc5a5cf.zip
[DAGCombiner] Use APInt directly in (shl (ext (shl x, c1)), c2) combine
Fix failure to detect out of range shift constants leading to assert in ConstantSDNode::getZExtValue() Followup to D23007 llvm-svn: 281354
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/CodeGen/X86/shift-i128.ll18
1 files changed, 18 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/shift-i128.ll b/llvm/test/CodeGen/X86/shift-i128.ll
index aef923f8d10..1de99b15e42 100644
--- a/llvm/test/CodeGen/X86/shift-i128.ll
+++ b/llvm/test/CodeGen/X86/shift-i128.ll
@@ -116,3 +116,21 @@ entry:
store <2 x i128> %1, <2 x i128>* %r, align 16
ret void
}
+
+;
+; Combines
+;
+
+define <2 x i256> @shl_sext_shl_outofrange(<2 x i128> %a0) {
+ %1 = shl <2 x i128> %a0, <i128 -1, i128 -1>
+ %2 = sext <2 x i128> %1 to <2 x i256>
+ %3 = shl <2 x i256> %2, <i256 128, i256 128>
+ ret <2 x i256> %3
+}
+
+define <2 x i256> @shl_zext_shl_outofrange(<2 x i128> %a0) {
+ %1 = shl <2 x i128> %a0, <i128 -1, i128 -1>
+ %2 = zext <2 x i128> %1 to <2 x i256>
+ %3 = shl <2 x i256> %2, <i256 128, i256 128>
+ ret <2 x i256> %3
+}
OpenPOWER on IntegriCloud