1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-01-31 20:51:52 +01:00
llvm-mirror/test/MC/AMDGPU/vop3-errs.s
Jay Foad 36faa379a8 [AMDGPU] Allow some modifiers on VOP3B instructions
V_DIV_SCALE_F32/F64 are VOP3B encoded so they can't use the ABS src
modifier, but they can still use NEG and the usual output modifiers.

This partially reverts 3b99f12a4e6f "AMDGPU: Remove modifiers from v_div_scale_*".

Differential Revision: https://reviews.llvm.org/D90296
2020-10-28 21:54:14 +00:00

105 lines
3.6 KiB
ArmAsm

// RUN: not llvm-mc -arch=amdgcn %s 2>&1 | FileCheck %s --check-prefix=GFX67 --check-prefix=GCN --implicit-check-not=error:
// RUN: not llvm-mc -arch=amdgcn -mcpu=tahiti %s 2>&1 | FileCheck %s --check-prefix=GFX67 --check-prefix=GCN --implicit-check-not=error:
// RUN: not llvm-mc -arch=amdgcn -mcpu=fiji %s 2>&1 | FileCheck %s --check-prefix=GFX89 --check-prefix=GCN --implicit-check-not=error:
// RUN: not llvm-mc -arch=amdgcn -mcpu=gfx900 %s 2>&1 | FileCheck %s --check-prefix=GFX89 --check-prefix=GCN --implicit-check-not=error:
v_add_f32_e64 v0, v1
// GCN: error: too few operands for instruction
v_div_scale_f32 v24, vcc, v22, 1.1, v22
// GCN: error: invalid literal operand
v_mqsad_u32_u8 v[0:3], s[2:3], v4, v[0:3]
// GFX67: error: instruction not supported on this GPU
// GFX89: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[0:1], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[1:2], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[2:3], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[3:4], v[0:1], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[4:5], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[5:6], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[8:9], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_mqsad_pk_u16_u8 v[9:10], v[1:2], v9, v[4:5]
// GCN: error: destination must be different than all sources
v_cmp_eq_f32_e64 vcc, v0, v1 mul:2
// GCN: error: invalid operand for instruction
v_cmp_le_f64_e64 vcc, v0, v1 mul:4
// GCN: error: invalid operand for instruction
v_cvt_u32_f32_e64 v0, v1 div:2
// GCN: error: invalid operand for instruction
//
// mul
//
v_cvt_f64_i32 v[5:6], s1 mul:3
// GCN: error: invalid mul value.
//
// v_interp*
//
v_interp_mov_f32_e64 v5, p10, attr0.x high
// GFX67: error: e64 variant of this instruction is not supported
// GFX89: error: invalid operand for instruction
v_interp_mov_f32_e64 v5, p10, attr0.x v0
// GFX67: error: e64 variant of this instruction is not supported
// GFX89: error: invalid operand for instruction
v_interp_p1_f32_e64 v5, v2, attr0.x high
// GFX67: error: e64 variant of this instruction is not supported
// GFX89: error: invalid operand for instruction
v_interp_p1_f32_e64 v5, v2, attr0.x v0
// GFX67: error: e64 variant of this instruction is not supported
// GFX89: error: invalid operand for instruction
v_interp_p2_f32_e64 v255, v2, attr0.x high
// GFX67: error: e64 variant of this instruction is not supported
// GFX89: error: invalid operand for instruction
v_interp_p2_f32_e64 v255, v2, attr0.x v0
// GFX67: error: e64 variant of this instruction is not supported
// GFX89: error: invalid operand for instruction
v_interp_p1ll_f16 v5, p0, attr31.x
// GFX67: error: instruction not supported on this GPU
// GFX89: error: invalid operand for instruction
v_interp_p1ll_f16 v5, v2, attr31.x v0
// GFX67: error: instruction not supported on this GPU
// GFX89: error: invalid operand for instruction
v_interp_p2_f16 v5, v2, attr1.x, v3 mul:2
// GFX67: error: instruction not supported on this GPU
// GFX89: error: invalid operand for instruction
//
// v_div_scale_*
//
v_div_scale_f32 v24, vcc, v22, v22, |v20|
// GCN: error: ABS not allowed in VOP3B instructions
v_div_scale_f64 v[24:25], vcc, -|v[22:23]|, v[22:23], v[20:21]
// GCN: error: ABS not allowed in VOP3B instructions