From d44466c852dd353166c79d1cc618646b21e17f8c Mon Sep 17 00:00:00 2001 From: Johannes Stoelp Date: Mon, 27 Feb 2023 23:35:32 +0100 Subject: Add JNZ and Reg32 ADD, DEC, TEST for readme example --- src/insn/add.rs | 6 ++++++ src/insn/dec.rs | 6 ++++++ src/insn/jnz.rs | 7 +++++++ src/insn/test.rs | 6 ++++++ 4 files changed, 25 insertions(+) create mode 100644 src/insn/jnz.rs (limited to 'src/insn') diff --git a/src/insn/add.rs b/src/insn/add.rs index b8456c4..3757d14 100644 --- a/src/insn/add.rs +++ b/src/insn/add.rs @@ -5,3 +5,9 @@ impl Add for Asm { self.encode_rr(0x01, op1, op2); } } + +impl Add for Asm { + fn add(&mut self, op1: Reg32, op2: Reg32) { + self.encode_rr(0x01, op1, op2); + } +} diff --git a/src/insn/dec.rs b/src/insn/dec.rs index 7de5a54..c5803e7 100644 --- a/src/insn/dec.rs +++ b/src/insn/dec.rs @@ -5,3 +5,9 @@ impl Dec for Asm { self.encode_r(0xff, 1, op1); } } + +impl Dec for Asm { + fn dec(&mut self, op1: Reg32) { + self.encode_r(0xff, 1, op1); + } +} diff --git a/src/insn/jnz.rs b/src/insn/jnz.rs new file mode 100644 index 0000000..6517bd7 --- /dev/null +++ b/src/insn/jnz.rs @@ -0,0 +1,7 @@ +use crate::prelude::*; + +impl Jnz<&mut Label> for Asm { + fn jnz(&mut self, op1: &mut Label) { + self.encode_jmp_label(&[0x0f, 0x85], op1); + } +} diff --git a/src/insn/test.rs b/src/insn/test.rs index 1319e3f..25f1680 100644 --- a/src/insn/test.rs +++ b/src/insn/test.rs @@ -5,3 +5,9 @@ impl Test for Asm { self.encode_rr(0x85, op1, op2); } } + +impl Test for Asm { + fn test(&mut self, op1: Reg32, op2: Reg32) { + self.encode_rr(0x85, op1, op2); + } +} -- cgit v1.2.3