Fill out support for Thumb2 encodings of NEON instructions.
[oota-llvm.git] / test / MC / ARM / neont2-absdiff-encoding.s
1 @ RUN: llvm-mc -mcpu=cortex-a8 -triple thumb-unknown-unkown -show-encoding < %s | FileCheck %s
2 @ XFAIL: *
3 @ NOTE: This currently fails because the ASM parser doesn't parse vabal.
4
5 .code 16
6
7 @ CHECK: vabd.s8        d16, d16, d17           @ encoding: [0xa1,0x07,0x40,0xef]
8         vabd.s8 d16, d16, d17
9 @ CHECK: vabd.s16       d16, d16, d17   @ encoding: [0xa1,0x07,0x50,0xef]
10         vabd.s16        d16, d16, d17
11 @ CHECK: vabd.s32       d16, d16, d17   @ encoding: [0xa1,0x07,0x60,0xef]
12         vabd.s32        d16, d16, d17
13 @ CHECK: vabd.u8        d16, d16, d17           @ encoding: [0xa1,0x07,0x40,0xff]
14         vabd.u8 d16, d16, d17
15 @ CHECK: vabd.u16       d16, d16, d17   @ encoding: [0xa1,0x07,0x50,0xff]
16         vabd.u16        d16, d16, d17
17   @ CHECK: vabd.u32     d16, d16, d17   @ encoding: [0xa1,0x07,0x60,0xff]
18         vabd.u32        d16, d16, d17
19 @ CHECK: vabd.f32       d16, d16, d17   @ encoding: [0xa1,0x0d,0x60,0xff]
20         vabd.f32        d16, d16, d17
21 @ CHECK: vabd.s8        q8, q8, q9              @ encoding: [0xe2,0x07,0x40,0xef]
22         vabd.s8 q8, q8, q9
23 @ CHECK: vabd.s16       q8, q8, q9      @ encoding: [0xe2,0x07,0x50,0xef]
24         vabd.s16        q8, q8, q9
25 @ CHECK: vabd.s32       q8, q8, q9      @ encoding: [0xe2,0x07,0x60,0xef]
26         vabd.s32        q8, q8, q9
27 @ CHECK: vabd.u8        q8, q8, q9              @ encoding: [0xe2,0x07,0x40,0xff]
28         vabd.u8 q8, q8, q9
29 @ CHECK: vabd.u16       q8, q8, q9      @ encoding: [0xe2,0x07,0x50,0xff]
30         vabd.u16        q8, q8, q9
31 @ CHECK: vabd.u32       q8, q8, q9      @ encoding: [0xe2,0x07,0x60,0xff]
32         vabd.u32        q8, q8, q9
33 @ CHECK: vabd.f32       q8, q8, q9      @ encoding: [0xe2,0x0d,0x60,0xff]
34         vabd.f32        q8, q8, q9
35
36 @ CHECK: vabdl.s8       q8, d16, d17    @ encoding: [0xa1,0x07,0xc0,0xef]
37         vabdl.s8        q8, d16, d17
38 @ CHECK: vabdl.s16      q8, d16, d17    @ encoding: [0xa1,0x07,0xd0,0xef]
39         vabdl.s16       q8, d16, d17
40 @ CHECK: vabdl.s32      q8, d16, d17    @ encoding: [0xa1,0x07,0xe0,0xef]
41         vabdl.s32       q8, d16, d17
42 @ CHECK: vabdl.u8       q8, d16, d17    @ encoding: [0xa1,0x07,0xc0,0xff]
43         vabdl.u8        q8, d16, d17
44 @ CHECK: vabdl.u16      q8, d16, d17    @ encoding: [0xa1,0x07,0xd0,0xff]
45         vabdl.u16       q8, d16, d17
46 @ CHECK: vabdl.u32      q8, d16, d17    @ encoding: [0xa1,0x07,0xe0,0xff]
47         vabdl.u32       q8, d16, d17
48
49 @ CHECK: vaba.s8        d16, d18, d17           @ encoding: [0xb1,0x07,0x42,0xef]
50         vaba.s8 d16, d18, d17
51 @ CHECK: vaba.s16       d16, d18, d17   @ encoding: [0xb1,0x07,0x52,0xef]
52         vaba.s16        d16, d18, d17
53 @ CHECK: vaba.s32       d16, d18, d17   @ encoding: [0xb1,0x07,0x62,0xef]
54         vaba.s32        d16, d18, d17
55 @ CHECK: vaba.u8        d16, d18, d17           @ encoding: [0xb1,0x07,0x42,0xff]
56         vaba.u8 d16, d18, d17
57 @ CHECK: vaba.u16       d16, d18, d17   @ encoding: [0xb1,0x07,0x52,0xff]
58         vaba.u16        d16, d18, d17
59 @ CHECK: vaba.u32       d16, d18, d17   @ encoding: [0xb1,0x07,0x62,0xff]
60         vaba.u32        d16, d18, d17
61 @ CHECK: vaba.s8        q9, q8, q10             @ encoding: [0xf4,0x27,0x40,0xef]
62         vaba.s8 q9, q8, q10
63 @ CHECK: vaba.s16       q9, q8, q10     @ encoding: [0xf4,0x27,0x50,0xef]
64         vaba.s16        q9, q8, q10
65 @ CHECK: vaba.s32       q9, q8, q10     @ encoding: [0xf4,0x27,0x60,0xef]
66         vaba.s32        q9, q8, q10
67 @ CHECK: vaba.u8        q9, q8, q10             @ encoding: [0xf4,0x27,0x40,0xff]
68         vaba.u8 q9, q8, q10
69 @ CHECK: vaba.u16       q9, q8, q10     @ encoding: [0xf4,0x27,0x50,0xff]
70         vaba.u16        q9, q8, q10
71 @ CHECK: vaba.u32       q9, q8, q10     @ encoding: [0xf4,0x27,0x60,0xff]
72         vaba.u32        q9, q8, q10
73
74 @ CHECK: vabal.s8       q8, d19, d18    @ encoding: [0xa2,0x05,0xc3,0xef]
75         vabal.s8        q8, d19, d18
76 @ CHECK: vabal.s16      q8, d19, d18    @ encoding: [0xa2,0x05,0xd3,0xef]
77         vabal.s16       q8, d19, d18
78 @ CHECK: vabal.s32      q8, d19, d18    @ encoding: [0xa2,0x05,0xe3,0xef]
79         vabal.s32       q8, d19, d18
80 @ CHECK: vabal.u8       q8, d19, d18    @ encoding: [0xa2,0x05,0xc3,0xff]
81         vabal.u8        q8, d19, d18
82 @ CHECK:        vabal.u16       q8, d19, d18    @ encoding: [0xa2,0x05,0xd3,0xff]
83         vabal.u16       q8, d19, d18
84 @ CHECK: vabal.u32      q8, d19, d18    @ encoding: [0xa2,0x05,0xe3,0xff]
85         vabal.u32       q8, d19, d18
86