ARM VSHR implied destination operand form aliases.
[oota-llvm.git] / test / MC / ARM / neon-cmp-encoding.s
index 27ebc8a9363bf76f37559a8b3a5a1a0cae4431d7..57de2db9c62156717da0135cc079dabedf089817 100644 (file)
-@ RUN: llvm-mc -mcpu=cortex-a8 -triple arm-unknown-unkown -show-encoding < %s | FileCheck %s
-@ XFAIL: *
+@ RUN: llvm-mc -mcpu=cortex-a8 -triple arm-unknown-unknown -show-encoding < %s | FileCheck %s
 
-@ FIXME: We cannot currently test the following instructions, which are 
-@ currently marked as for-disassembly only in the .td files:
-@  - VCEQz
-@  - VCGEz, VCLEz
-@  - VCGTz, VCLTz
-
-@ CHECK: vceq.i8       d16, d16, d17           @ encoding: [0xb1,0x08,0x40,0xf3]
        vceq.i8 d16, d16, d17
-@ CHECK: vceq.i16      d16, d16, d17   @ encoding: [0xb1,0x08,0x50,0xf3]
        vceq.i16        d16, d16, d17
-@ CHECK: vceq.i32      d16, d16, d17   @ encoding: [0xb1,0x08,0x60,0xf3]
        vceq.i32        d16, d16, d17
-@ CHECK: vceq.f32      d16, d16, d17   @ encoding: [0xa1,0x0e,0x40,0xf2]
        vceq.f32        d16, d16, d17
-@ CHECK: vceq.i8       q8, q8, q9              @ encoding: [0xf2,0x08,0x40,0xf3]
        vceq.i8 q8, q8, q9
-@ CHECK: vceq.i16      q8, q8, q9      @ encoding: [0xf2,0x08,0x50,0xf3]
        vceq.i16        q8, q8, q9
-@ CHECK: vceq.i32      q8, q8, q9      @ encoding: [0xf2,0x08,0x60,0xf3]
        vceq.i32        q8, q8, q9
-@ CHECK: vceq.f32      q8, q8, q9      @ encoding: [0xe2,0x0e,0x40,0xf2]
        vceq.f32        q8, q8, q9
 
-@ CHECK: vcge.s8       d16, d16, d17           @ encoding: [0xb1,0x03,0x40,0xf2]
+@ CHECK: vceq.i8       d16, d16, d17   @ encoding: [0xb1,0x08,0x40,0xf3]
+@ CHECK: vceq.i16      d16, d16, d17   @ encoding: [0xb1,0x08,0x50,0xf3]
+@ CHECK: vceq.i32      d16, d16, d17   @ encoding: [0xb1,0x08,0x60,0xf3]
+@ CHECK: vceq.f32      d16, d16, d17   @ encoding: [0xa1,0x0e,0x40,0xf2]
+@ CHECK: vceq.i8       q8, q8, q9      @ encoding: [0xf2,0x08,0x40,0xf3]
+@ CHECK: vceq.i16      q8, q8, q9      @ encoding: [0xf2,0x08,0x50,0xf3]
+@ CHECK: vceq.i32      q8, q8, q9      @ encoding: [0xf2,0x08,0x60,0xf3]
+@ CHECK: vceq.f32      q8, q8, q9      @ encoding: [0xe2,0x0e,0x40,0xf2]
+
        vcge.s8 d16, d16, d17
-@ CHECK: vcge.s16      d16, d16, d17   @ encoding: [0xb1,0x03,0x50,0xf2]
        vcge.s16        d16, d16, d17
-@ CHECK: vcge.s32      d16, d16, d17   @ encoding: [0xb1,0x03,0x60,0xf2]
        vcge.s32        d16, d16, d17
-@ CHECK: vcge.u8       d16, d16, d17           @ encoding: [0xb1,0x03,0x40,0xf3]
        vcge.u8 d16, d16, d17
-@ CHECK: vcge.u16      d16, d16, d17   @ encoding: [0xb1,0x03,0x50,0xf3]
        vcge.u16        d16, d16, d17
-@ CHECK: vcge.u32      d16, d16, d17   @ encoding: [0xb1,0x03,0x60,0xf3]
        vcge.u32        d16, d16, d17
-@ CHECK: vcge.f32      d16, d16, d17   @ encoding: [0xa1,0x0e,0x40,0xf3]
        vcge.f32        d16, d16, d17
-@ CHECK: vcge.s8       q8, q8, q9              @ encoding: [0xf2,0x03,0x40,0xf2]
        vcge.s8 q8, q8, q9
-@ CHECK: vcge.s16      q8, q8, q9      @ encoding: [0xf2,0x03,0x50,0xf2]
        vcge.s16        q8, q8, q9
-@ CHECK: vcge.s32      q8, q8, q9      @ encoding: [0xf2,0x03,0x60,0xf2]
        vcge.s32        q8, q8, q9
-@ CHECK: vcge.u8       q8, q8, q9              @ encoding: [0xf2,0x03,0x40,0xf3]
        vcge.u8 q8, q8, q9
-@ CHECK: vcge.u16      q8, q8, q9      @ encoding: [0xf2,0x03,0x50,0xf3]
        vcge.u16        q8, q8, q9
-@ CHECK: vcge.u32      q8, q8, q9      @ encoding: [0xf2,0x03,0x60,0xf3]
        vcge.u32        q8, q8, q9
-@ CHECK: vcge.f32      q8, q8, q9      @ encoding: [0xe2,0x0e,0x40,0xf3]
        vcge.f32        q8, q8, q9
-@ CHECK: vacge.f32     d16, d16, d17   @ encoding: [0xb1,0x0e,0x40,0xf3]
        vacge.f32       d16, d16, d17
-@ CHECK: vacge.f32     q8, q8, q9      @ encoding: [0xf2,0x0e,0x40,0xf3]
        vacge.f32       q8, q8, q9
 
-@ CHECK: vcgt.s8       d16, d16, d17           @ encoding: [0xa1,0x03,0x40,0xf2]
+@ CHECK: vcge.s8       d16, d16, d17   @ encoding: [0xb1,0x03,0x40,0xf2]
+@ CHECK: vcge.s16      d16, d16, d17   @ encoding: [0xb1,0x03,0x50,0xf2]
+@ CHECK: vcge.s32      d16, d16, d17   @ encoding: [0xb1,0x03,0x60,0xf2]
+@ CHECK: vcge.u8       d16, d16, d17   @ encoding: [0xb1,0x03,0x40,0xf3]
+@ CHECK: vcge.u16      d16, d16, d17   @ encoding: [0xb1,0x03,0x50,0xf3]
+@ CHECK: vcge.u32      d16, d16, d17   @ encoding: [0xb1,0x03,0x60,0xf3]
+@ CHECK: vcge.f32      d16, d16, d17   @ encoding: [0xa1,0x0e,0x40,0xf3]
+@ CHECK: vcge.s8       q8, q8, q9      @ encoding: [0xf2,0x03,0x40,0xf2]
+@ CHECK: vcge.s16      q8, q8, q9      @ encoding: [0xf2,0x03,0x50,0xf2]
+@ CHECK: vcge.s32      q8, q8, q9      @ encoding: [0xf2,0x03,0x60,0xf2]
+@ CHECK: vcge.u8       q8, q8, q9      @ encoding: [0xf2,0x03,0x40,0xf3]
+@ CHECK: vcge.u16      q8, q8, q9      @ encoding: [0xf2,0x03,0x50,0xf3]
+@ CHECK: vcge.u32      q8, q8, q9      @ encoding: [0xf2,0x03,0x60,0xf3]
+@ CHECK: vcge.f32      q8, q8, q9      @ encoding: [0xe2,0x0e,0x40,0xf3]
+@ CHECK: vacge.f32     d16, d16, d17   @ encoding: [0xb1,0x0e,0x40,0xf3]
+@ CHECK: vacge.f32     q8, q8, q9      @ encoding: [0xf2,0x0e,0x40,0xf3]
+
        vcgt.s8 d16, d16, d17
-@ CHECK: vcgt.s16      d16, d16, d17   @ encoding: [0xa1,0x03,0x50,0xf2]
        vcgt.s16        d16, d16, d17
-@ CHECK: vcgt.s32      d16, d16, d17   @ encoding: [0xa1,0x03,0x60,0xf2]
        vcgt.s32        d16, d16, d17
-@ CHECK: vcgt.u8       d16, d16, d17           @ encoding: [0xa1,0x03,0x40,0xf3]
        vcgt.u8 d16, d16, d17
-@ CHECK: vcgt.u16      d16, d16, d17   @ encoding: [0xa1,0x03,0x50,0xf3]
        vcgt.u16        d16, d16, d17
-@ CHECK: vcgt.u32      d16, d16, d17   @ encoding: [0xa1,0x03,0x60,0xf3]
        vcgt.u32        d16, d16, d17
-@ CHECK: vcgt.f32      d16, d16, d17   @ encoding: [0xa1,0x0e,0x60,0xf3]
        vcgt.f32        d16, d16, d17
-@ CHECK: vcgt.s8       q8, q8, q9              @ encoding: [0xe2,0x03,0x40,0xf2]
        vcgt.s8 q8, q8, q9
-@ CHECK: vcgt.s16      q8, q8, q9      @ encoding: [0xe2,0x03,0x50,0xf2]
        vcgt.s16        q8, q8, q9
-@ CHECK: vcgt.s32      q8, q8, q9      @ encoding: [0xe2,0x03,0x60,0xf2]
        vcgt.s32        q8, q8, q9
-@ CHECK: vcgt.u8       q8, q8, q9              @ encoding: [0xe2,0x03,0x40,0xf3]
        vcgt.u8 q8, q8, q9
-@ CHECK: vcgt.u16      q8, q8, q9      @ encoding: [0xe2,0x03,0x50,0xf3]
        vcgt.u16        q8, q8, q9
-@ CHECK: vcgt.u32      q8, q8, q9      @ encoding: [0xe2,0x03,0x60,0xf3]
        vcgt.u32        q8, q8, q9
-@ CHECK: vcgt.f32      q8, q8, q9      @ encoding: [0xe2,0x0e,0x60,0xf3]
        vcgt.f32        q8, q8, q9
-@ CHECK: vacgt.f32     d16, d16, d17   @ encoding: [0xb1,0x0e,0x60,0xf3]
        vacgt.f32       d16, d16, d17
-@ CHECK: vacgt.f32     q8, q8, q9      @ encoding: [0xf2,0x0e,0x60,0xf3]
        vacgt.f32       q8, q8, q9
 
-@ CHECK: vtst.8        d16, d16, d17           @ encoding: [0xb1,0x08,0x40,0xf2]
+@ CHECK: vcgt.s8       d16, d16, d17   @ encoding: [0xa1,0x03,0x40,0xf2]
+@ CHECK: vcgt.s16      d16, d16, d17   @ encoding: [0xa1,0x03,0x50,0xf2]
+@ CHECK: vcgt.s32      d16, d16, d17   @ encoding: [0xa1,0x03,0x60,0xf2]
+@ CHECK: vcgt.u8       d16, d16, d17   @ encoding: [0xa1,0x03,0x40,0xf3]
+@ CHECK: vcgt.u16      d16, d16, d17   @ encoding: [0xa1,0x03,0x50,0xf3]
+@ CHECK: vcgt.u32      d16, d16, d17   @ encoding: [0xa1,0x03,0x60,0xf3]
+@ CHECK: vcgt.f32      d16, d16, d17   @ encoding: [0xa1,0x0e,0x60,0xf3]
+@ CHECK: vcgt.s8       q8, q8, q9      @ encoding: [0xe2,0x03,0x40,0xf2]
+@ CHECK: vcgt.s16      q8, q8, q9      @ encoding: [0xe2,0x03,0x50,0xf2]
+@ CHECK: vcgt.s32      q8, q8, q9      @ encoding: [0xe2,0x03,0x60,0xf2]
+@ CHECK: vcgt.u8       q8, q8, q9      @ encoding: [0xe2,0x03,0x40,0xf3]
+@ CHECK: vcgt.u16      q8, q8, q9      @ encoding: [0xe2,0x03,0x50,0xf3]
+@ CHECK: vcgt.u32      q8, q8, q9      @ encoding: [0xe2,0x03,0x60,0xf3]
+@ CHECK: vcgt.f32      q8, q8, q9      @ encoding: [0xe2,0x0e,0x60,0xf3]
+@ CHECK: vacgt.f32     d16, d16, d17   @ encoding: [0xb1,0x0e,0x60,0xf3]
+@ CHECK: vacgt.f32     q8, q8, q9      @ encoding: [0xf2,0x0e,0x60,0xf3]
+
        vtst.8  d16, d16, d17
-@ CHECK: vtst.16       d16, d16, d17           @ encoding: [0xb1,0x08,0x50,0xf2]
        vtst.16 d16, d16, d17
-@ CHECK: vtst.32       d16, d16, d17           @ encoding: [0xb1,0x08,0x60,0xf2]
        vtst.32 d16, d16, d17
-@ CHECK: vtst.8        q8, q8, q9              @ encoding: [0xf2,0x08,0x40,0xf2]
        vtst.8  q8, q8, q9
-@ CHECK: vtst.16       q8, q8, q9              @ encoding: [0xf2,0x08,0x50,0xf2]
        vtst.16 q8, q8, q9
-@ CHECK: vtst.32       q8, q8, q9              @ encoding: [0xf2,0x08,0x60,0xf2]
        vtst.32 q8, q8, q9
+
+@ CHECK: vtst.8        d16, d16, d17           @ encoding: [0xb1,0x08,0x40,0xf2]
+@ CHECK: vtst.16       d16, d16, d17   @ encoding: [0xb1,0x08,0x50,0xf2]
+@ CHECK: vtst.32       d16, d16, d17   @ encoding: [0xb1,0x08,0x60,0xf2]
+@ CHECK: vtst.8        q8, q8, q9              @ encoding: [0xf2,0x08,0x40,0xf2]
+@ CHECK: vtst.16       q8, q8, q9      @ encoding: [0xf2,0x08,0x50,0xf2]
+@ CHECK: vtst.32       q8, q8, q9      @ encoding: [0xf2,0x08,0x60,0xf2]
+
+       vceq.i8 d16, d16, #0
+       vcge.s8 d16, d16, #0
+       vcle.s8 d16, d16, #0
+       vcgt.s8 d16, d16, #0
+       vclt.s8 d16, d16, #0
+
+@ CHECK: vceq.i8       d16, d16, #0    @ encoding: [0x20,0x01,0xf1,0xf3]
+@ CHECK: vcge.s8       d16, d16, #0    @ encoding: [0xa0,0x00,0xf1,0xf3]
+@ CHECK: vcle.s8       d16, d16, #0    @ encoding: [0xa0,0x01,0xf1,0xf3]
+@ CHECK: vcgt.s8       d16, d16, #0    @ encoding: [0x20,0x00,0xf1,0xf3]
+@ CHECK: vclt.s8       d16, d16, #0    @ encoding: [0x20,0x02,0xf1,0xf3]
+
+
+        vclt.s8 q12, q13, q3
+        vclt.s16 q12, q13, q3
+        vclt.s32 q12, q13, q3
+        vclt.u8 q12, q13, q3
+        vclt.u16 q12, q13, q3
+        vclt.u32 q12, q13, q3
+        vclt.f32 q12, q13, q3
+
+        vclt.s8 d12, d13, d3
+        vclt.s16 d12, d13, d3
+        vclt.s32 d12, d13, d3
+        vclt.u8 d12, d13, d3
+        vclt.u16 d12, d13, d3
+        vclt.u32 d12, d13, d3
+        vclt.f32 d12, d13, d3
+
+@ CHECK: vcgt.s8       q12, q3, q13    @ encoding: [0x6a,0x83,0x46,0xf2]
+@ CHECK: vcgt.s16      q12, q3, q13    @ encoding: [0x6a,0x83,0x56,0xf2]
+@ CHECK: vcgt.s32      q12, q3, q13    @ encoding: [0x6a,0x83,0x66,0xf2]
+@ CHECK: vcgt.u8       q12, q3, q13    @ encoding: [0x6a,0x83,0x46,0xf3]
+@ CHECK: vcgt.u16      q12, q3, q13    @ encoding: [0x6a,0x83,0x56,0xf3]
+@ CHECK: vcgt.u32      q12, q3, q13    @ encoding: [0x6a,0x83,0x66,0xf3]
+@ CHECK: vcgt.f32      q12, q3, q13    @ encoding: [0x6a,0x8e,0x66,0xf3]
+
+@ CHECK: vcgt.s8       d12, d3, d13    @ encoding: [0x0d,0xc3,0x03,0xf2]
+@ CHECK: vcgt.s16      d12, d3, d13    @ encoding: [0x0d,0xc3,0x13,0xf2]
+@ CHECK: vcgt.s32      d12, d3, d13    @ encoding: [0x0d,0xc3,0x23,0xf2]
+@ CHECK: vcgt.u8       d12, d3, d13    @ encoding: [0x0d,0xc3,0x03,0xf3]
+@ CHECK: vcgt.u16      d12, d3, d13    @ encoding: [0x0d,0xc3,0x13,0xf3]
+@ CHECK: vcgt.u32      d12, d3, d13    @ encoding: [0x0d,0xc3,0x23,0xf3]
+@ CHECK: vcgt.f32      d12, d3, d13    @ encoding: [0x0d,0xce,0x23,0xf3]