1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 19:23:23 +01:00
llvm-mirror/test/MC/X86/F16C-64.s
Gadi Haber 98d9000b4b [X86][MC]: Adding test coverage of MC encoding for several small extensions.<NFC>
NFC.
 Adding MC regressions tests to cover several small x86 extensions as follows:
 CLWB, CLZERO, F16C, INVPCID, PKU, POPCNT, RTM, SGX, SHA, SVM, VMFUNC, VTX

This patch is part of a larger task to cover MC encoding of all X86 isa sets started in revision: https://reviews.llvm.org/D39952

Reviewers: RKSimon, craig.topper, zvi, AndreiGrischenko
Differential Revision: https://reviews.llvm.org/D41388

Change-Id: I254508cd17faca00b780be0fc2abf6c71b61faab
llvm-svn: 324595
2018-02-08 11:16:02 +00:00

115 lines
4.2 KiB
ArmAsm

// RUN: llvm-mc -triple i386-unknown-unknown --show-encoding %s | FileCheck %s
// CHECK: vcvtph2ps -485498096(%edx,%eax,4), %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0x8c,0x82,0x10,0xe3,0x0f,0xe3]
vcvtph2ps -485498096(%edx,%eax,4), %xmm1
// CHECK: vcvtph2ps 485498096(%edx,%eax,4), %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0x8c,0x82,0xf0,0x1c,0xf0,0x1c]
vcvtph2ps 485498096(%edx,%eax,4), %xmm1
// CHECK: vcvtph2ps -485498096(%edx,%eax,4), %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0xa4,0x82,0x10,0xe3,0x0f,0xe3]
vcvtph2ps -485498096(%edx,%eax,4), %ymm4
// CHECK: vcvtph2ps 485498096(%edx,%eax,4), %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0xa4,0x82,0xf0,0x1c,0xf0,0x1c]
vcvtph2ps 485498096(%edx,%eax,4), %ymm4
// CHECK: vcvtph2ps 485498096(%edx), %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0x8a,0xf0,0x1c,0xf0,0x1c]
vcvtph2ps 485498096(%edx), %xmm1
// CHECK: vcvtph2ps 485498096(%edx), %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0xa2,0xf0,0x1c,0xf0,0x1c]
vcvtph2ps 485498096(%edx), %ymm4
// CHECK: vcvtph2ps 485498096, %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0x0d,0xf0,0x1c,0xf0,0x1c]
vcvtph2ps 485498096, %xmm1
// CHECK: vcvtph2ps 485498096, %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0x25,0xf0,0x1c,0xf0,0x1c]
vcvtph2ps 485498096, %ymm4
// CHECK: vcvtph2ps 64(%edx,%eax), %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0x4c,0x02,0x40]
vcvtph2ps 64(%edx,%eax), %xmm1
// CHECK: vcvtph2ps 64(%edx,%eax), %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0x64,0x02,0x40]
vcvtph2ps 64(%edx,%eax), %ymm4
// CHECK: vcvtph2ps (%edx), %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0x0a]
vcvtph2ps (%edx), %xmm1
// CHECK: vcvtph2ps (%edx), %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0x22]
vcvtph2ps (%edx), %ymm4
// CHECK: vcvtph2ps %xmm1, %xmm1
// CHECK: encoding: [0xc4,0xe2,0x79,0x13,0xc9]
vcvtph2ps %xmm1, %xmm1
// CHECK: vcvtph2ps %xmm1, %ymm4
// CHECK: encoding: [0xc4,0xe2,0x7d,0x13,0xe1]
vcvtph2ps %xmm1, %ymm4
// CHECK: vcvtps2ph $0, %xmm1, -485498096(%edx,%eax,4)
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0x8c,0x82,0x10,0xe3,0x0f,0xe3,0x00]
vcvtps2ph $0, %xmm1, -485498096(%edx,%eax,4)
// CHECK: vcvtps2ph $0, %xmm1, 485498096(%edx,%eax,4)
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0x8c,0x82,0xf0,0x1c,0xf0,0x1c,0x00]
vcvtps2ph $0, %xmm1, 485498096(%edx,%eax,4)
// CHECK: vcvtps2ph $0, %xmm1, 485498096(%edx)
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0x8a,0xf0,0x1c,0xf0,0x1c,0x00]
vcvtps2ph $0, %xmm1, 485498096(%edx)
// CHECK: vcvtps2ph $0, %xmm1, 485498096
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0x0d,0xf0,0x1c,0xf0,0x1c,0x00]
vcvtps2ph $0, %xmm1, 485498096
// CHECK: vcvtps2ph $0, %xmm1, 64(%edx,%eax)
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0x4c,0x02,0x40,0x00]
vcvtps2ph $0, %xmm1, 64(%edx,%eax)
// CHECK: vcvtps2ph $0, %xmm1, (%edx)
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0x0a,0x00]
vcvtps2ph $0, %xmm1, (%edx)
// CHECK: vcvtps2ph $0, %xmm1, %xmm1
// CHECK: encoding: [0xc4,0xe3,0x79,0x1d,0xc9,0x00]
vcvtps2ph $0, %xmm1, %xmm1
// CHECK: vcvtps2ph $0, %ymm4, -485498096(%edx,%eax,4)
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0xa4,0x82,0x10,0xe3,0x0f,0xe3,0x00]
vcvtps2ph $0, %ymm4, -485498096(%edx,%eax,4)
// CHECK: vcvtps2ph $0, %ymm4, 485498096(%edx,%eax,4)
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0xa4,0x82,0xf0,0x1c,0xf0,0x1c,0x00]
vcvtps2ph $0, %ymm4, 485498096(%edx,%eax,4)
// CHECK: vcvtps2ph $0, %ymm4, 485498096(%edx)
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0xa2,0xf0,0x1c,0xf0,0x1c,0x00]
vcvtps2ph $0, %ymm4, 485498096(%edx)
// CHECK: vcvtps2ph $0, %ymm4, 485498096
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0x25,0xf0,0x1c,0xf0,0x1c,0x00]
vcvtps2ph $0, %ymm4, 485498096
// CHECK: vcvtps2ph $0, %ymm4, 64(%edx,%eax)
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0x64,0x02,0x40,0x00]
vcvtps2ph $0, %ymm4, 64(%edx,%eax)
// CHECK: vcvtps2ph $0, %ymm4, (%edx)
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0x22,0x00]
vcvtps2ph $0, %ymm4, (%edx)
// CHECK: vcvtps2ph $0, %ymm4, %xmm1
// CHECK: encoding: [0xc4,0xe3,0x7d,0x1d,0xe1,0x00]
vcvtps2ph $0, %ymm4, %xmm1