blob: f48b1132de8838915242b4f6ddeee8ec4abf18d1 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6
; RUN: llc < %s -mtriple=s390x-linux-gnu 2>&1 | FileCheck %s
; Ensure attempting a fcmp->tdc conversion does not crash for vector types.
define <4 x float> @f1(<4 x float> %x, <4 x float> %a, <4 x float> %b) {
; CHECK-LABEL: f1:
; CHECK: # %bb.0:
; CHECK-NEXT: # kill: def $f6s killed $f6s def $f6d
; CHECK-NEXT: # kill: def $f4s killed $f4s def $f4d
; CHECK-NEXT: # kill: def $f2s killed $f2s def $f2d
; CHECK-NEXT: # kill: def $f0s killed $f0s def $f0d
; CHECK-NEXT: lgdr %r1, %f0
; CHECK-NEXT: lgdr %r3, %f2
; CHECK-NEXT: lgdr %r0, %f4
; CHECK-NEXT: lgdr %r2, %f6
; CHECK-NEXT: risbg %r0, %r0, 33, 191, 32
; CHECK-NEXT: risbg %r3, %r3, 33, 191, 32
; CHECK-NEXT: risbg %r1, %r1, 33, 191, 32
; CHECK-NEXT: cfi %r1, 2139095040
; CHECK-NEXT: la %r1, 196(%r15)
; CHECK-NEXT: je .LBB0_2
; CHECK-NEXT: # %bb.1:
; CHECK-NEXT: la %r1, 164(%r15)
; CHECK-NEXT: .LBB0_2:
; CHECK-NEXT: risbg %r2, %r2, 33, 191, 32
; CHECK-NEXT: cfi %r3, 2139095040
; CHECK-NEXT: la %r3, 204(%r15)
; CHECK-NEXT: je .LBB0_4
; CHECK-NEXT: # %bb.3:
; CHECK-NEXT: la %r3, 172(%r15)
; CHECK-NEXT: .LBB0_4:
; CHECK-NEXT: cfi %r0, 2139095040
; CHECK-NEXT: la %r4, 212(%r15)
; CHECK-NEXT: je .LBB0_6
; CHECK-NEXT: # %bb.5:
; CHECK-NEXT: la %r4, 180(%r15)
; CHECK-NEXT: .LBB0_6:
; CHECK-NEXT: le %f0, 0(%r1)
; CHECK-NEXT: le %f2, 0(%r3)
; CHECK-NEXT: le %f4, 0(%r4)
; CHECK-NEXT: cfi %r2, 2139095040
; CHECK-NEXT: la %r1, 220(%r15)
; CHECK-NEXT: je .LBB0_8
; CHECK-NEXT: # %bb.7:
; CHECK-NEXT: la %r1, 188(%r15)
; CHECK-NEXT: .LBB0_8:
; CHECK-NEXT: le %f6, 0(%r1)
; CHECK-NEXT: br %r14
%abs = call <4 x float> @llvm.fabs.v4f32(<4 x float> %x)
%cmp = fcmp ult <4 x float> %abs, splat (float 0x7FF0000000000000)
%sel = select <4 x i1> %cmp, <4 x float> %a, <4 x float> %b
ret <4 x float> %sel
}