diff options
author | Johannes Stoelp <johannes.stoelp@gmail.com> | 2023-12-13 00:10:30 +0100 |
---|---|---|
committer | Johannes Stoelp <johannes.stoelp@gmail.com> | 2023-12-13 00:10:30 +0100 |
commit | fe5064d532011bea705693594015d70c5ce2d726 (patch) | |
tree | e14f4611c069e90670c050d1f189afe907d51735 /src | |
parent | 20744b382d4d0226037eab810f312accc28fbfe2 (diff) | |
download | juicebox-asm-fe5064d532011bea705693594015d70c5ce2d726.tar.gz juicebox-asm-fe5064d532011bea705693594015d70c5ce2d726.zip |
asm: add push/pop insn
Diffstat (limited to 'src')
-rw-r--r-- | src/insn.rs | 14 | ||||
-rw-r--r-- | src/insn/pop.rs | 14 | ||||
-rw-r--r-- | src/insn/push.rs | 14 |
3 files changed, 42 insertions, 0 deletions
diff --git a/src/insn.rs b/src/insn.rs index c7e6e7e..60004d2 100644 --- a/src/insn.rs +++ b/src/insn.rs @@ -9,6 +9,8 @@ mod jnz; mod jz; mod mov; mod nop; +mod pop; +mod push; mod ret; mod test; @@ -63,6 +65,18 @@ pub trait Mov<T, U> { fn mov(&mut self, op1: T, op2: U); } +/// Trait for [`push`](https://www.felixcloutier.com/x86/push) instruction kinds. +pub trait Push<T> { + /// Emit a push instruction. + fn push(&mut self, op1: T); +} + +/// Trait for [`pop`](https://www.felixcloutier.com/x86/pop) instruction kinds. +pub trait Pop<T> { + /// Emit a pop instruction. + fn pop(&mut self, op1: T); +} + /// Trait for [`test`](https://www.felixcloutier.com/x86/test) instruction kinds. pub trait Test<T, U> { /// Emit a logical compare instruction. diff --git a/src/insn/pop.rs b/src/insn/pop.rs new file mode 100644 index 0000000..c8cc5b5 --- /dev/null +++ b/src/insn/pop.rs @@ -0,0 +1,14 @@ +use super::Pop; +use crate::{Asm, Reg16, Reg64}; + +impl Pop<Reg64> for Asm { + fn pop(&mut self, op1: Reg64) { + self.encode_r(0x8f, 0x0, op1); + } +} + +impl Pop<Reg16> for Asm { + fn pop(&mut self, op1: Reg16) { + self.encode_r(0x8f, 0x0, op1); + } +} diff --git a/src/insn/push.rs b/src/insn/push.rs new file mode 100644 index 0000000..8554dcb --- /dev/null +++ b/src/insn/push.rs @@ -0,0 +1,14 @@ +use super::Push; +use crate::{Asm, Reg16, Reg64}; + +impl Push<Reg64> for Asm { + fn push(&mut self, op1: Reg64) { + self.encode_r(0xff, 0x6, op1); + } +} + +impl Push<Reg16> for Asm { + fn push(&mut self, op1: Reg16) { + self.encode_r(0xff, 0x6, op1); + } +} |