Zydis 5.0.0
Zyan Disassembler Library
Loading...
Searching...
No Matches
Decoder.h
Go to the documentation of this file.
1/***************************************************************************************************
2
3 Zyan Disassembler Library (Zydis)
4
5 Original Author : Florian Bernd
6
7 * Permission is hereby granted, free of charge, to any person obtaining a copy
8 * of this software and associated documentation files (the "Software"), to deal
9 * in the Software without restriction, including without limitation the rights
10 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11 * copies of the Software, and to permit persons to whom the Software is
12 * furnished to do so, subject to the following conditions:
13 *
14 * The above copyright notice and this permission notice shall be included in all
15 * copies or substantial portions of the Software.
16 *
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23 * SOFTWARE.
24
25***************************************************************************************************/
26
31
32#ifndef ZYDIS_DECODER_H
33#define ZYDIS_DECODER_H
34
35#include <Zycore/Types.h>
36#include <Zycore/Defines.h>
37#include <Zydis/DecoderTypes.h>
38#include <Zydis/Status.h>
39
40#ifdef __cplusplus
41extern "C" {
42#endif
43
44/* ============================================================================================== */
45/* Enums and types */
46/* ============================================================================================== */
47
48/* ---------------------------------------------------------------------------------------------- */
49/* Decoder mode */
50/* ---------------------------------------------------------------------------------------------- */
51
179
180/* ---------------------------------------------------------------------------------------------- */
181/* Decoder struct */
182/* ---------------------------------------------------------------------------------------------- */
183
205
206/* ---------------------------------------------------------------------------------------------- */
207
208/* ============================================================================================== */
209/* Exported functions */
210/* ============================================================================================== */
211
217
228 ZydisStackWidth stack_width);
229
240 ZyanBool enabled);
241
271 const void* buffer, ZyanUSize length, ZydisDecodedInstruction* instruction,
273
292 ZydisDecoderContext* context, const void* buffer, ZyanUSize length,
293 ZydisDecodedInstruction* instruction);
294
321ZYDIS_EXPORT ZyanStatus ZydisDecoderDecodeOperands(const ZydisDecoder* decoder,
322 const ZydisDecoderContext* context, const ZydisDecodedInstruction* instruction,
323 ZydisDecodedOperand* operands, ZyanU8 operand_count);
324
326
327/* ============================================================================================== */
328
329#ifdef __cplusplus
330}
331#endif
332
333#endif /* ZYDIS_DECODER_H */
Defines the basic ZydisDecodedInstruction and ZydisDecodedOperand structs.
struct ZydisDecoderContext_ ZydisDecoderContext
The decoder context is used to preserve some internal state between subsequent decode operations for ...
struct ZydisDecodedOperand_ ZydisDecodedOperand
Defines the ZydisDecodedOperand struct.
struct ZydisDecodedInstruction_ ZydisDecodedInstruction
Information about a decoded instruction.
struct ZydisDecoder_ ZydisDecoder
Defines the ZydisDecoder struct.
ZydisDecoderMode_
Defines the ZydisDecoderMode enum.
Definition Decoder.h:56
@ ZYDIS_DECODER_MODE_WBNOINVD
Enables the WBNOINVD mode.
Definition Decoder.h:135
@ ZYDIS_DECODER_MODE_KNC
Enables KNC compatibility-mode.
Definition Decoder.h:94
@ ZYDIS_DECODER_MODE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition Decoder.h:177
@ ZYDIS_DECODER_MODE_IPREFETCH
Enables the IPREFETCH mode.
Definition Decoder.h:151
@ ZYDIS_DECODER_MODE_APX
Enables the APX mode.
Definition Decoder.h:168
@ ZYDIS_DECODER_MODE_LZCNT
Enables the LZCNT mode.
Definition Decoder.h:118
@ ZYDIS_DECODER_MODE_MINIMAL
Enables minimal instruction decoding without semantic analysis.
Definition Decoder.h:69
@ ZYDIS_DECODER_MODE_TZCNT
Enables the TZCNT mode.
Definition Decoder.h:126
@ ZYDIS_DECODER_MODE_MAX_VALUE
Maximum value of this enum.
Definition Decoder.h:173
@ ZYDIS_DECODER_MODE_UD0_COMPAT
Enables the UD0 compatibility mode.
Definition Decoder.h:160
@ ZYDIS_DECODER_MODE_AMD_BRANCHES
Enables the AMD-branch mode.
Definition Decoder.h:80
@ ZYDIS_DECODER_MODE_MPX
Enables the MPX mode.
Definition Decoder.h:102
@ ZYDIS_DECODER_MODE_CLDEMOTE
Enables the CLDEMOTE mode.
Definition Decoder.h:143
@ ZYDIS_DECODER_MODE_CET
Enables the CET mode.
Definition Decoder.h:110
enum ZydisDecoderMode_ ZydisDecoderMode
Defines the ZydisDecoderMode enum.
#define ZYDIS_EXPORT
Symbol is exported in shared library builds.
Definition Defines.h:67
#define ZYDIS_MAX_OPERAND_COUNT
Definition SharedTypes.h:50
enum ZydisStackWidth_ ZydisStackWidth
Defines the ZydisStackWidth enum.
enum ZydisMachineMode_ ZydisMachineMode
Defines the ZydisMachineMode enum.
Status code definitions and check macros.
ZYDIS_EXPORT ZyanStatus ZydisDecoderDecodeFull(const ZydisDecoder *decoder, const void *buffer, ZyanUSize length, ZydisDecodedInstruction *instruction, ZydisDecodedOperand operands[ZYDIS_MAX_OPERAND_COUNT])
Decodes the instruction in the given input buffer and returns all details (e.g.
ZYDIS_EXPORT ZyanStatus ZydisDecoderDecodeInstruction(const ZydisDecoder *decoder, ZydisDecoderContext *context, const void *buffer, ZyanUSize length, ZydisDecodedInstruction *instruction)
Decodes the instruction in the given input buffer.
ZYDIS_EXPORT ZyanStatus ZydisDecoderInit(ZydisDecoder *decoder, ZydisMachineMode machine_mode, ZydisStackWidth stack_width)
Initializes the given ZydisDecoder instance.
ZYDIS_EXPORT ZyanStatus ZydisDecoderEnableMode(ZydisDecoder *decoder, ZydisDecoderMode mode, ZyanBool enabled)
Enables or disables the specified decoder-mode.
Defines the ZydisDecoder struct.
Definition Decoder.h:191
ZydisStackWidth stack_width
The stack width.
Definition Decoder.h:199
ZydisMachineMode machine_mode
The machine mode.
Definition Decoder.h:195
ZyanU32 decoder_mode
The decoder mode bitmap.
Definition Decoder.h:203