[AArch64][SVE] Asm: Support for vector element FP compare.
Contains the following variants:
- Compare with (elements from) other vector
instructions: fcmeq, fcmgt, fcmge, fcmne, fcmuo.
aliases: fcmle, fcmlt.
e.g. fcmle p0.h, p0/z, z0.h, z1.h => fcmge p0.h, p0/z, z1.h, z0.h
- Compare absolute values with (absolute values from) other vector.
instructions: facge, facgt.
aliases: facle, faclt.
e.g. facle p0.h, p0/z, z0.h, z1.h => facge p0.h, p0/z, z1.h, z0.h
- Compare vector elements with #0.0
instructions: fcmeq, fcmgt, fcmge, fcmle, fcmlt, fcmne.
e.g. fcmle p0.h, p0/z, z0.h, #0.0
llvm-svn: 336182
2018-07-03 17:07:23 +08:00
|
|
|
// RUN: not llvm-mc -triple=aarch64 -show-encoding -mattr=+sve 2>&1 < %s| FileCheck %s
|
|
|
|
|
|
|
|
facge p0.b, p0/z, z0.b, z0.b
|
|
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid predicate register
|
|
|
|
// CHECK-NEXT: facge p0.b, p0/z, z0.b, z0.b
|
|
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
|
|
|
|
facge p0.b, p0/z, z0.b, #0.0
|
|
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected floating point literal
|
|
|
|
// CHECK-NEXT: facge p0.b, p0/z, z0.b, #0.0
|
|
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
2018-07-31 00:05:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------//
|
|
|
|
// Negative tests for instructions that are incompatible with movprfx
|
|
|
|
|
|
|
|
movprfx z0.d, p0/z, z7.d
|
|
|
|
facge p0.d, p0/z, z0.d, z1.d
|
|
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx, suggest replacing movprfx with mov
|
|
|
|
// CHECK-NEXT: facge p0.d, p0/z, z0.d, z1.d
|
|
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
|
|
|
|
movprfx z0, z7
|
|
|
|
facge p0.d, p0/z, z0.d, z1.d
|
|
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx, suggest replacing movprfx with mov
|
|
|
|
// CHECK-NEXT: facge p0.d, p0/z, z0.d, z1.d
|
|
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|