1 # RUN: llvm-mc -triple arm-none-linux-gnu -mattr=+dotprod --disassemble < %s | FileCheck %s
2 # RUN: llvm-mc -triple arm-none-linux-gnu -mattr=-dotprod --disassemble < %s 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR
13 #CHECK: vudot.u8 d0, d1, d2
14 #CHECK: vsdot.s8 d0, d1, d2
15 #CHECK: vudot.u8 q0, q1, q4
16 #CHECK: vsdot.s8 q0, q1, q4
17 #CHECK: vudot.u8 d0, d1, d2[0]
18 #CHECK: vsdot.s8 d0, d1, d2[1]
19 #CHECK: vudot.u8 q0, q1, d4[0]
20 #CHECK: vsdot.s8 q0, q1, d4[1]
22 # without dot product enabled, the instructions get disassembled to these
23 # coprocessor instructions:
25 #CHECK-ERROR: stc2 p13, c0, [r1], #-72
26 #CHECK-ERROR: stc2 p13, c0, [r1], #-8
27 #CHECK-ERROR: stc2 p13, c0, [r2], #-352
28 #CHECK-ERROR: stc2 p13, c0, [r2], #-288
29 #CHECK-ERROR: mcr2 p13, #1, r0, c1, c2, #0
30 #CHECK-ERROR: cdp2 p13, #2, c0, c1, c2, #1
31 #CHECK-ERROR: mcr2 p13, #1, r0, c2, c4, #2
32 #CHECK-ERROR: cdp2 p13, #2, c0, c2, c4, #3