| @ RUN: not llvm-mc -triple armv8a-none-eabi -mattr=-fullfp16 -show-encoding < %s 2>&1 | FileCheck %s |
| @ RUN: not llvm-mc -triple armv8a-none-eabi -mattr=-fullfp16,+thumb-mode -show-encoding < %s 2>&1 | FileCheck %s |
| |
| vadd.f16 s0, s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vsub.f16 s0, s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vdiv.f16 s0, s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vmul.f16 s0, s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vnmul.f16 s0, s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vmla.f16 s1, s2, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vmls.f16 s1, s2, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vnmla.f16 s1, s2, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vnmls.f16 s1, s2, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vcmp.f16 s0, s1 |
| @ CHECK: instruction requires: full half-float |
| |
| vcmp.f16 s2, #0 |
| @ CHECK: instruction requires: full half-float |
| |
| vcmpe.f16 s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vcmpe.f16 s0, #0 |
| @ CHECK: instruction requires: full half-float |
| |
| vabs.f16 s0, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vneg.f16 s0, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vsqrt.f16 s0, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvt.f16.s32 s0, s0 |
| vcvt.f16.u32 s0, s0 |
| vcvt.s32.f16 s0, s0 |
| vcvt.u32.f16 s0, s0 |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtr.s32.f16 s0, s1 |
| vcvtr.u32.f16 s0, s1 |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| |
| vcvt.f16.u32 s0, s0, #20 |
| vcvt.f16.u16 s0, s0, #1 |
| vcvt.f16.s32 s1, s1, #20 |
| vcvt.f16.s16 s17, s17, #1 |
| vcvt.u32.f16 s12, s12, #20 |
| vcvt.u16.f16 s28, s28, #1 |
| vcvt.s32.f16 s1, s1, #20 |
| vcvt.s16.f16 s17, s17, #1 |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| |
| vcvta.s32.f16 s2, s3 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtn.s32.f16 s6, s23 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtp.s32.f16 s0, s4 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtm.s32.f16 s17, s8 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvta.u32.f16 s2, s3 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtn.u32.f16 s6, s23 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtp.u32.f16 s0, s4 |
| @ CHECK: instruction requires: full half-float |
| |
| vcvtm.u32.f16 s17, s8 |
| @ CHECK: instruction requires: full half-float |
| |
| vselge.f16 s4, s1, s23 |
| @ CHECK: instruction requires: full half-float |
| |
| vselgt.f16 s0, s1, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vseleq.f16 s30, s28, s23 |
| @ CHECK: instruction requires: full half-float |
| |
| vselvs.f16 s21, s16, s14 |
| @ CHECK: instruction requires: full half-float |
| |
| vmaxnm.f16 s5, s12, s0 |
| @ CHECK: instruction requires: full half-float |
| |
| vminnm.f16 s0, s0, s12 |
| @ CHECK: instruction requires: full half-float |
| |
| vrintz.f16 s3, s24 |
| @ CHECK: instruction requires: full half-float |
| |
| vrintr.f16 s0, s9 |
| @ CHECK: instruction requires: full half-float |
| |
| vrintx.f16 s10, s14 |
| @ CHECK: instruction requires: full half-float |
| |
| vrinta.f16 s12, s1 |
| @ CHECK: instruction requires: full half-float |
| |
| vrintn.f16 s12, s1 |
| @ CHECK: instruction requires: full half-float |
| |
| vrintp.f16 s12, s1 |
| @ CHECK: instruction requires: full half-float |
| |
| vrintm.f16 s12, s1 |
| @ CHECK: instruction requires: full half-float |
| |
| vfma.f16 s2, s7, s4 |
| @ CHECK: instruction requires: full half-float |
| |
| vfms.f16 s2, s7, s4 |
| @ CHECK: instruction requires: full half-float |
| |
| vfnma.f16 s2, s7, s4 |
| @ CHECK: instruction requires: full half-float |
| |
| vfnms.f16 s2, s7, s4 |
| @ CHECK: instruction requires: full half-float |
| |
| vmovx.f16 s2, s5 |
| vins.f16 s2, s5 |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| |
| |
| vldr.16 s1, [pc, #6] |
| vldr.16 s2, [pc, #510] |
| vldr.16 s3, [pc, #-510] |
| vldr.16 s4, [r4, #-18] |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| |
| |
| vstr.16 s1, [pc, #6] |
| vstr.16 s2, [pc, #510] |
| vstr.16 s3, [pc, #-510] |
| vstr.16 s4, [r4, #-18] |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |
| |
| vmov.f16 s0, #1.0 |
| @ CHECK: instruction requires: full half-float |
| |
| vmov.f16 s1, r2 |
| vmov.f16 r3, s4 |
| @ CHECK: instruction requires: full half-float |
| @ CHECK: instruction requires: full half-float |