Zydis  v4.0.0-rc.1
SharedData.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 
27 #ifndef ZYDIS_INTERNAL_SHAREDDATA_H
28 #define ZYDIS_INTERNAL_SHAREDDATA_H
29 
30 #include <Zycore/Defines.h>
31 #include <Zydis/Mnemonic.h>
32 #include <Zydis/Register.h>
33 #include <Zydis/SharedTypes.h>
34 #include <Zydis/DecoderTypes.h>
35 
36 #ifdef __cplusplus
37 extern "C" {
38 #endif
39 
40 /* ============================================================================================== */
41 /* Enums and types */
42 /* ============================================================================================== */
43 
44 // MSVC does not like types other than (un-)signed int for bit-fields
45 #ifdef ZYAN_MSVC
46 # pragma warning(push)
47 # pragma warning(disable:4214)
48 #endif
49 
50 #pragma pack(push, 1)
51 
52 /* ---------------------------------------------------------------------------------------------- */
53 /* Operand definition */
54 /* ---------------------------------------------------------------------------------------------- */
55 
60 {
94 
104 
105 /* ---------------------------------------------------------------------------------------------- */
106 
111 {
136 
146 
147 /* ---------------------------------------------------------------------------------------------- */
148 
153 {
154  // TODO: Rename OSZ|ASZ|SSZ_
162 
172 
173 /* ---------------------------------------------------------------------------------------------- */
174 
179 {
180  // TODO: Rename OSZ|ASZ|SSZ_
190 
200 
201 /* ---------------------------------------------------------------------------------------------- */
202 
203 // MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
204 // enum types
213 
218 {
222  ZyanU16 size[3];
224  union
225  {
227  struct
228  {
230  union
231  {
233  ZyanU8 id ZYAN_BITFIELD(6);
234  } reg;
235  } reg;
236  struct
237  {
238  ZyanU8 seg ZYAN_BITFIELD(3);
240  } mem;
241  } op;
242  ZyanBool is_multisource4 ZYAN_BITFIELD(1);
243  ZyanBool ignore_seg_override ZYAN_BITFIELD(1);
245 
246 /* ---------------------------------------------------------------------------------------------- */
247 /* Instruction definition */
248 /* ---------------------------------------------------------------------------------------------- */
249 
254 {
259 
269 
270 /* ---------------------------------------------------------------------------------------------- */
271 
276 {
281 
291 
292 /* ---------------------------------------------------------------------------------------------- */
293 
298 {
305 
315 
316 /* ---------------------------------------------------------------------------------------------- */
317 
322 {
336 
346 
347 /* ---------------------------------------------------------------------------------------------- */
348 
353 {
419 
429 
430 /* ---------------------------------------------------------------------------------------------- */
431 
436 {
541 
551 
552 /* ---------------------------------------------------------------------------------------------- */
553 
558 {
566 
575  ZYAN_BITS_TO_REPRESENT(ZYDIS_VEX_STATIC_BROADCAST_MAX_VALUE)
577 
578 /* ---------------------------------------------------------------------------------------------- */
579 
584 {
598 
607  ZYAN_BITS_TO_REPRESENT(ZYDIS_EVEX_STATIC_BROADCAST_MAX_VALUE)
609 
610 /* ---------------------------------------------------------------------------------------------- */
611 
616 {
622 
631  ZYAN_BITS_TO_REPRESENT(ZYDIS_MVEX_STATIC_BROADCAST_MAX_VALUE)
633 
634 /* ---------------------------------------------------------------------------------------------- */
635 
639 typedef enum ZydisMaskPolicy_
640 {
655 
665 
666 /* ---------------------------------------------------------------------------------------------- */
667 
671 typedef enum ZydisMaskOverride_
672 {
676 
686 
687 /* ---------------------------------------------------------------------------------------------- */
688 
689 #define ZYDIS_OPDEF_REQUIRED_BITS \
690  ZYAN_MAX(ZYDIS_REGKIND_REQUIRED_BITS, ZYDIS_MEMOP_TYPE_REQUIRED_BITS + 1) + 1
691 
692 #define ZYDIS_OPDEF_GET_REG(operand_definition) \
693  ((operand_definition) & ((1 << ZYDIS_REGKIND_REQUIRED_BITS ) - 1))
694 
695 #define ZYDIS_OPDEF_GET_MEM(operand_definition) \
696  ((operand_definition) & ((1 << ZYDIS_MEMOP_TYPE_REQUIRED_BITS) - 1))
697 
698 #define ZYDIS_OPDEF_GET_REG_HIGH_BIT(operand_definition) \
699  (((operand_definition) >> ZYDIS_REGKIND_REQUIRED_BITS ) & 0x01)
700 
701 #define ZYDIS_OPDEF_GET_MEM_HIGH_BIT(operand_definition) \
702  (((operand_definition) >> ZYDIS_MEMOP_TYPE_REQUIRED_BITS) & 0x01)
703 
704 // MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
705 // enum types
714 
715 #ifndef ZYDIS_MINIMAL_MODE
716 # define ZYDIS_INSTRUCTION_DEFINITION_BASE \
717  ZyanU16 mnemonic ZYAN_BITFIELD(ZYDIS_MNEMONIC_REQUIRED_BITS); \
718  ZyanU8 operand_count ZYAN_BITFIELD( 4); \
719  ZyanU8 operand_count_visible ZYAN_BITFIELD( 3); \
720  ZyanU16 operand_reference ZYAN_BITFIELD(15); \
721  ZyanU8 operand_size_map ZYAN_BITFIELD( 3); \
722  ZyanU8 address_size_map ZYAN_BITFIELD( 2); \
723  ZyanU8 flags_reference ZYAN_BITFIELD( 7); \
724  ZyanBool requires_protected_mode ZYAN_BITFIELD( 1); \
725  ZyanBool no_compat_mode ZYAN_BITFIELD( 1); \
726  ZyanU8 category ZYAN_BITFIELD(ZYDIS_CATEGORY_REQUIRED_BITS); \
727  ZyanU8 isa_set ZYAN_BITFIELD(ZYDIS_ISA_SET_REQUIRED_BITS); \
728  ZyanU8 isa_ext ZYAN_BITFIELD(ZYDIS_ISA_EXT_REQUIRED_BITS); \
729  ZyanU8 branch_type ZYAN_BITFIELD(ZYDIS_BRANCH_TYPE_REQUIRED_BITS); \
730  ZyanU8 exception_class ZYAN_BITFIELD(ZYDIS_EXCEPTION_CLASS_REQUIRED_BITS); \
731  ZyanU8 op_reg ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS); \
732  ZyanU8 op_rm ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS); \
733  ZyanU8 cpu_state ZYAN_BITFIELD(ZYDIS_RW_ACTION_REQUIRED_BITS); \
734  ZyanU8 fpu_state ZYAN_BITFIELD(ZYDIS_RW_ACTION_REQUIRED_BITS); \
735  ZyanU8 xmm_state ZYAN_BITFIELD(ZYDIS_RW_ACTION_REQUIRED_BITS); \
736  ZyanBool accepts_segment ZYAN_BITFIELD( 1)
737 #else
738 # define ZYDIS_INSTRUCTION_DEFINITION_BASE \
739  ZyanU16 mnemonic ZYAN_BITFIELD(ZYDIS_MNEMONIC_REQUIRED_BITS); \
740  ZyanU8 operand_size_map ZYAN_BITFIELD( 3); \
741  ZyanU8 address_size_map ZYAN_BITFIELD( 2); \
742  ZyanBool requires_protected_mode ZYAN_BITFIELD( 1); \
743  ZyanBool no_compat_mode ZYAN_BITFIELD( 1); \
744  ZyanU8 op_reg ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS); \
745  ZyanU8 op_rm ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS)
746 #endif
747 
748 #define ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR \
749  ZYDIS_INSTRUCTION_DEFINITION_BASE; \
750  ZyanU8 op_ndsndd ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS)
751 
752 #define ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL \
753  ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR; \
754  ZyanBool is_gather ZYAN_BITFIELD( 1); \
755  ZyanBool no_source_dest_match ZYAN_BITFIELD( 1); \
756  ZyanBool no_source_source_match ZYAN_BITFIELD( 1) // TODO: Could be moved to VEX
757 
762 {
765 
770 {
772 #ifndef ZYDIS_MINIMAL_MODE
773  ZyanBool is_privileged ZYAN_BITFIELD( 1);
774 #endif
775  ZyanBool accepts_LOCK ZYAN_BITFIELD( 1);
776 #ifndef ZYDIS_MINIMAL_MODE
777  ZyanBool accepts_REP ZYAN_BITFIELD( 1);
778  ZyanBool accepts_REPEREPZ ZYAN_BITFIELD( 1);
779  ZyanBool accepts_REPNEREPNZ ZYAN_BITFIELD( 1);
780  ZyanBool accepts_BOUND ZYAN_BITFIELD( 1);
781  ZyanBool accepts_XACQUIRE ZYAN_BITFIELD( 1);
782  ZyanBool accepts_XRELEASE ZYAN_BITFIELD( 1);
783  ZyanBool accepts_NOTRACK ZYAN_BITFIELD( 1);
784  ZyanBool accepts_hle_without_lock ZYAN_BITFIELD( 1);
785  ZyanBool accepts_branch_hints ZYAN_BITFIELD( 1);
786 #endif
788 
793 {
796 
801 {
804 
805 // MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
806 // enum types
808 
813 {
815 #ifndef ZYDIS_MINIMAL_MODE
817 #endif
819 
820 #ifndef ZYDIS_DISABLE_AVX512
821 
822 // MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
823 // enum types
831 
836 {
838 #ifndef ZYDIS_MINIMAL_MODE
843 #endif
845  ZyanBool accepts_zero_mask ZYAN_BITFIELD( 1);
846 #ifndef ZYDIS_MINIMAL_MODE
849 #endif
851 #endif
852 
853 #ifndef ZYDIS_DISABLE_KNC
854 
855 // MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
856 // enum types
860 
865 {
869 #ifndef ZYDIS_MINIMAL_MODE
870  ZyanBool has_element_granularity ZYAN_BITFIELD( 1);
872 #endif
874 #endif
875 
876 /* ---------------------------------------------------------------------------------------------- */
877 
878 #pragma pack(pop)
879 
880 #ifdef ZYAN_MSVC
881 # pragma warning(pop)
882 #endif
883 
884 /* ---------------------------------------------------------------------------------------------- */
885 /* Accessed CPU/FPU flags */
886 /* ---------------------------------------------------------------------------------------------- */
887 
888 /*
889  * Contains information about the CPU/FPU flags accessed by an instruction.
890  *
891  * We don't want this struct to be packed! A pointer to the individual members will be used by the
892  * `ZydisDecodedInstruction` struct.
893  */
895 {
899 
900 /* ---------------------------------------------------------------------------------------------- */
901 
902 /* ============================================================================================== */
903 /* Functions */
904 /* ============================================================================================== */
905 
906 /* ---------------------------------------------------------------------------------------------- */
907 /* Instruction definition */
908 /* ---------------------------------------------------------------------------------------------- */
909 
919  ZyanU16 id, const ZydisInstructionDefinition** definition);
920 
921 /* ---------------------------------------------------------------------------------------------- */
922 /* Operand definition */
923 /* ---------------------------------------------------------------------------------------------- */
924 
925 #ifndef ZYDIS_MINIMAL_MODE
934  const ZydisInstructionDefinition* definition);
935 #endif
936 
937 /* ---------------------------------------------------------------------------------------------- */
938 /* Element info */
939 /* ---------------------------------------------------------------------------------------------- */
940 
941 #ifndef ZYDIS_MINIMAL_MODE
950  ZydisElementSize* size);
951 #endif
952 
953 /* ---------------------------------------------------------------------------------------------- */
954 /* Accessed CPU flags */
955 /* ---------------------------------------------------------------------------------------------- */
956 
957 #ifndef ZYDIS_MINIMAL_MODE
968  const ZydisDefinitionAccessedFlags** flags);
969 #endif
970 
971 /* ---------------------------------------------------------------------------------------------- */
972 
973 /* ============================================================================================== */
974 
975 #ifdef __cplusplus
976 }
977 #endif
978 
979 #endif /* ZYDIS_INTERNAL_SHAREDDATA_H */
Defines the basic ZydisDecodedInstruction and ZydisDecodedOperand structs.
@ ZYDIS_EXCEPTION_CLASS_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: DecoderTypes.h:509
@ ZYDIS_BRANCH_TYPE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: DecoderTypes.h:442
#define ZYDIS_NO_EXPORT
Symbol is not exported and for internal use only.
Definition: Defines.h:74
@ ZYDIS_ISA_EXT_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: EnumISAExt.h:103
@ ZYDIS_ISA_SET_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: EnumISASet.h:195
@ ZYDIS_CATEGORY_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: EnumInstructionCategory.h:123
@ ZYDIS_MNEMONIC_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: EnumMnemonic.h:1769
@ ZYDIS_REGISTER_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: EnumRegister.h:320
Mnemonic constant definitions and helper functions.
Utility functions and constants for registers.
enum ZydisSemanticOperandType_ ZydisSemanticOperandType
Defines the ZydisSemanticOperandType enum.
enum ZydisEVEXStaticBroadcast_ ZydisEVEXStaticBroadcast
Defines the ZydisEVEXStaticBroadcast enum.
struct ZydisInstructionDefinition_ ZydisInstructionDefinition
Defines the ZydisInstructionDefinition struct.
ZydisEVEXTupleType_
Defines the ZydisEVEXTupleType enum.
Definition: SharedData.h:353
@ ZYDIS_TUPLETYPE_M128
Mem128.
Definition: SharedData.h:410
@ ZYDIS_TUPLETYPE_GSCAT
Gather / Scatter.
Definition: SharedData.h:382
@ ZYDIS_TUPLETYPE_T1F
Tuple1 Fixed.
Definition: SharedData.h:374
@ ZYDIS_TUPLETYPE_T8
Tuple8.
Definition: SharedData.h:394
@ ZYDIS_TUPLETYPE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:423
@ ZYDIS_TUPLETYPE_QUARTER
Quarter of the vector-length.
Definition: SharedData.h:418
@ ZYDIS_TUPLETYPE_T4
Tuple4.
Definition: SharedData.h:390
@ ZYDIS_TUPLETYPE_T1S
Tuple1 Scalar.
Definition: SharedData.h:370
@ ZYDIS_TUPLETYPE_FV
Full Vector.
Definition: SharedData.h:358
@ ZYDIS_TUPLETYPE_OVM
OctMem.
Definition: SharedData.h:406
@ ZYDIS_TUPLETYPE_FVM
Full Vector Mem.
Definition: SharedData.h:366
@ ZYDIS_TUPLETYPE_QVM
QuarterMem.
Definition: SharedData.h:402
@ ZYDIS_TUPLETYPE_HV
Half Vector.
Definition: SharedData.h:362
@ ZYDIS_TUPLETYPE_DUP
MOVDDUP.
Definition: SharedData.h:414
@ ZYDIS_TUPLETYPE_INVALID
Definition: SharedData.h:354
@ ZYDIS_TUPLETYPE_HVM
Half Mem.
Definition: SharedData.h:398
@ ZYDIS_TUPLETYPE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:427
@ ZYDIS_TUPLETYPE_T1_4X
Tuple1 4x32.
Definition: SharedData.h:378
@ ZYDIS_TUPLETYPE_T2
Tuple2.
Definition: SharedData.h:386
enum ZydisMVEXFunctionality_ ZydisMVEXFunctionality
Defines the ZydisMVEXFunctionality enum.
ZydisMVEXFunctionality_
Defines the ZydisMVEXFunctionality enum.
Definition: SharedData.h:436
@ ZYDIS_MVEX_FUNC_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:545
@ ZYDIS_MVEX_FUNC_F_32
No special operation (32bit float elements).
Definition: SharedData.h:456
@ ZYDIS_MVEX_FUNC_SF_64
Sf64(mem).
Definition: SharedData.h:492
@ ZYDIS_MVEX_FUNC_DI_32
Di32.
Definition: SharedData.h:536
@ ZYDIS_MVEX_FUNC_SI_32_BCST_4TO16
Si32(mem) broadcast 4to16 only.
Definition: SharedData.h:504
@ ZYDIS_MVEX_FUNC_SF_32_BCST
Sf32(mem) broadcast only.
Definition: SharedData.h:484
@ ZYDIS_MVEX_FUNC_DF_64
Df64.
Definition: SharedData.h:532
@ ZYDIS_MVEX_FUNC_F_64
No special operation (64bit float elements).
Definition: SharedData.h:464
@ ZYDIS_MVEX_FUNC_SI_32_BCST
Si32(mem) broadcast only.
Definition: SharedData.h:500
@ ZYDIS_MVEX_FUNC_INVALID
MVEX.SSS must be 000b.
Definition: SharedData.h:444
@ ZYDIS_MVEX_FUNC_I_64
No special operation (64bit uint elements).
Definition: SharedData.h:468
@ ZYDIS_MVEX_FUNC_SI_32
Si32(mem).
Definition: SharedData.h:496
@ ZYDIS_MVEX_FUNC_SWIZZLE_64
Sf64(reg) or Si64(reg).
Definition: SharedData.h:476
@ ZYDIS_MVEX_FUNC_SI_64
Si64(mem).
Definition: SharedData.h:508
@ ZYDIS_MVEX_FUNC_I_32
No special operation (32bit uint elements).
Definition: SharedData.h:460
@ ZYDIS_MVEX_FUNC_SF_32
Sf32(mem).
Definition: SharedData.h:480
@ ZYDIS_MVEX_FUNC_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:549
@ ZYDIS_MVEX_FUNC_SAE
MVEX.SSS controls sae functionality.
Definition: SharedData.h:452
@ ZYDIS_MVEX_FUNC_SWIZZLE_32
Sf32(reg) or Si32(reg).
Definition: SharedData.h:472
@ ZYDIS_MVEX_FUNC_UI_64
Ui64.
Definition: SharedData.h:524
@ ZYDIS_MVEX_FUNC_SF_32_BCST_4TO16
Sf32(mem) broadcast 4to16 only.
Definition: SharedData.h:488
@ ZYDIS_MVEX_FUNC_DI_64
Di64.
Definition: SharedData.h:540
@ ZYDIS_MVEX_FUNC_DF_32
Df32.
Definition: SharedData.h:528
@ ZYDIS_MVEX_FUNC_UI_32
Ui32.
Definition: SharedData.h:520
@ ZYDIS_MVEX_FUNC_IGNORED
The MVEX.SSS value is ignored.
Definition: SharedData.h:440
@ ZYDIS_MVEX_FUNC_UF_32
Uf32.
Definition: SharedData.h:512
@ ZYDIS_MVEX_FUNC_UF_64
Uf64.
Definition: SharedData.h:516
@ ZYDIS_MVEX_FUNC_RC
MVEX.SSS controls embedded-rounding functionality.
Definition: SharedData.h:448
enum ZydisImplicitMemBase_ ZydisImplicitMemBase
Defines the ZydisImplicitMemBase enum.
ZydisEVEXFunctionality_
Defines the ZydisEVEXFunctionality enum.
Definition: SharedData.h:322
@ ZYDIS_EVEX_FUNC_INVALID
Definition: SharedData.h:323
@ ZYDIS_EVEX_FUNC_SAE
EVEX.b enables sae functionality.
Definition: SharedData.h:335
@ ZYDIS_EVEX_FUNC_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:340
@ ZYDIS_EVEX_FUNC_BC
EVEX.b enables broadcast functionality.
Definition: SharedData.h:327
@ ZYDIS_EVEX_FUNC_RC
EVEX.b enables embedded-rounding functionality.
Definition: SharedData.h:331
@ ZYDIS_EVEX_FUNC_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:344
enum ZydisEVEXFunctionality_ ZydisEVEXFunctionality
Defines the ZydisEVEXFunctionality enum.
#define ZYDIS_OPDEF_REQUIRED_BITS
Definition: SharedData.h:689
ZYDIS_NO_EXPORT ZyanBool ZydisGetAccessedFlags(const ZydisInstructionDefinition *definition, const ZydisDefinitionAccessedFlags **flags)
Returns the the operand-definitions for the given instruction-definition.
enum ZydisImplicitRegisterType_ ZydisImplicitRegisterType
Defines the ZydisImplicitRegisterType enum.
ZydisImplicitRegisterType_
Defines the ZydisImplicitRegisterType enum.
Definition: SharedData.h:153
@ ZYDIS_IMPLREG_TYPE_IP_ASZ
Definition: SharedData.h:158
@ ZYDIS_IMPLREG_TYPE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:170
@ ZYDIS_IMPLREG_TYPE_GPR_ASZ
Definition: SharedData.h:157
@ ZYDIS_IMPLREG_TYPE_STATIC
Definition: SharedData.h:155
@ ZYDIS_IMPLREG_TYPE_GPR_OSZ
Definition: SharedData.h:156
@ ZYDIS_IMPLREG_TYPE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:166
@ ZYDIS_IMPLREG_TYPE_IP_SSZ
Definition: SharedData.h:159
@ ZYDIS_IMPLREG_TYPE_FLAGS_SSZ
Definition: SharedData.h:161
@ ZYDIS_IMPLREG_TYPE_GPR_SSZ
Definition: SharedData.h:160
ZydisInternalElementType_
Defines the ZydisInternalElementType enum.
Definition: SharedData.h:111
@ ZYDIS_IELEMENT_TYPE_FLOAT16X2
Definition: SharedData.h:129
@ ZYDIS_IELEMENT_TYPE_STRUCT
Definition: SharedData.h:114
@ ZYDIS_IELEMENT_TYPE_FLOAT64
Definition: SharedData.h:131
@ ZYDIS_IELEMENT_TYPE_INT
Definition: SharedData.h:115
@ ZYDIS_IELEMENT_TYPE_FLOAT16
Definition: SharedData.h:128
@ ZYDIS_IELEMENT_TYPE_UINT32
Definition: SharedData.h:124
@ ZYDIS_IELEMENT_TYPE_UINT8
Definition: SharedData.h:122
@ ZYDIS_IELEMENT_TYPE_FLOAT80
Definition: SharedData.h:132
@ ZYDIS_IELEMENT_TYPE_UINT16
Definition: SharedData.h:123
@ ZYDIS_IELEMENT_TYPE_VARIABLE
Definition: SharedData.h:113
@ ZYDIS_IELEMENT_TYPE_UINT64
Definition: SharedData.h:125
@ ZYDIS_IELEMENT_TYPE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:144
@ ZYDIS_IELEMENT_TYPE_UINT256
Definition: SharedData.h:127
@ ZYDIS_IELEMENT_TYPE_INT16
Definition: SharedData.h:119
@ ZYDIS_IELEMENT_TYPE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:140
@ ZYDIS_IELEMENT_TYPE_INT8
Definition: SharedData.h:118
@ ZYDIS_IELEMENT_TYPE_BCD80
Definition: SharedData.h:133
@ ZYDIS_IELEMENT_TYPE_INT32
Definition: SharedData.h:120
@ ZYDIS_IELEMENT_TYPE_UINT
Definition: SharedData.h:116
@ ZYDIS_IELEMENT_TYPE_CC5
Definition: SharedData.h:135
@ ZYDIS_IELEMENT_TYPE_INT1
Definition: SharedData.h:117
@ ZYDIS_IELEMENT_TYPE_FLOAT32
Definition: SharedData.h:130
@ ZYDIS_IELEMENT_TYPE_INT64
Definition: SharedData.h:121
@ ZYDIS_IELEMENT_TYPE_INVALID
Definition: SharedData.h:112
@ ZYDIS_IELEMENT_TYPE_UINT128
Definition: SharedData.h:126
@ ZYDIS_IELEMENT_TYPE_CC3
Definition: SharedData.h:134
enum ZydisMaskOverride_ ZydisMaskOverride
Defines the ZydisMaskOverride enum.
struct ZydisInstructionDefinitionVEX_ ZydisInstructionDefinitionVEX
Defines the ZydisInstructionDefinitionVEX struct.
enum ZydisReadWriteAction_ ZydisReadWriteAction
Defines the ZydisReadWriteAction enum.
ZydisInternalElementSize_
Defines the ZydisInternalElementSize enum.
Definition: SharedData.h:298
@ ZYDIS_IELEMENT_SIZE_INVALID
Definition: SharedData.h:299
@ ZYDIS_IELEMENT_SIZE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:309
@ ZYDIS_IELEMENT_SIZE_128
Definition: SharedData.h:304
@ ZYDIS_IELEMENT_SIZE_32
Definition: SharedData.h:302
@ ZYDIS_IELEMENT_SIZE_16
Definition: SharedData.h:301
@ ZYDIS_IELEMENT_SIZE_64
Definition: SharedData.h:303
@ ZYDIS_IELEMENT_SIZE_8
Definition: SharedData.h:300
@ ZYDIS_IELEMENT_SIZE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:313
ZydisVEXStaticBroadcast
Defines the ZydisVEXStaticBroadcast enum.
Definition: SharedData.h:558
@ ZYDIS_VEX_STATIC_BROADCAST_1_TO_4
Definition: SharedData.h:561
@ ZYDIS_VEX_STATIC_BROADCAST_1_TO_8
Definition: SharedData.h:562
@ ZYDIS_VEX_STATIC_BROADCAST_1_TO_2
Definition: SharedData.h:560
@ ZYDIS_VEX_STATIC_BROADCAST_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:574
@ ZYDIS_VEX_STATIC_BROADCAST_1_TO_32
Definition: SharedData.h:564
@ ZYDIS_VEX_STATIC_BROADCAST_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:570
@ ZYDIS_VEX_STATIC_BROADCAST_1_TO_16
Definition: SharedData.h:563
@ ZYDIS_VEX_STATIC_BROADCAST_2_TO_4
Definition: SharedData.h:565
@ ZYDIS_VEX_STATIC_BROADCAST_NONE
Definition: SharedData.h:559
struct ZydisDefinitionAccessedFlags_ ZydisDefinitionAccessedFlags
struct ZydisInstructionDefinition3DNOW_ ZydisInstructionDefinition3DNOW
Defines the ZydisInstructionDefinition3DNOW struct.
ZYDIS_NO_EXPORT void ZydisGetInstructionDefinition(ZydisInstructionEncoding encoding, ZyanU16 id, const ZydisInstructionDefinition **definition)
Returns the instruction-definition with the given encoding and id.
ZYDIS_NO_EXPORT const ZydisOperandDefinition * ZydisGetOperandDefinitions(const ZydisInstructionDefinition *definition)
Returns the the operand-definitions for the given instruction-definition.
enum ZydisInternalVectorLength_ ZydisInternalVectorLength
Defines the ZydisInternalVectorLength enum.
ZydisMaskOverride_
Defines the ZydisMaskOverride enum.
Definition: SharedData.h:672
@ ZYDIS_MASK_OVERRIDE_DEFAULT
Definition: SharedData.h:673
@ ZYDIS_MASK_OVERRIDE_ZEROING
Definition: SharedData.h:674
@ ZYDIS_MASK_OVERRIDE_CONTROL
Definition: SharedData.h:675
@ ZYDIS_MASK_OVERRIDE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:684
@ ZYDIS_MASK_OVERRIDE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:680
ZydisMaskPolicy_
Defines the ZydisMaskPolicy enum.
Definition: SharedData.h:640
@ ZYDIS_MASK_POLICY_INVALID
Definition: SharedData.h:641
@ ZYDIS_MASK_POLICY_FORBIDDEN
The instruction does not allow a mask-register other than the default-mask (K0).
Definition: SharedData.h:654
@ ZYDIS_MASK_POLICY_ALLOWED
The instruction accepts mask-registers other than the default-mask (K0), but does not require them.
Definition: SharedData.h:646
@ ZYDIS_MASK_POLICY_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:663
@ ZYDIS_MASK_POLICY_REQUIRED
The instruction requires a mask-register other than the default-mask (K0).
Definition: SharedData.h:650
@ ZYDIS_MASK_POLICY_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:659
enum ZydisEVEXTupleType_ ZydisEVEXTupleType
Defines the ZydisEVEXTupleType enum.
enum ZydisMVEXStaticBroadcast_ ZydisMVEXStaticBroadcast
Defines the ZydisMVEXStaticBroadcast enum.
ZYDIS_NO_EXPORT void ZydisGetElementInfo(ZydisInternalElementType element, ZydisElementType *type, ZydisElementSize *size)
Returns the actual type and size of an internal element-type.
ZydisMVEXStaticBroadcast_
Defines the ZydisMVEXStaticBroadcast enum.
Definition: SharedData.h:616
@ ZYDIS_MVEX_STATIC_BROADCAST_4_TO_8
Definition: SharedData.h:620
@ ZYDIS_MVEX_STATIC_BROADCAST_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:626
@ ZYDIS_MVEX_STATIC_BROADCAST_4_TO_16
Definition: SharedData.h:621
@ ZYDIS_MVEX_STATIC_BROADCAST_1_TO_16
Definition: SharedData.h:619
@ ZYDIS_MVEX_STATIC_BROADCAST_NONE
Definition: SharedData.h:617
@ ZYDIS_MVEX_STATIC_BROADCAST_1_TO_8
Definition: SharedData.h:618
@ ZYDIS_MVEX_STATIC_BROADCAST_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:630
struct ZydisOperandDefinition_ ZydisOperandDefinition
Defines the ZydisOperandDefinition struct.
ZydisInternalVectorLength_
Defines the ZydisInternalVectorLength enum.
Definition: SharedData.h:276
@ ZYDIS_IVECTOR_LENGTH_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:289
@ ZYDIS_IVECTOR_LENGTH_DEFAULT
Definition: SharedData.h:277
@ ZYDIS_IVECTOR_LENGTH_FIXED_256
Definition: SharedData.h:279
@ ZYDIS_IVECTOR_LENGTH_FIXED_128
Definition: SharedData.h:278
@ ZYDIS_IVECTOR_LENGTH_FIXED_512
Definition: SharedData.h:280
@ ZYDIS_IVECTOR_LENGTH_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:285
struct ZydisInstructionDefinitionMVEX_ ZydisInstructionDefinitionMVEX
Defines the ZydisInstructionDefinitionMVEX struct.
ZydisReadWriteAction_
Defines the ZydisReadWriteAction enum.
Definition: SharedData.h:254
@ ZYDIS_RW_ACTION_READ
Definition: SharedData.h:256
@ ZYDIS_RW_ACTION_NONE
Definition: SharedData.h:255
@ ZYDIS_RW_ACTION_READWRITE
Definition: SharedData.h:258
@ ZYDIS_RW_ACTION_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:267
@ ZYDIS_RW_ACTION_WRITE
Definition: SharedData.h:257
@ ZYDIS_RW_ACTION_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:263
ZydisImplicitMemBase_
Defines the ZydisImplicitMemBase enum.
Definition: SharedData.h:179
@ ZYDIS_IMPLMEM_BASE_AGPR_RM
Definition: SharedData.h:182
@ ZYDIS_IMPLMEM_BASE_AGPR_REG
Definition: SharedData.h:181
@ ZYDIS_IMPLMEM_BASE_SBP
Definition: SharedData.h:189
@ ZYDIS_IMPLMEM_BASE_SSP
Definition: SharedData.h:188
@ ZYDIS_IMPLMEM_BASE_ASI
Definition: SharedData.h:186
@ ZYDIS_IMPLMEM_BASE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:194
@ ZYDIS_IMPLMEM_BASE_ABX
Definition: SharedData.h:185
@ ZYDIS_IMPLMEM_BASE_AAX
Definition: SharedData.h:183
@ ZYDIS_IMPLMEM_BASE_ADI
Definition: SharedData.h:187
@ ZYDIS_IMPLMEM_BASE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:198
@ ZYDIS_IMPLMEM_BASE_ADX
Definition: SharedData.h:184
enum ZydisMaskPolicy_ ZydisMaskPolicy
Defines the ZydisMaskPolicy enum.
ZydisSemanticOperandType_
Defines the ZydisSemanticOperandType enum.
Definition: SharedData.h:60
@ ZYDIS_SEMANTIC_OPTYPE_MMX
Definition: SharedData.h:74
@ ZYDIS_SEMANTIC_OPTYPE_ZMM
Definition: SharedData.h:77
@ ZYDIS_SEMANTIC_OPTYPE_BND
Definition: SharedData.h:79
@ ZYDIS_SEMANTIC_OPTYPE_GPR32_32_64
Definition: SharedData.h:70
@ ZYDIS_SEMANTIC_OPTYPE_MEM
Definition: SharedData.h:84
@ ZYDIS_SEMANTIC_OPTYPE_AGEN
Definition: SharedData.h:91
@ ZYDIS_SEMANTIC_OPTYPE_CR
Definition: SharedData.h:81
@ ZYDIS_SEMANTIC_OPTYPE_DR
Definition: SharedData.h:82
@ ZYDIS_SEMANTIC_OPTYPE_IMPLICIT_MEM
Definition: SharedData.h:63
@ ZYDIS_SEMANTIC_OPTYPE_GPR32
Definition: SharedData.h:67
@ ZYDIS_SEMANTIC_OPTYPE_MEM_VSIBY
Definition: SharedData.h:86
@ ZYDIS_SEMANTIC_OPTYPE_FPR
Definition: SharedData.h:73
@ ZYDIS_SEMANTIC_OPTYPE_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:98
@ ZYDIS_SEMANTIC_OPTYPE_XMM
Definition: SharedData.h:75
@ ZYDIS_SEMANTIC_OPTYPE_GPR8
Definition: SharedData.h:65
@ ZYDIS_SEMANTIC_OPTYPE_MEM_VSIBX
Definition: SharedData.h:85
@ ZYDIS_SEMANTIC_OPTYPE_MEM_VSIBZ
Definition: SharedData.h:87
@ ZYDIS_SEMANTIC_OPTYPE_GPR16
Definition: SharedData.h:66
@ ZYDIS_SEMANTIC_OPTYPE_MIB
Definition: SharedData.h:93
@ ZYDIS_SEMANTIC_OPTYPE_SREG
Definition: SharedData.h:80
@ ZYDIS_SEMANTIC_OPTYPE_TMM
Definition: SharedData.h:78
@ ZYDIS_SEMANTIC_OPTYPE_IMM
Definition: SharedData.h:88
@ ZYDIS_SEMANTIC_OPTYPE_MOFFS
Definition: SharedData.h:92
@ ZYDIS_SEMANTIC_OPTYPE_GPR64
Definition: SharedData.h:68
@ ZYDIS_SEMANTIC_OPTYPE_IMPLICIT_IMM1
Definition: SharedData.h:64
@ ZYDIS_SEMANTIC_OPTYPE_GPR16_32_32
Definition: SharedData.h:71
@ ZYDIS_SEMANTIC_OPTYPE_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:102
@ ZYDIS_SEMANTIC_OPTYPE_UNUSED
Definition: SharedData.h:61
@ ZYDIS_SEMANTIC_OPTYPE_IMPLICIT_REG
Definition: SharedData.h:62
@ ZYDIS_SEMANTIC_OPTYPE_GPR16_32_64
Definition: SharedData.h:69
@ ZYDIS_SEMANTIC_OPTYPE_YMM
Definition: SharedData.h:76
@ ZYDIS_SEMANTIC_OPTYPE_REL
Definition: SharedData.h:89
@ ZYDIS_SEMANTIC_OPTYPE_PTR
Definition: SharedData.h:90
@ ZYDIS_SEMANTIC_OPTYPE_MASK
Definition: SharedData.h:83
@ ZYDIS_SEMANTIC_OPTYPE_GPR_ASZ
Definition: SharedData.h:72
struct ZydisInstructionDefinitionXOP_ ZydisInstructionDefinitionXOP
Defines the ZydisInstructionDefinitionXOP struct.
ZYAN_STATIC_ASSERT(ZYDIS_SEMANTIC_OPTYPE_REQUIRED_BITS<=8)
enum ZydisInternalElementType_ ZydisInternalElementType
Defines the ZydisInternalElementType enum.
enum ZydisInternalElementSize_ ZydisInternalElementSize
Defines the ZydisInternalElementSize enum.
struct ZydisInstructionDefinitionEVEX_ ZydisInstructionDefinitionEVEX
Defines the ZydisInstructionDefinitionEVEX struct.
ZydisEVEXStaticBroadcast_
Defines the ZydisEVEXStaticBroadcast enum.
Definition: SharedData.h:584
@ ZYDIS_EVEX_STATIC_BROADCAST_1_TO_4
Definition: SharedData.h:587
@ ZYDIS_EVEX_STATIC_BROADCAST_8_TO_16
Definition: SharedData.h:597
@ ZYDIS_EVEX_STATIC_BROADCAST_1_TO_16
Definition: SharedData.h:589
@ ZYDIS_EVEX_STATIC_BROADCAST_4_TO_8
Definition: SharedData.h:595
@ ZYDIS_EVEX_STATIC_BROADCAST_2_TO_4
Definition: SharedData.h:592
@ ZYDIS_EVEX_STATIC_BROADCAST_1_TO_32
Definition: SharedData.h:590
@ ZYDIS_EVEX_STATIC_BROADCAST_4_TO_16
Definition: SharedData.h:596
@ ZYDIS_EVEX_STATIC_BROADCAST_MAX_VALUE
Maximum value of this enum.
Definition: SharedData.h:602
@ ZYDIS_EVEX_STATIC_BROADCAST_1_TO_2
Definition: SharedData.h:586
@ ZYDIS_EVEX_STATIC_BROADCAST_1_TO_64
Definition: SharedData.h:591
@ ZYDIS_EVEX_STATIC_BROADCAST_2_TO_8
Definition: SharedData.h:593
@ ZYDIS_EVEX_STATIC_BROADCAST_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedData.h:606
@ ZYDIS_EVEX_STATIC_BROADCAST_1_TO_8
Definition: SharedData.h:588
@ ZYDIS_EVEX_STATIC_BROADCAST_NONE
Definition: SharedData.h:585
@ ZYDIS_EVEX_STATIC_BROADCAST_2_TO_16
Definition: SharedData.h:594
struct ZydisInstructionDefinitionLEGACY_ ZydisInstructionDefinitionLEGACY
Defines the ZydisInstructionDefinitionLEGACY struct.
Defines decoder/encoder-shared macros and types.
@ ZYDIS_OPERAND_VISIBILITY_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedTypes.h:321
enum ZydisInstructionEncoding_ ZydisInstructionEncoding
Defines the ZydisInstructionEncoding enum.
@ ZYDIS_OPERAND_ENCODING_REQUIRED_BITS
The minimum number of bits required to represent all values of this enum.
Definition: SharedTypes.h:288
@ ZYDIS_OPERAND_ACTION_REQUIRED_BITS
The minimum number of bits required to represent all values of this bitset.
Definition: SharedTypes.h:396
enum ZydisElementType_ ZydisElementType
Defines the ZydisElementType enum.
ZyanU16 ZydisElementSize
Defines the ZydisElementSize datatype.
Definition: SharedTypes.h:190
Definition: DecoderTypes.h:386
Definition: SharedData.h:895
ZydisAccessedFlags fpu_flags
Definition: SharedData.h:897
ZydisAccessedFlags cpu_flags
Definition: SharedData.h:896
Defines the ZydisInstructionDefinition3DNOW struct.
Definition: SharedData.h:793
ZYDIS_INSTRUCTION_DEFINITION_BASE
Definition: SharedData.h:794
Defines the ZydisInstructionDefinitionEVEX struct.
Definition: SharedData.h:836
ZyanU8 tuple_type ZYAN_BITFIELD(ZYDIS_TUPLETYPE_REQUIRED_BITS)
ZyanU8 functionality ZYAN_BITFIELD(ZYDIS_EVEX_FUNC_REQUIRED_BITS)
ZyanU8 mask_override ZYAN_BITFIELD(ZYDIS_MASK_OVERRIDE_REQUIRED_BITS)
ZyanU8 vector_length ZYAN_BITFIELD(ZYDIS_IVECTOR_LENGTH_REQUIRED_BITS)
ZyanBool accepts_zero_mask ZYAN_BITFIELD(1)
ZyanU8 broadcast ZYAN_BITFIELD(ZYDIS_EVEX_STATIC_BROADCAST_REQUIRED_BITS)
ZyanU8 element_size ZYAN_BITFIELD(ZYDIS_IELEMENT_SIZE_REQUIRED_BITS)
ZyanU8 mask_policy ZYAN_BITFIELD(ZYDIS_MASK_POLICY_REQUIRED_BITS)
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL
Definition: SharedData.h:837
Defines the ZydisInstructionDefinitionLEGACY struct.
Definition: SharedData.h:770
ZyanBool accepts_branch_hints ZYAN_BITFIELD(1)
ZyanBool accepts_XACQUIRE ZYAN_BITFIELD(1)
ZyanBool accepts_XRELEASE ZYAN_BITFIELD(1)
ZYDIS_INSTRUCTION_DEFINITION_BASE
Definition: SharedData.h:771
ZyanBool accepts_REPNEREPNZ ZYAN_BITFIELD(1)
ZyanBool accepts_BOUND ZYAN_BITFIELD(1)
ZyanBool accepts_LOCK ZYAN_BITFIELD(1)
ZyanBool accepts_REP ZYAN_BITFIELD(1)
ZyanBool accepts_REPEREPZ ZYAN_BITFIELD(1)
ZyanBool accepts_NOTRACK ZYAN_BITFIELD(1)
ZyanBool accepts_hle_without_lock ZYAN_BITFIELD(1)
ZyanBool is_privileged ZYAN_BITFIELD(1)
Defines the ZydisInstructionDefinitionMVEX struct.
Definition: SharedData.h:865
ZyanBool has_element_granularity ZYAN_BITFIELD(1)
ZyanU8 broadcast ZYAN_BITFIELD(ZYDIS_MVEX_STATIC_BROADCAST_REQUIRED_BITS)
ZyanU8 functionality ZYAN_BITFIELD(ZYDIS_MVEX_FUNC_REQUIRED_BITS)
ZyanU8 mask_policy ZYAN_BITFIELD(ZYDIS_MASK_POLICY_REQUIRED_BITS)
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL
Definition: SharedData.h:866
Defines the ZydisInstructionDefinitionVEX struct.
Definition: SharedData.h:813
ZyanU8 broadcast ZYAN_BITFIELD(ZYDIS_VEX_STATIC_BROADCAST_REQUIRED_BITS)
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL
Definition: SharedData.h:814
Defines the ZydisInstructionDefinitionXOP struct.
Definition: SharedData.h:801
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR
Definition: SharedData.h:802
Defines the ZydisInstructionDefinition struct.
Definition: SharedData.h:762
ZYDIS_INSTRUCTION_DEFINITION_BASE
Definition: SharedData.h:763
Defines the ZydisOperandDefinition struct.
Definition: SharedData.h:218
union ZydisOperandDefinition_::@11::@12::@14 reg
ZyanBool ignore_seg_override ZYAN_BITFIELD(1)
ZyanU8 type ZYAN_BITFIELD(ZYDIS_SEMANTIC_OPTYPE_REQUIRED_BITS)
union ZydisOperandDefinition_::@11 op
struct ZydisOperandDefinition_::@11::@13 mem
ZyanU8 element_type ZYAN_BITFIELD(ZYDIS_IELEMENT_TYPE_REQUIRED_BITS)
ZyanBool is_multisource4 ZYAN_BITFIELD(1)
ZyanU8 actions ZYAN_BITFIELD(ZYDIS_OPERAND_ACTION_REQUIRED_BITS)
ZyanU8 visibility ZYAN_BITFIELD(ZYDIS_OPERAND_VISIBILITY_REQUIRED_BITS)
ZyanU16 size[3]
Definition: SharedData.h:222