; 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 }