blob: ee5cee5e86024f250997737914e6ca5068f890e9 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=amdgcn-- -mcpu=gfx950 < %s | FileCheck -check-prefix=GFX950 %s
; RUN: llc -mtriple=amdgcn-- -mcpu=gfx1250 < %s | FileCheck -check-prefix=GFX1250 %s
define i64 @srl_bv_v4i16_extract_last(i16 %a, i16 %b, i16 %c, i16 %d) {
; GFX950-LABEL: srl_bv_v4i16_extract_last:
; GFX950: ; %bb.0:
; GFX950-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
; GFX950-NEXT: v_and_b32_e32 v0, 0xffff, v3
; GFX950-NEXT: v_mov_b32_e32 v1, 0
; GFX950-NEXT: s_setpc_b64 s[30:31]
;
; GFX1250-LABEL: srl_bv_v4i16_extract_last:
; GFX1250: ; %bb.0:
; GFX1250-NEXT: s_wait_loadcnt_dscnt 0x0
; GFX1250-NEXT: s_wait_kmcnt 0x0
; GFX1250-NEXT: v_mov_b16_e32 v0.h, 0
; GFX1250-NEXT: v_mov_b16_e32 v0.l, v3.l
; GFX1250-NEXT: v_mov_b32_e32 v1, 0
; GFX1250-NEXT: s_set_pc_i64 s[30:31]
%bv0 = insertelement <4 x i16> poison, i16 %a, i32 0
%bv1 = insertelement <4 x i16> %bv0, i16 %b, i32 1
%bv2 = insertelement <4 x i16> %bv1, i16 %c, i32 2
%bv3 = insertelement <4 x i16> %bv2, i16 %d, i32 3
%bc = bitcast <4 x i16> %bv3 to i64
%srl = lshr i64 %bc, 48
ret i64 %srl
}
define i64 @srl_bv_v2f32_extract_last(float %a, float %b) {
; GFX950-LABEL: srl_bv_v2f32_extract_last:
; GFX950: ; %bb.0:
; GFX950-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
; GFX950-NEXT: v_mov_b32_e32 v0, v1
; GFX950-NEXT: v_mov_b32_e32 v1, 0
; GFX950-NEXT: s_setpc_b64 s[30:31]
;
; GFX1250-LABEL: srl_bv_v2f32_extract_last:
; GFX1250: ; %bb.0:
; GFX1250-NEXT: s_wait_loadcnt_dscnt 0x0
; GFX1250-NEXT: s_wait_kmcnt 0x0
; GFX1250-NEXT: v_dual_mov_b32 v0, v1 :: v_dual_mov_b32 v1, 0
; GFX1250-NEXT: s_set_pc_i64 s[30:31]
%bv0 = insertelement <2 x float> poison, float %a, i32 0
%bv1 = insertelement <2 x float> %bv0, float %b, i32 1
%bc = bitcast <2 x float> %bv1 to i64
%srl = lshr i64 %bc, 32
ret i64 %srl
}
; Negative test: shift amount is not (NumElts-1) * EltSize.
define i64 @srl_bv_not_last(i16 %a, i16 %b, i16 %c, i16 %d) {
; GFX950-LABEL: srl_bv_not_last:
; GFX950: ; %bb.0:
; GFX950-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
; GFX950-NEXT: s_mov_b32 s0, 0x5040100
; GFX950-NEXT: v_perm_b32 v2, v3, v2, s0
; GFX950-NEXT: v_perm_b32 v0, v1, v0, s0
; GFX950-NEXT: v_alignbit_b32 v0, v2, v0, 16
; GFX950-NEXT: v_and_b32_e32 v1, 0xffff, v3
; GFX950-NEXT: s_setpc_b64 s[30:31]
;
; GFX1250-LABEL: srl_bv_not_last:
; GFX1250: ; %bb.0:
; GFX1250-NEXT: s_wait_loadcnt_dscnt 0x0
; GFX1250-NEXT: s_wait_kmcnt 0x0
; GFX1250-NEXT: v_mov_b16_e32 v2.h, v3.l
; GFX1250-NEXT: v_mov_b16_e32 v0.h, v1.l
; GFX1250-NEXT: v_mov_b16_e32 v1.h, 0
; GFX1250-NEXT: v_mov_b16_e32 v1.l, v3.l
; GFX1250-NEXT: s_delay_alu instid0(VALU_DEP_3)
; GFX1250-NEXT: v_alignbit_b32 v0, v2, v0, 16
; GFX1250-NEXT: s_set_pc_i64 s[30:31]
%bv0 = insertelement <4 x i16> poison, i16 %a, i32 0
%bv1 = insertelement <4 x i16> %bv0, i16 %b, i32 1
%bv2 = insertelement <4 x i16> %bv1, i16 %c, i32 2
%bv3 = insertelement <4 x i16> %bv2, i16 %d, i32 3
%bc = bitcast <4 x i16> %bv3 to i64
%srl = lshr i64 %bc, 16
ret i64 %srl
}