1# RUN: llvm-mc -disassemble -triple thumbv8a-none-eabi -mattr=+fullfp16,+thumb-mode -show-encoding < %s | FileCheck %s 2 3# CHECK: vadd.f16 s0, s1, s0 4[0x30,0xee,0x80,0x09] 5 6# CHECK: vsub.f16 s0, s1, s0 7[0x30,0xee,0xc0,0x09] 8 9# CHECK: vdiv.f16 s0, s1, s0 10[0x80,0xee,0x80,0x09] 11 12# CHECK: vmul.f16 s0, s1, s0 13[0x20,0xee,0x80,0x09] 14 15# CHECK: vnmul.f16 s0, s1, s0 16[0x20,0xee,0xc0,0x09] 17 18# CHECK: vmla.f16 s1, s2, s0 19[0x41,0xee,0x00,0x09] 20 21# CHECK: vmls.f16 s1, s2, s0 22[0x41,0xee,0x40,0x09] 23 24# CHECK: vnmla.f16 s1, s2, s0 25[0x51,0xee,0x40,0x09] 26 27# CHECK: vnmls.f16 s1, s2, s0 28[0x51,0xee,0x00,0x09] 29 30# CHECK: vcmp.f16 s0, s1 31[0xb4,0xee,0x60,0x09] 32 33# CHECK: vcmp.f16 s2, #0 34[0xb5,0xee,0x40,0x19] 35 36# CHECK: vcmpe.f16 s1, s0 37[0xf4,0xee,0xc0,0x09] 38 39# CHECK: vcmpe.f16 s0, #0 40[0xb5,0xee,0xc0,0x09] 41 42# CHECK: vabs.f16 s0, s0 43[0xb0,0xee,0xc0,0x09] 44 45# CHECK: vneg.f16 s0, s0 46[0xb1,0xee,0x40,0x09] 47 48# CHECK: vsqrt.f16 s0, s0 49[0xb1,0xee,0xc0,0x09] 50 51# CHECK: vcvt.f16.s32 s0, s0 52# CHECK: vcvt.f16.u32 s0, s0 53# CHECK: vcvt.s32.f16 s0, s0 54# CHECK: vcvt.u32.f16 s0, s0 55[0xb8,0xee,0xc0,0x09] 56[0xb8,0xee,0x40,0x09] 57[0xbd,0xee,0xc0,0x09] 58[0xbc,0xee,0xc0,0x09] 59 60# CHECK: vcvtr.s32.f16 s0, s1 61# CHECK: vcvtr.u32.f16 s0, s1 62[0xbd,0xee,0x60,0x09] 63[0xbc,0xee,0x60,0x09] 64 65# CHECK: vcvt.f16.u32 s0, s0, #20 66# CHECK: vcvt.f16.u16 s0, s0, #1 67# CHECK: vcvt.f16.s32 s1, s1, #20 68# CHECK: vcvt.f16.s16 s17, s17, #1 69# CHECK: vcvt.u32.f16 s12, s12, #20 70# CHECK: vcvt.u16.f16 s28, s28, #1 71# CHECK: vcvt.s32.f16 s1, s1, #20 72# CHECK: vcvt.s16.f16 s17, s17, #1 73[0xbb,0xee,0xc6,0x09] 74[0xbb,0xee,0x67,0x09] 75[0xfa,0xee,0xc6,0x09] 76[0xfa,0xee,0x67,0x89] 77[0xbf,0xee,0xc6,0x69] 78[0xbf,0xee,0x67,0xe9] 79[0xfe,0xee,0xc6,0x09] 80[0xfe,0xee,0x67,0x89] 81 82# CHECK: vcvta.s32.f16 s2, s3 83[0xbc,0xfe,0xe1,0x19] 84 85# CHECK: vcvtn.s32.f16 s6, s23 86[0xbd,0xfe,0xeb,0x39] 87 88# CHECK: vcvtp.s32.f16 s0, s4 89[0xbe,0xfe,0xc2,0x09] 90 91# CHECK: vcvtm.s32.f16 s17, s8 92[0xff,0xfe,0xc4,0x89] 93 94# CHECK: vcvta.u32.f16 s2, s3 95[0xbc,0xfe,0x61,0x19] 96 97# CHECK: vcvtn.u32.f16 s6, s23 98[0xbd,0xfe,0x6b,0x39] 99 100# CHECK: vcvtp.u32.f16 s0, s4 101[0xbe,0xfe,0x42,0x09] 102 103# CHECK: vcvtm.u32.f16 s17, s8 104[0xff,0xfe,0x44,0x89] 105 106# CHECK: vselge.f16 s4, s1, s23 107[0x20,0xfe,0xab,0x29] 108 109# CHECK: vselgt.f16 s0, s1, s0 110[0x30,0xfe,0x80,0x09] 111 112# CHECK: vseleq.f16 s30, s28, s23 113[0x0e,0xfe,0x2b,0xf9] 114 115# CHECK: vselvs.f16 s21, s16, s14 116[0x58,0xfe,0x07,0xa9] 117 118# CHECK: vmaxnm.f16 s5, s12, s0 119[0xc6,0xfe,0x00,0x29] 120 121# CHECK: vminnm.f16 s0, s0, s12 122[0x80,0xfe,0x46,0x09] 123 124# CHECK: vrintz.f16 s3, s24 125[0xf6,0xee,0xcc,0x19] 126 127# CHECK: vrintr.f16 s0, s9 128[0xb6,0xee,0x64,0x09] 129 130# CHECK: vrintx.f16 s10, s14 131[0xb7,0xee,0x47,0x59] 132 133# CHECK: vrinta.f16 s12, s1 134[0xb8,0xfe,0x60,0x69] 135 136# CHECK: vrintn.f16 s12, s1 137[0xb9,0xfe,0x60,0x69] 138 139# CHECK: vrintp.f16 s12, s1 140[0xba,0xfe,0x60,0x69] 141 142# CHECK: vrintm.f16 s12, s1 143[0xbb,0xfe,0x60,0x69] 144 145# CHECK: vfma.f16 s2, s7, s4 146[0xa3,0xee,0x82,0x19] 147 148# CHECK: vfms.f16 s2, s7, s4 149[0xa3,0xee,0xc2,0x19] 150 151# CHECK: vfnma.f16 s2, s7, s4 152[0x93,0xee,0xc2,0x19] 153 154# CHECK: vfnms.f16 s2, s7, s4 155[0x93,0xee,0x82,0x19] 156 157# CHECK: vmovx.f16 s2, s5 158# CHECK: vins.f16 s2, s5 159[0xb0,0xfe,0x62,0x1a] 160[0xb0,0xfe,0xe2,0x1a] 161 162# CHECK: vldr.16 s1, [pc, #6] 163# CHECK: vldr.16 s2, [pc, #510] 164# CHECK: vldr.16 s3, [pc, #-510] 165# CHECK: vldr.16 s4, [r4, #-18] 166[0xdf,0xed,0x03,0x09] 167[0x9f,0xed,0xff,0x19] 168[0x5f,0xed,0xff,0x19] 169[0x14,0xed,0x09,0x29] 170 171# CHECK: vstr.16 s1, [pc, #6] 172# CHECK: vstr.16 s2, [pc, #510] 173# CHECK: vstr.16 s3, [pc, #-510] 174# CHECK: vstr.16 s4, [r4, #-18] 175[0xcf,0xed,0x03,0x09] 176[0x8f,0xed,0xff,0x19] 177[0x4f,0xed,0xff,0x19] 178[0x04,0xed,0x09,0x29] 179 180# CHECK: vmov.f16 s0, #1.0 181[0xb7,0xee,0x00,0x09] 182 183# CHECK: vmov.f16 s1, r2 184# CHECK: vmov.f16 r3, s4 185[0x00,0xee,0x90,0x29] 186[0x12,0xee,0x10,0x39] 187