1a888f5e4SIvan Kosarev// RUN: llvm-mc -triple=amdgcn -show-encoding -mcpu=gfx1200 %s | FileCheck --check-prefix=GFX12 %s 25b9be0ecSJay Foad 35b9be0ecSJay Foad// 4e4c8c585SJay Foad// Subtargets allow src1 of VOP3 DPP instructions to be SGPR or inlinable 5e4c8c585SJay Foad// constant. 6e4c8c585SJay Foad// 7e4c8c585SJay Foad 8e4c8c585SJay Foadv_add3_u32_e64_dpp v5, v1, s2, v3 quad_perm:[3,2,1,0] row_mask:0xf bank_mask:0xf 9e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x55,0xd6,0xfa,0x04,0x0c,0x04,0x01,0x1b,0x00,0xff] 10e4c8c585SJay Foad 11e4c8c585SJay Foadv_add3_u32_e64_dpp v5, v1, 42, v3 quad_perm:[3,2,1,0] row_mask:0xf bank_mask:0xf 12e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x55,0xd6,0xfa,0x54,0x0d,0x04,0x01,0x1b,0x00,0xff] 13e4c8c585SJay Foad 14e4c8c585SJay Foadv_add3_u32_e64_dpp v5, v1, s2, v0 dpp8:[7,6,5,4,3,2,1,0] 15e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x55,0xd6,0xe9,0x04,0x00,0x04,0x01,0x77,0x39,0x05] 16e4c8c585SJay Foad 17e4c8c585SJay Foadv_add3_u32_e64_dpp v5, v1, 42, v0 dpp8:[7,6,5,4,3,2,1,0] 18e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x55,0xd6,0xe9,0x54,0x01,0x04,0x01,0x77,0x39,0x05] 19e4c8c585SJay Foad 20e4c8c585SJay Foadv_add3_u32_e64_dpp v5, v1, s2, s3 dpp8:[7,6,5,4,3,2,1,0] 21e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x55,0xd6,0xe9,0x04,0x0c,0x00,0x01,0x77,0x39,0x05] 22e4c8c585SJay Foad 23e4c8c585SJay Foadv_cmp_ne_i32_e64_dpp vcc_lo, v1, s2 dpp8:[7,6,5,4,3,2,1,0] 24e29228efSJoe Nash// GFX12: encoding: [0x6a,0x00,0x45,0xd4,0xe9,0x04,0x00,0x00,0x01,0x77,0x39,0x05] 25e4c8c585SJay Foad 266a13bbf9SJoe Nashv_cmp_le_f32 vcc_lo, v1, v2 row_mirror 27e29228efSJoe Nash// GFX12: encoding: [0xfa,0x04,0x26,0x7c,0x01,0x40,0x01,0xff] 28e29228efSJoe Nash 29e29228efSJoe Nashv_cmp_eq_f32_e64_dpp s5, v1, s99 row_mirror 30e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x12,0xd4,0xfa,0xc6,0x00,0x00,0x01,0x40,0x01,0xff] 31e29228efSJoe Nash 32e29228efSJoe Nashv_cmp_eq_f32_e64_dpp s5, v1, s99 row_half_mirror 33e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x12,0xd4,0xfa,0xc6,0x00,0x00,0x01,0x41,0x01,0xff] 34e29228efSJoe Nash 35e29228efSJoe Nashv_cmp_eq_f32_e64_dpp s5, v1, s99 row_shl:15 36e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x12,0xd4,0xfa,0xc6,0x00,0x00,0x01,0x0f,0x01,0xff] 37e29228efSJoe Nash 38e29228efSJoe Nashv_cmp_eq_f32_e64_dpp s5, v1, s99 row_shr:1 39e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x12,0xd4,0xfa,0xc6,0x00,0x00,0x01,0x11,0x01,0xff] 40e29228efSJoe Nash 41e29228efSJoe Nashv_cmp_eq_f32_e64_dpp s5, v1, s99 row_ror:1 42e29228efSJoe Nash// GFX12: encoding: [0x05,0x00,0x12,0xd4,0xfa,0xc6,0x00,0x00,0x01,0x21,0x01,0xff] 43e29228efSJoe Nash 44e29228efSJoe Nashv_cmp_eq_f32_e64_dpp vcc_hi, |v1|, -s99 row_share:15 row_mask:0x0 bank_mask:0x1 45e29228efSJoe Nash// GFX12: encoding: [0x6b,0x01,0x12,0xd4,0xfa,0xc6,0x00,0x40,0x01,0x5f,0x01,0x01] 46e29228efSJoe Nash 47e29228efSJoe Nashv_cmp_eq_f32_e64_dpp ttmp15, -v1, |s99| row_xmask:0 row_mask:0x1 bank_mask:0x3 bound_ctrl:1 fi:0 48e29228efSJoe Nash// GFX12: encoding: [0x7b,0x02,0x12,0xd4,0xfa,0xc6,0x00,0x20,0x01,0x60,0x09,0x13] 49e29228efSJoe Nash 50e29228efSJoe Nashv_cmpx_gt_f32_e64_dpp v255, 4.0 dpp8:[0,0,0,0,0,0,0,0] fi:0 51e29228efSJoe Nash// GFX12: encoding: [0x7e,0x00,0x94,0xd4,0xe9,0xec,0x01,0x00,0xff,0x00,0x00,0x00] 526a13bbf9SJoe Nash 53e4c8c585SJay Foad// 545b9be0ecSJay Foad// Elements of CPol operand can be given in any order 555b9be0ecSJay Foad// 565b9be0ecSJay Foad 575b9be0ecSJay Foadimage_load v0, v0, s[0:7] dmask:0x1 dim:SQ_RSRC_IMG_1D th:TH_LOAD_HT scope:SCOPE_SE 585b9be0ecSJay Foad// GFX12: encoding: [0x00,0x00,0x40,0xd0,0x00,0x00,0x24,0x00,0x00,0x00,0x00,0x00] 595b9be0ecSJay Foad 605b9be0ecSJay Foadimage_load v0, v0, s[0:7] dmask:0x1 dim:SQ_RSRC_IMG_1D scope:SCOPE_SE th:TH_LOAD_HT 615b9be0ecSJay Foad// GFX12: encoding: [0x00,0x00,0x40,0xd0,0x00,0x00,0x24,0x00,0x00,0x00,0x00,0x00] 625b9be0ecSJay Foad 635b9be0ecSJay Foadimage_sample v[29:30], [v31, v32, v33], s[32:39], s[68:71] dmask:0x3 dim:SQ_RSRC_IMG_3D th:TH_LOAD_NT scope:SCOPE_SYS 645b9be0ecSJay Foad// GFX12: encoding: [0x02,0xc0,0xc6,0xe4,0x1d,0x40,0x1c,0x22,0x1f,0x20,0x21,0x00] 655b9be0ecSJay Foad 665b9be0ecSJay Foadimage_sample v[29:30], [v31, v32, v33], s[32:39], s[68:71] dmask:0x3 dim:SQ_RSRC_IMG_3D scope:SCOPE_SYS th:TH_LOAD_NT 675b9be0ecSJay Foad// GFX12: encoding: [0x02,0xc0,0xc6,0xe4,0x1d,0x40,0x1c,0x22,0x1f,0x20,0x21,0x00] 685b9be0ecSJay Foad 69*2d6d723aSJay Foadglobal_load_block v[9:40], v[5:6], off th:TH_LOAD_HT scope:SCOPE_SE 70*2d6d723aSJay Foad// GFX12: encoding: [0x7c,0xc0,0x14,0xee,0x09,0x00,0x24,0x00,0x05,0x00,0x00,0x00] 71*2d6d723aSJay Foad 72*2d6d723aSJay Foadglobal_load_block v[9:40], v[5:6], off scope:SCOPE_SE th:TH_LOAD_HT 73*2d6d723aSJay Foad// GFX12: encoding: [0x7c,0xc0,0x14,0xee,0x09,0x00,0x24,0x00,0x05,0x00,0x00,0x00] 74*2d6d723aSJay Foad 755b9be0ecSJay Foadbuffer_load_b32 v5, off, s[8:11], s3 offset:8388607 th:TH_LOAD_NT_HT scope:SCOPE_DEV 765b9be0ecSJay Foad// GFX12: encoding: [0x03,0x00,0x05,0xc4,0x05,0x10,0xe8,0x00,0x00,0xff,0xff,0x7f] 775b9be0ecSJay Foad 785b9be0ecSJay Foadbuffer_load_b32 v5, off, s[8:11], s3 offset:8388607 scope:SCOPE_DEV th:TH_LOAD_NT_HT 795b9be0ecSJay Foad// GFX12: encoding: [0x03,0x00,0x05,0xc4,0x05,0x10,0xe8,0x00,0x00,0xff,0xff,0x7f] 805b9be0ecSJay Foad 815b9be0ecSJay Foadtbuffer_load_d16_format_x v4, off, ttmp[4:7], s3 format:[BUF_FMT_8_UINT] offset:8388607 th:TH_LOAD_BYPASS scope:SCOPE_SYS 825b9be0ecSJay Foad// GFX12: encoding: [0x03,0x00,0x22,0xc4,0x04,0xe0,0xbc,0x02,0x00,0xff,0xff,0x7f] 835b9be0ecSJay Foad 845b9be0ecSJay Foadtbuffer_load_d16_format_x v4, off, ttmp[4:7], s3 format:[BUF_FMT_8_UINT] offset:8388607 scope:SCOPE_SYS th:TH_LOAD_BYPASS 855b9be0ecSJay Foad// GFX12: encoding: [0x03,0x00,0x22,0xc4,0x04,0xe0,0xbc,0x02,0x00,0xff,0xff,0x7f] 86