From 4f60de32bbba15a6fdad1cccbe43c638c3aef338 Mon Sep 17 00:00:00 2001 From: Johannes Stoelp Date: Wed, 11 Dec 2024 22:22:48 +0100 Subject: asm: add sub insn, add imm8 --- src/insn/add.rs | 8 +++++++- src/insn/sub.rs | 14 ++++++++++++++ 2 files changed, 21 insertions(+), 1 deletion(-) create mode 100644 src/insn/sub.rs (limited to 'src/insn') diff --git a/src/insn/add.rs b/src/insn/add.rs index d5312be..1f5294e 100644 --- a/src/insn/add.rs +++ b/src/insn/add.rs @@ -1,5 +1,5 @@ use super::Add; -use crate::{Asm, Imm16, MemOp, Reg16, Reg32, Reg64}; +use crate::{Asm, Imm16, Imm8, MemOp, Reg16, Reg32, Reg64}; impl Add for Asm { fn add(&mut self, op1: Reg64, op2: Reg64) { @@ -25,6 +25,12 @@ impl Add for Asm { } } +impl Add for Asm { + fn add(&mut self, op1: MemOp, op2: Imm8) { + self.encode_mi(0x83, 0, op1, op2); + } +} + impl Add for Asm { fn add(&mut self, op1: MemOp, op2: Imm16) { self.encode_mi(0x81, 0, op1, op2); diff --git a/src/insn/sub.rs b/src/insn/sub.rs new file mode 100644 index 0000000..814744c --- /dev/null +++ b/src/insn/sub.rs @@ -0,0 +1,14 @@ +use super::Sub; +use crate::{Asm, Imm8, MemOp, Reg64}; + +impl Sub for Asm { + fn sub(&mut self, op1: Reg64, op2: Reg64) { + self.encode_rr(&[0x29], op1, op2); + } +} + +impl Sub for Asm { + fn sub(&mut self, op1: MemOp, op2: Imm8) { + self.encode_mi(0x83, 5, op1, op2); + } +} -- cgit v1.2.3