From 2699292790476eccd726fc5dae179b3a688a1468 Mon Sep 17 00:00:00 2001 From: Johannes Stoelp Date: Fri, 6 Dec 2024 23:32:58 +0100 Subject: asm: add initial support for memory operand only instructions * add dec, inc instruction for with memory operand --- src/insn/dec.rs | 26 +++++++++++++++++++++++++- src/insn/inc.rs | 26 +++++++++++++++++++++++++- 2 files changed, 50 insertions(+), 2 deletions(-) (limited to 'src/insn') diff --git a/src/insn/dec.rs b/src/insn/dec.rs index 1377d1c..66b83aa 100644 --- a/src/insn/dec.rs +++ b/src/insn/dec.rs @@ -1,5 +1,5 @@ use super::Dec; -use crate::{Asm, Reg32, Reg64}; +use crate::{Asm, MemOp16, MemOp32, MemOp64, MemOp8, Reg32, Reg64}; impl Dec for Asm { fn dec(&mut self, op1: Reg64) { @@ -12,3 +12,27 @@ impl Dec for Asm { self.encode_r(0xff, 1, op1); } } + +impl Dec for Asm { + fn dec(&mut self, op1: MemOp8) { + self.encode_m(0xfe, 1, op1); + } +} + +impl Dec for Asm { + fn dec(&mut self, op1: MemOp16) { + self.encode_m(0xff, 1, op1); + } +} + +impl Dec for Asm { + fn dec(&mut self, op1: MemOp32) { + self.encode_m(0xff, 1, op1); + } +} + +impl Dec for Asm { + fn dec(&mut self, op1: MemOp64) { + self.encode_m(0xff, 1, op1); + } +} diff --git a/src/insn/inc.rs b/src/insn/inc.rs index ede780a..1530d63 100644 --- a/src/insn/inc.rs +++ b/src/insn/inc.rs @@ -1,5 +1,5 @@ use super::Inc; -use crate::{Asm, Reg32, Reg64}; +use crate::{Asm, MemOp16, MemOp32, MemOp64, MemOp8, Reg32, Reg64}; impl Inc for Asm { fn inc(&mut self, op1: Reg64) { @@ -12,3 +12,27 @@ impl Inc for Asm { self.encode_r(0xff, 0, op1); } } + +impl Inc for Asm { + fn inc(&mut self, op1: MemOp8) { + self.encode_m(0xfe, 0, op1); + } +} + +impl Inc for Asm { + fn inc(&mut self, op1: MemOp16) { + self.encode_m(0xff, 0, op1); + } +} + +impl Inc for Asm { + fn inc(&mut self, op1: MemOp32) { + self.encode_m(0xff, 0, op1); + } +} + +impl Inc for Asm { + fn inc(&mut self, op1: MemOp64) { + self.encode_m(0xff, 0, op1); + } +} -- cgit v1.2.3