223 lines
8.5 KiB
ArmAsm
223 lines
8.5 KiB
ArmAsm
|
// RUN: not llvm-mc -triple=aarch64-none-linux-gnu -show-encoding -mattr=+sve 2>&1 < %s | FileCheck %s
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Type suffix on unpredicated movprfx
|
||
|
|
||
|
movprfx z0.b, z1.b
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid operand for instruction
|
||
|
// CHECK-NEXT: movprfx z0.b, z1.b
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
movprfx z0.b, z1.s
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid operand for instruction
|
||
|
// CHECK-NEXT: movprfx z0.b, z1.s
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
movprfx z0, z1.s
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: expected register without element width suffix
|
||
|
// CHECK-NEXT: movprfx z0, z1.s
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different destination register (unary)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
abs z2.d, p0/m, z2.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx writing to a different destination
|
||
|
// CHECK-NEXT: abs z2.d, p0/m, z2.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different destination register (binary)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
add z2.d, p0/m, z2.d, z0.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx writing to a different destination
|
||
|
// CHECK-NEXT: add z2.d, p0/m, z2.d, z0.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different destination register (wide element)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
asr z2.s, p0/m, z2.s, z0.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx writing to a different destination
|
||
|
// CHECK-NEXT: asr z2.s, p0/m, z2.s, z0.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different destination register (ternary)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
mla z3.d, p0/m, z1.d, z2.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx writing to a different destination
|
||
|
// CHECK-NEXT: mla z3.d, p0/m, z1.d, z2.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Destination used in other operand (unary)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
abs z0.d, p0/m, z0.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: abs z0.d, p0/m, z0.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
movprfx z0.d, p0/z, z1.d
|
||
|
cpy z0.d, p0/m, d0
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: cpy z0.d, p0/m, d0
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
movprfx z0.d, p0/z, z1.d
|
||
|
mov z0.d, p0/m, d0
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: mov z0.d, p0/m, d0
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Destination used in other operand (binary)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
add z0.d, p0/m, z0.d, z0.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: add z0.d, p0/m, z0.d, z0.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Destination used in other operand (wide element)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
asr z0.s, p0/m, z0.s, z0.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: asr z0.s, p0/m, z0.s, z0.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Destination used in other operand (ternary)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
mla z0.d, p0/m, z0.d, z2.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: mla z0.d, p0/m, z0.d, z2.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Destination used in other operand (ternary + indexed)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
sdot z0.s, z1.b, z0.b[3]
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx and destination also used as non-destructive source
|
||
|
// CHECK-NEXT: sdot z0.s, z1.b, z0.b[3]
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different general predicate (unary)
|
||
|
|
||
|
movprfx z0.d, p0/m, z1.d
|
||
|
abs z0.d, p1/m, z1.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx using a different general predicate
|
||
|
// CHECK-NEXT: abs z0.d, p1/m, z1.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different general predicate (binary)
|
||
|
|
||
|
movprfx z0.d, p0/m, z1.d
|
||
|
add z0.d, p1/m, z0.d, z1.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx using a different general predicate
|
||
|
// CHECK-NEXT: add z0.d, p1/m, z0.d, z1.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different general predicate (wide element)
|
||
|
|
||
|
movprfx z0.d, p0/m, z1.d
|
||
|
asr z0.s, p1/m, z0.s, z1.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx using a different general predicate
|
||
|
// CHECK-NEXT: asr z0.s, p1/m, z0.s, z1.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different general predicate (ternary)
|
||
|
|
||
|
movprfx z0.d, p0/m, z1.d
|
||
|
mla z0.d, p1/m, z1.d, z2.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx using a different general predicate
|
||
|
// CHECK-NEXT: mla z0.d, p1/m, z1.d, z2.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different element size (unary)
|
||
|
|
||
|
movprfx z0.s, p0/m, z1.s
|
||
|
abs z0.d, p0/m, z1.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx with a different element size
|
||
|
// CHECK-NEXT: abs z0.d, p0/m, z1.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different element size (binary)
|
||
|
|
||
|
movprfx z0.s, p0/m, z1.s
|
||
|
add z0.d, p0/m, z0.d, z1.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx with a different element size
|
||
|
// CHECK-NEXT: add z0.d, p0/m, z0.d, z1.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different element size (wide element)
|
||
|
|
||
|
movprfx z0.d, p0/m, z1.d
|
||
|
asr z0.s, p0/m, z0.s, z1.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx with a different element size
|
||
|
// CHECK-NEXT: asr z0.s, p0/m, z0.s, z1.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Different element size (ternary)
|
||
|
|
||
|
movprfx z0.s, p0/m, z1.s
|
||
|
mla z0.d, p0/m, z1.d, z2.d
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx with a different element size
|
||
|
// CHECK-NEXT: mla z0.d, p0/m, z1.d, z2.d
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Predicated movprfx with non-predicated instruction.
|
||
|
|
||
|
movprfx z0.d, p0/m, z1.d
|
||
|
add z0.d, z0.d, #1
|
||
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: instruction is unpredictable when following a predicated movprfx, suggest using unpredicated movprfx
|
||
|
// CHECK-NEXT: add z0.d, z0.d, #1
|
||
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------- //
|
||
|
// Ensure we don't try to apply a prefix to subsequent instructions (upon failure)
|
||
|
|
||
|
movprfx z0, z1
|
||
|
add z0.d, z1.d, z2.d
|
||
|
add z0.d, z1.d, z2.d
|
||
|
// CHECK: [[@LINE-2]]:{{[0-9]+}}: error: instruction is unpredictable when following a movprfx, suggest replacing movprfx with mov
|
||
|
// CHECK-NEXT: add z0.d, z1.d, z2.d
|
||
|
// CHECK-NOT: [[@LINE-3]]:{{[0-9]+}}:
|
||
|
// CHECK: add z0.d, z1.d, z2.d
|