[llvm] r345566 - [AArch64] Add test case for D53229. NFC
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Mon Oct 29 20:27:14 PDT 2018
Author: ctopper
Date: Mon Oct 29 20:27:13 2018
New Revision: 345566
URL: http://llvm.org/viewvc/llvm-project?rev=345566&view=rev
Log:
[AArch64] Add test case for D53229. NFC
Added:
llvm/trunk/test/CodeGen/AArch64/bitcast-promote-widen.ll
Added: llvm/trunk/test/CodeGen/AArch64/bitcast-promote-widen.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/AArch64/bitcast-promote-widen.ll?rev=345566&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/AArch64/bitcast-promote-widen.ll (added)
+++ llvm/trunk/test/CodeGen/AArch64/bitcast-promote-widen.ll Mon Oct 29 20:27:13 2018
@@ -0,0 +1,31 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
+; RUN: llc < %s -mtriple=aarch64-unknown-linux-gnu | FileCheck %s
+
+; Test cases of bitcasts where one type needs to be widened and one needs to be promoted.
+
+define <2 x i16> @bitcast_v2i16_v2f16(<2 x half> %x) {
+; CHECK-LABEL: bitcast_v2i16_v2f16:
+; CHECK: // %bb.0:
+; CHECK-NEXT: sub sp, sp, #16 // =16
+; CHECK-NEXT: .cfi_def_cfa_offset 16
+; CHECK-NEXT: // kill: def $d0 killed $d0 def $q0
+; CHECK-NEXT: str s0, [sp, #12]
+; CHECK-NEXT: ldrh w8, [sp, #12]
+; CHECK-NEXT: ldrh w9, [sp, #14]
+; CHECK-NEXT: fmov s0, w8
+; CHECK-NEXT: mov v0.s[1], w9
+; CHECK-NEXT: // kill: def $d0 killed $d0 killed $q0
+; CHECK-NEXT: add sp, sp, #16 // =16
+; CHECK-NEXT: ret
+ %y = bitcast <2 x half> %x to <2 x i16>
+ ret <2 x i16> %y
+}
+
+define <2 x half> @bitcast_v2f16_v2i16(<2 x i16> %x) {
+; CHECK-LABEL: bitcast_v2f16_v2i16:
+; CHECK: // %bb.0:
+; CHECK-NEXT: uzp1 v0.4h, v0.4h, v0.4h
+; CHECK-NEXT: ret
+ %y = bitcast <2 x i16> %x to <2 x half>
+ ret <2 x half> %y
+}
More information about the llvm-commits
mailing list