Files
system76-edk2/OvmfPkg/Include/IndustryStandard/InstructionParsing.h
Michael Kubacki ac0a286f4d OvmfPkg: Apply uncrustify changes
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737

Apply uncrustify changes to .c/.h files in the OvmfPkg package

Cc: Andrew Fish <afish@apple.com>
Cc: Leif Lindholm <leif@nuviainc.com>
Cc: Michael D Kinney <michael.d.kinney@intel.com>
Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com>
Reviewed-by: Andrew Fish <afish@apple.com>
2021-12-07 17:24:28 +00:00

84 lines
1.6 KiB
C

/** @file
Instruction parsing support definitions.
Copyright (C) 2020, Advanced Micro Devices, Inc. All rights reserved.<BR>
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#ifndef __INSTRUCTION_PARSING_H__
#define __INSTRUCTION_PARSING_H__
#include <Base.h>
#include <Uefi.h>
//
// Instruction REX prefix definition
//
typedef union {
struct {
UINT8 BitB : 1;
UINT8 BitX : 1;
UINT8 BitR : 1;
UINT8 BitW : 1;
UINT8 Rex : 4;
} Bits;
UINT8 Uint8;
} INSTRUCTION_REX_PREFIX;
//
// Instruction ModRM definition
//
typedef union {
struct {
UINT8 Rm : 3;
UINT8 Reg : 3;
UINT8 Mod : 2;
} Bits;
UINT8 Uint8;
} INSTRUCTION_MODRM;
//
// Instruction SIB definition
//
typedef union {
struct {
UINT8 Base : 3;
UINT8 Index : 3;
UINT8 Scale : 2;
} Bits;
UINT8 Uint8;
} INSTRUCTION_SIB;
//
// Legacy Instruction Prefixes
//
#define OVERRIDE_SEGMENT_CS 0x2E
#define OVERRIDE_SEGMENT_DS 0x3E
#define OVERRIDE_SEGMENT_ES 0x26
#define OVERRIDE_SEGMENT_SS 0x36
#define OVERRIDE_SEGMENT_FS 0x64
#define OVERRIDE_SEGMENT_GS 0x65
#define OVERRIDE_OPERAND_SIZE 0x66
#define OVERRIDE_ADDRESS_SIZE 0x67
#define LOCK_PREFIX 0xF0
#define REPNZ_PREFIX 0xF2
#define REPZ_PREFIX 0xF3
//
// REX Prefixes
//
#define REX_PREFIX_START 0x40
#define REX_PREFIX_STOP 0x4F
#define REX_64BIT_OPERAND_SIZE_MASK 0x08
//
// Two-byte Opcode Flag
//
#define TWO_BYTE_OPCODE_ESCAPE 0x0F
#endif