diff options
| author | iximeow <me@iximeow.net> | 2021-07-01 23:54:06 -0700 | 
|---|---|---|
| committer | iximeow <me@iximeow.net> | 2021-07-01 23:54:06 -0700 | 
| commit | a781322552d9fb52b7b5e51641f49f12678f682f (patch) | |
| tree | b7ea7042d707dca8ffc322ddac4ebd5b8c475027 /src/protected_mode/evex.rs | |
| parent | 889ce5c55af062d12cdd109bac22cc05565f68a6 (diff) | |
reallocate OperandCode, convert disparate registers to array
also remove redundant assignments of operand_count and some OperandSpec,
bulk-assign all registers and operands on entry to `read_instr`. this
all, taken together, shaves off about 7 cycles per decode.
Diffstat (limited to 'src/protected_mode/evex.rs')
| -rw-r--r-- | src/protected_mode/evex.rs | 3 | 
1 files changed, 2 insertions, 1 deletions
| diff --git a/src/protected_mode/evex.rs b/src/protected_mode/evex.rs index 9d2a093..cb0a4ba 100644 --- a/src/protected_mode/evex.rs +++ b/src/protected_mode/evex.rs @@ -1,6 +1,7 @@  // use crate::long_mode::{OperandSpec, DecodeError, RegSpec, RegisterBank, Instruction, Opcode}; -use crate::protected_mode::{DecodeError, RegSpec, RegisterBank, Instruction, Opcode}; +use crate::protected_mode::{Arch, DecodeError, RegSpec, RegisterBank, Instruction, Opcode};  use crate::protected_mode::{read_modrm, read_E_vex, read_imm_unsigned}; +use yaxpeax_arch::Reader;  const DEFAULT_EVEX_REGISTER_SIZE: RegisterBank = RegisterBank::D;  const DEFAULT_EVEX_REGISTER_WIDTH: u8 = 4; | 
