summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorJonas Paulsson <paulsson@linux.vnet.ibm.com>2017-05-10 13:03:25 +0000
committerJonas Paulsson <paulsson@linux.vnet.ibm.com>2017-05-10 13:03:25 +0000
commit11d251c05cc498194945cac07ab5d17770e298bf (patch)
tree4e669b66073b3a70225174add14bc872db73f243 /llvm/test
parentda61a7f9efecbba9b5d018d947ff3800fdbc8dc4 (diff)
downloadbcm5719-llvm-11d251c05cc498194945cac07ab5d17770e298bf.tar.gz
bcm5719-llvm-11d251c05cc498194945cac07ab5d17770e298bf.zip
[SystemZ] Implement getRepRegClassFor()
This method must return a valid register class, or the list-ilp isel scheduler will crash. For MVT::Untyped nullptr was previously returned, but now ADDR128BitRegClass is returned instead. This is needed just as long as list-ilp (and probably also list-hybrid) is still there. Review: Ulrich Weigand, A Trick https://reviews.llvm.org/D32802 llvm-svn: 302649
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/CodeGen/SystemZ/list-ilp-crash.ll23
1 files changed, 23 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/SystemZ/list-ilp-crash.ll b/llvm/test/CodeGen/SystemZ/list-ilp-crash.ll
new file mode 100644
index 00000000000..c67ed318b93
--- /dev/null
+++ b/llvm/test/CodeGen/SystemZ/list-ilp-crash.ll
@@ -0,0 +1,23 @@
+; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 -pre-RA-sched=list-ilp | FileCheck %s
+;
+; Check that list-ilp scheduler does not crash due to SystemZ's current use
+; of MVT::Untyped.
+
+define void @pr32723(i8) {
+; CHECK: .text
+BB:
+ br label %CF245
+
+CF245: ; preds = %CF245, %BB
+ %Shuff57 = shufflevector <4 x i8> zeroinitializer, <4 x i8> zeroinitializer, <4 x i32> <i32 0, i32 2, i32 4, i32 6>
+ %Cmp84 = icmp uge i8 %0, undef
+ br i1 %Cmp84, label %CF245, label %CF260
+
+CF260: ; preds = %CF245
+ %B156 = sdiv <4 x i8> %Shuff57, %Shuff57
+ br label %CF255
+
+CF255: ; preds = %CF255, %CF260
+ %I186 = insertelement <4 x i8> %B156, i8 %0, i32 2
+ br label %CF255
+}
OpenPOWER on IntegriCloud