llvm/llvm/test/MC/AMDGPU/vop3p-err.s

// RUN: not llvm-mc -triple=amdgcn -mcpu=gfx900 %s 2>&1 | FileCheck -check-prefix=GFX9 --implicit-check-not=error: %s

// GFX9: :[[@LINE+1]]:25: error: invalid operand for instruction
v_pk_add_u16 v1, v2, v3 op_sel

// GFX9: :[[@LINE+1]]:32: error: expected a left square bracket
v_pk_add_u16 v1, v2, v3 op_sel:

// GFX9: :[[@LINE+1]]:33: error: unknown token in expression
v_pk_add_u16 v1, v2, v3 op_sel:[

// GFX9: :[[@LINE+1]]:33: error: unknown token in expression
v_pk_add_u16 v1, v2, v3 op_sel:[]

// GFX9: :[[@LINE+1]]:33: error: unknown token in expression
v_pk_add_u16 v1, v2, v3 op_sel:[,]

// FIXME: Should trigger an error.
// v_pk_add_u16 v1, v2, v3 op_sel:[0]

// GFX9: :[[@LINE+1]]:35: error: expected a comma
v_pk_add_u16 v1, v2, v3 op_sel:[0 0]

// GFX9: :[[@LINE+1]]:35: error: unknown token in expression
v_pk_add_u16 v1, v2, v3 op_sel:[0,]

// GFX9: :[[@LINE+1]]:33: error: unknown token in expression
v_pk_add_u16 v1, v2, v3 op_sel:[,0]

// GFX9: :[[@LINE+1]]:42: error: expected a closing square bracket
v_max3_f16 v5, v1, v2, v3 op_sel:[1,1,1,1,

// GFX9: :[[@LINE+1]]:42: error: expected a closing square bracket
v_max3_f16 v5, v1, v2, v3 op_sel:[1,1,1,1[

// GFX9: :[[@LINE+1]]:43: error: expected a closing square bracket
v_max3_f16 v5, v1, v2, v3 op_sel:[1,1,1,1 1

// GFX9: :[[@LINE+1]]:35: error: invalid op_sel value.
v_pk_add_u16 v1, v2, v3 op_sel:[0,2]

// GFX9: :[[@LINE+1]]:33: error: invalid op_sel value.
v_pk_add_u16 v1, v2, v3 op_sel:[2,0]

// GFX9: :[[@LINE+1]]:33: error: invalid op_sel value.
v_pk_add_u16 v1, v2, v3 op_sel:[-1,0]

// GFX9: :[[@LINE+1]]:35: error: invalid op_sel value.
v_pk_add_u16 v1, v2, v3 op_sel:[0,-1]

// GFX9: :[[@LINE+1]]:40: error: expected a closing square bracket
v_pk_add_u16 v1, v2, v3 op_sel:[0,0,0,0,0]

// FIXME: should trigger an error
v_pk_add_u16 v1, v2, v3 neg_lo:[0,0]

//
// Regular modifiers on packed instructions
//

// FIXME: should be "invalid operand for instruction"
// GFX9: :[[@LINE+1]]:18: error: not a valid operand.
v_pk_add_f16 v1, |v2|, v3

// GFX9: :[[@LINE+1]]:18: error: not a valid operand
v_pk_add_f16 v1, abs(v2), v3

// GFX9: :[[@LINE+1]]:22: error: not a valid operand.
v_pk_add_f16 v1, v2, |v3|

// GFX9: :[[@LINE+1]]:22: error: not a valid operand.
v_pk_add_f16 v1, v2, abs(v3)

// GFX9: :[[@LINE+1]]:18: error: not a valid operand.
v_pk_add_f16 v1, -v2, v3

// GFX9: :[[@LINE+1]]:22: error: not a valid operand.
v_pk_add_f16 v1, v2, -v3

// GFX9: :[[@LINE+1]]:18: error: not a valid operand.
v_pk_add_u16 v1, abs(v2), v3

// GFX9: :[[@LINE+1]]:18: error: not a valid operand.
v_pk_add_u16 v1, -v2, v3

//
// Constant bus restrictions
//

// GFX9: :[[@LINE+1]]:{{[0-9]+}}: error: invalid operand (violates constant bus restrictions)
v_pk_add_f16 v255, s1, s2