diff options
| author | Sanjay Patel <spatel@rotateright.com> | 2015-12-11 20:26:30 +0000 |
|---|---|---|
| committer | Sanjay Patel <spatel@rotateright.com> | 2015-12-11 20:26:30 +0000 |
| commit | d497ad43da0d83e9a4713431fc86dc3e648a6d06 (patch) | |
| tree | 4e3c0923f3d937ae255e7c2a048168e7568418c4 | |
| parent | a86545b0b57b55722ba65a4493e313a72ac8d242 (diff) | |
| download | bcm5719-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.ll | 90 |
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 +} + |

