mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
cbcd7a559a
These instructions read their inputs from fixed registers rather than using a modrm byte. We shouldn't require the user to list them when parsing assembly. This matches the GNU assembler. This patch adds InstAliases so we can accept either form. It also changes the printing code to use the form without registers. This will change the behavior of llvm-objdump, but should be consistent with binutils objdump. This also matches what we already do in LLVM for clzero and monitorx which also used fixed registers. I need to add and improve tests before this can be commited. The disassembler tests exist, but weren't checking the fixed register so they pass before and after this change. Fixes https://github.com/ClangBuiltLinux/linux/issues/1216 Differential Revision: https://reviews.llvm.org/D93524
73 lines
2.7 KiB
TableGen
73 lines
2.7 KiB
TableGen
//===-- X86InstrSVM.td - SVM Instruction Set Extension -----*- tablegen -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file describes the instructions that make up the AMD SVM instruction
|
|
// set.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// SVM instructions
|
|
|
|
let SchedRW = [WriteSystem] in {
|
|
// 0F 01 D9
|
|
def VMMCALL : I<0x01, MRM_D9, (outs), (ins), "vmmcall", []>, TB;
|
|
|
|
// 0F 01 DC
|
|
def STGI : I<0x01, MRM_DC, (outs), (ins), "stgi", []>, TB;
|
|
|
|
// 0F 01 DD
|
|
def CLGI : I<0x01, MRM_DD, (outs), (ins), "clgi", []>, TB;
|
|
|
|
// 0F 01 DE
|
|
let Uses = [EAX] in
|
|
def SKINIT : I<0x01, MRM_DE, (outs), (ins), "skinit", []>, TB;
|
|
|
|
// 0F 01 D8
|
|
let Uses = [EAX] in
|
|
def VMRUN32 : I<0x01, MRM_D8, (outs), (ins), "vmrun", []>, TB,
|
|
Requires<[Not64BitMode]>;
|
|
let Uses = [RAX] in
|
|
def VMRUN64 : I<0x01, MRM_D8, (outs), (ins), "vmrun", []>, TB,
|
|
Requires<[In64BitMode]>;
|
|
|
|
// 0F 01 DA
|
|
let Uses = [EAX] in
|
|
def VMLOAD32 : I<0x01, MRM_DA, (outs), (ins), "vmload", []>, TB,
|
|
Requires<[Not64BitMode]>;
|
|
let Uses = [RAX] in
|
|
def VMLOAD64 : I<0x01, MRM_DA, (outs), (ins), "vmload", []>, TB,
|
|
Requires<[In64BitMode]>;
|
|
|
|
// 0F 01 DB
|
|
let Uses = [EAX] in
|
|
def VMSAVE32 : I<0x01, MRM_DB, (outs), (ins), "vmsave", []>, TB,
|
|
Requires<[Not64BitMode]>;
|
|
let Uses = [RAX] in
|
|
def VMSAVE64 : I<0x01, MRM_DB, (outs), (ins), "vmsave", []>, TB,
|
|
Requires<[In64BitMode]>;
|
|
|
|
// 0F 01 DF
|
|
let Uses = [EAX, ECX] in
|
|
def INVLPGA32 : I<0x01, MRM_DF, (outs), (ins),
|
|
"invlpga", []>, TB, Requires<[Not64BitMode]>;
|
|
let Uses = [RAX, ECX] in
|
|
def INVLPGA64 : I<0x01, MRM_DF, (outs), (ins),
|
|
"invlpga", []>, TB, Requires<[In64BitMode]>;
|
|
} // SchedRW
|
|
|
|
def : InstAlias<"skinit\t{%eax|eax}", (SKINIT), 0>;
|
|
def : InstAlias<"vmrun\t{%eax|eax}", (VMRUN32), 0>, Requires<[Not64BitMode]>;
|
|
def : InstAlias<"vmrun\t{%rax|rax}", (VMRUN64), 0>, Requires<[In64BitMode]>;
|
|
def : InstAlias<"vmload\t{%eax|eax}", (VMLOAD32), 0>, Requires<[Not64BitMode]>;
|
|
def : InstAlias<"vmload\t{%rax|rax}", (VMLOAD64), 0>, Requires<[In64BitMode]>;
|
|
def : InstAlias<"vmsave\t{%eax|eax}", (VMSAVE32), 0>, Requires<[Not64BitMode]>;
|
|
def : InstAlias<"vmsave\t{%rax|rax}", (VMSAVE64), 0>, Requires<[In64BitMode]>;
|
|
def : InstAlias<"invlpga\t{%eax, %ecx|eax, ecx}", (INVLPGA32), 0>, Requires<[Not64BitMode]>;
|
|
def : InstAlias<"invlpga\t{%rax, %ecx|rax, ecx}", (INVLPGA64), 0>, Requires<[In64BitMode]>;
|