summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSanjay Patel <spatel@rotateright.com>2015-12-11 20:26:30 +0000
committerSanjay Patel <spatel@rotateright.com>2015-12-11 20:26:30 +0000
commitd497ad43da0d83e9a4713431fc86dc3e648a6d06 (patch)
tree4e3c0923f3d937ae255e7c2a048168e7568418c4
parenta86545b0b57b55722ba65a4493e313a72ac8d242 (diff)
downloadbcm5719-llvm-d497ad43da0d83e9a4713431fc86dc3e648a6d06.tar.gz
bcm5719-llvm-d497ad43da0d83e9a4713431fc86dc3e648a6d06.zip
Add tests for bitcast-bitcast sequences for all scalar/vector permutations
As noted in http://reviews.llvm.org/D15392 , we should be able to improve this. llvm-svn: 255370
-rw-r--r--llvm/test/Transforms/InstCombine/bitcast-bitcast.ll90
1 files changed, 90 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/bitcast-bitcast.ll b/llvm/test/Transforms/InstCombine/bitcast-bitcast.ll
new file mode 100644
index 00000000000..a67666c60a5
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/bitcast-bitcast.ll
@@ -0,0 +1,90 @@
+; RUN: opt < %s -instcombine -S | FileCheck %s
+
+; Check all scalar / vector combinations for a pair of bitcasts.
+
+define ppc_fp128 @bitcast_bitcast_s_s_s(i128 %a) {
+ %bc1 = bitcast i128 %a to fp128
+ %bc2 = bitcast fp128 %bc1 to ppc_fp128
+ ret ppc_fp128 %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_s_s_s(
+; CHECK-NEXT: %bc2 = bitcast i128 %a to ppc_fp128
+; CHECK-NEXT: ret ppc_fp128 %bc2
+}
+
+define <2 x i32> @bitcast_bitcast_s_s_v(i64 %a) {
+ %bc1 = bitcast i64 %a to double
+ %bc2 = bitcast double %bc1 to <2 x i32>
+ ret <2 x i32> %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_s_s_v(
+; CHECK-NEXT: %bc1 = bitcast i64 %a to double
+; CHECK-NEXT: %bc2 = bitcast double %bc1 to <2 x i32>
+; CHECK-NEXT: ret <2 x i32> %bc2
+}
+
+define double @bitcast_bitcast_s_v_s(i64 %a) {
+ %bc1 = bitcast i64 %a to <2 x i32>
+ %bc2 = bitcast <2 x i32> %bc1 to double
+ ret double %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_s_v_s(
+; CHECK-NEXT: %bc1 = bitcast i64 %a to <2 x i32>
+; CHECK-NEXT: %bc2 = bitcast <2 x i32> %bc1 to double
+; CHECK-NEXT: ret double %bc2
+}
+
+define <2 x i32> @bitcast_bitcast_s_v_v(i64 %a) {
+ %bc1 = bitcast i64 %a to <4 x i16>
+ %bc2 = bitcast <4 x i16> %bc1 to <2 x i32>
+ ret <2 x i32> %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_s_v_v(
+; CHECK-NEXT: %bc1 = bitcast i64 %a to <4 x i16>
+; CHECK-NEXT: %bc2 = bitcast <4 x i16> %bc1 to <2 x i32>
+; CHECK-NEXT: ret <2 x i32> %bc2
+}
+
+define i64 @bitcast_bitcast_v_s_s(<2 x i32> %a) {
+ %bc1 = bitcast <2 x i32> %a to double
+ %bc2 = bitcast double %bc1 to i64
+ ret i64 %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_v_s_s(
+; CHECK-NEXT: %bc1 = bitcast <2 x i32> %a to double
+; CHECK-NEXT: %bc2 = bitcast double %bc1 to i64
+; CHECK-NEXT: ret i64 %bc2
+}
+
+define <4 x i16> @bitcast_bitcast_v_s_v(<2 x i32> %a) {
+ %bc1 = bitcast <2 x i32> %a to double
+ %bc2 = bitcast double %bc1 to <4 x i16>
+ ret <4 x i16> %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_v_s_v(
+; CHECK-NEXT: %bc1 = bitcast <2 x i32> %a to double
+; CHECK-NEXT: %bc2 = bitcast double %bc1 to <4 x i16>
+; CHECK-NEXT: ret <4 x i16> %bc2
+}
+
+define double @bitcast_bitcast_v_v_s(<2 x float> %a) {
+ %bc1 = bitcast <2 x float> %a to <4 x i16>
+ %bc2 = bitcast <4 x i16> %bc1 to double
+ ret double %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_v_v_s(
+; CHECK-NEXT: %bc1 = bitcast <2 x float> %a to <4 x i16>
+; CHECK-NEXT: %bc2 = bitcast <4 x i16> %bc1 to double
+; CHECK-NEXT: ret double %bc2
+}
+
+define <2 x i32> @bitcast_bitcast_v_v_v(<2 x float> %a) {
+ %bc1 = bitcast <2 x float> %a to <4 x i16>
+ %bc2 = bitcast <4 x i16> %bc1 to <2 x i32>
+ ret <2 x i32> %bc2
+
+; CHECK-LABEL: @bitcast_bitcast_v_v_v(
+; CHECK-NEXT: %bc2 = bitcast <2 x float> %a to <2 x i32>
+; CHECK-NEXT: ret <2 x i32> %bc2
+}
+
OpenPOWER on IntegriCloud