2017-12-08 21:52:28 +01:00
|
|
|
// RUN: not llvm-mc -arch=amdgcn -mcpu=gfx900 -show-encoding %s 2>&1 | FileCheck -check-prefix=GFX9 %s
|
2017-02-27 19:49:11 +01:00
|
|
|
|
|
|
|
// GFX9: 31: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel
|
|
|
|
|
|
|
|
// GFX9: 32: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:
|
|
|
|
|
|
|
|
// GFX9: 33: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[
|
|
|
|
|
|
|
|
// GFX9: 33: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[]
|
|
|
|
|
|
|
|
// GFX9: 34: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[,]
|
|
|
|
|
|
|
|
// XXGFX9: 34: error: failed parsing operand.
|
|
|
|
// v_pk_add_u16 v1, v2, v3 op_sel:[0]
|
|
|
|
|
|
|
|
// GFX9: 35: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[0,]
|
|
|
|
|
|
|
|
// XXGFX9: 36: error: failed parsing operand.
|
|
|
|
// v_pk_add_u16 v1, v2, v3 op_sel:[,0]
|
|
|
|
|
|
|
|
// GFX9: 36: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[0,2]
|
|
|
|
|
|
|
|
// GFX9: 35: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[2,0]
|
|
|
|
|
|
|
|
// GFX9: 33: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[-1,0]
|
|
|
|
|
|
|
|
// GFX9: 35: error: failed parsing operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[0,-1]
|
|
|
|
|
2017-07-21 15:54:11 +02:00
|
|
|
// GFX9: 42: error: not a valid operand.
|
|
|
|
v_pk_add_u16 v1, v2, v3 op_sel:[0,0,0,0,0]
|
2017-02-27 19:49:11 +01:00
|
|
|
|
|
|
|
// XXGFX9: invalid operand for instruction
|
|
|
|
v_pk_add_u16 v1, v2, v3 neg_lo:[0,0]
|
|
|
|
|
|
|
|
//
|
|
|
|
// Regular modifiers on packed instructions
|
|
|
|
//
|
|
|
|
|
|
|
|
// FIXME: should be invalid operand for instruction
|
|
|
|
// GFX9: :18: error: not a valid operand.
|
|
|
|
v_pk_add_f16 v1, |v2|, v3
|
|
|
|
|
2017-08-04 15:55:24 +02:00
|
|
|
// GFX9: :18: error: invalid operand for instruction
|
2017-02-27 19:49:11 +01:00
|
|
|
v_pk_add_f16 v1, abs(v2), v3
|
|
|
|
|
|
|
|
// GFX9: :22: error: not a valid operand.
|
|
|
|
v_pk_add_f16 v1, v2, |v3|
|
|
|
|
|
2017-08-04 15:55:24 +02:00
|
|
|
// GFX9: :22: error: invalid operand for instruction
|
2017-02-27 19:49:11 +01:00
|
|
|
v_pk_add_f16 v1, v2, abs(v3)
|
|
|
|
|
2017-12-22 19:03:35 +01:00
|
|
|
// GFX9: :18: error: invalid operand for instruction
|
2017-02-27 19:49:11 +01:00
|
|
|
v_pk_add_f16 v1, -v2, v3
|
|
|
|
|
2017-12-22 19:03:35 +01:00
|
|
|
// GFX9: :22: error: invalid operand for instruction
|
2017-02-27 19:49:11 +01:00
|
|
|
v_pk_add_f16 v1, v2, -v3
|
|
|
|
|
2017-08-04 15:55:24 +02:00
|
|
|
// GFX9: :18: error: invalid operand for instruction
|
2017-02-27 19:49:11 +01:00
|
|
|
v_pk_add_u16 v1, abs(v2), v3
|
|
|
|
|
2017-12-22 19:03:35 +01:00
|
|
|
// GFX9: :18: error: invalid operand for instruction
|
2017-02-27 19:49:11 +01:00
|
|
|
v_pk_add_u16 v1, -v2, v3
|
|
|
|
|
2017-03-03 15:31:06 +01:00
|
|
|
//
|
|
|
|
// Constant bus restrictions
|
|
|
|
//
|
|
|
|
|
|
|
|
// GFX9: invalid operand (violates constant bus restrictions)
|
|
|
|
v_pk_add_f16 v255, s1, s2
|