aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/insn
diff options
context:
space:
mode:
authorJohannes Stoelp <johannes.stoelp@gmail.com>2023-12-05 00:56:58 +0100
committerJohannes Stoelp <johannes.stoelp@gmail.com>2023-12-05 00:56:58 +0100
commit3f47ede3d0a1aaf3a9176ab9c93b8d0e970388f2 (patch)
tree395c01d6dad25e14ee8f6879d3f040e9f57f1d2f /src/insn
parent4a80838151a9945438739ab937c415939e2ccf5b (diff)
downloadjuicebox-asm-3f47ede3d0a1aaf3a9176ab9c93b8d0e970388f2.tar.gz
juicebox-asm-3f47ede3d0a1aaf3a9176ab9c93b8d0e970388f2.zip
insn: add additional insn required for the new tiny_vm example
Diffstat (limited to 'src/insn')
-rw-r--r--src/insn/add.rs12
-rw-r--r--src/insn/cmp.rs7
-rw-r--r--src/insn/mov.rs8
-rw-r--r--src/insn/test.rs6
4 files changed, 33 insertions, 0 deletions
diff --git a/src/insn/add.rs b/src/insn/add.rs
index 3757d14..8232fe4 100644
--- a/src/insn/add.rs
+++ b/src/insn/add.rs
@@ -11,3 +11,15 @@ impl Add<Reg32, Reg32> for Asm {
self.encode_rr(0x01, op1, op2);
}
}
+
+impl Add<MemOp, Reg16> for Asm {
+ fn add(&mut self, op1: MemOp, op2: Reg16) {
+ self.encode_mr(0x01, op1, op2);
+ }
+}
+
+impl Add<MemOp, Imm16> for Asm {
+ fn add(&mut self, op1: MemOp, op2: Imm16) {
+ self.encode_mi(0x81, 0, op1, op2);
+ }
+}
diff --git a/src/insn/cmp.rs b/src/insn/cmp.rs
new file mode 100644
index 0000000..93aa26c
--- /dev/null
+++ b/src/insn/cmp.rs
@@ -0,0 +1,7 @@
+use crate::prelude::*;
+
+impl Cmp<MemOp, Imm16> for Asm {
+ fn cmp(&mut self, op1: MemOp, op2: Imm16) {
+ self.encode_mi(0x81, 0x7, op1, op2);
+ }
+}
diff --git a/src/insn/mov.rs b/src/insn/mov.rs
index bf1c33e..2614d82 100644
--- a/src/insn/mov.rs
+++ b/src/insn/mov.rs
@@ -103,3 +103,11 @@ impl Mov<Reg8, Imm8> for Asm {
self.encode_oi(0xb0, op1, op2);
}
}
+
+// -- MOV : mem imm
+
+impl Mov<MemOp, Imm16> for Asm {
+ fn mov(&mut self, op1: MemOp, op2: Imm16) {
+ self.encode_mi(0xc7, 0, op1, op2);
+ }
+}
diff --git a/src/insn/test.rs b/src/insn/test.rs
index 25f1680..b7ac774 100644
--- a/src/insn/test.rs
+++ b/src/insn/test.rs
@@ -11,3 +11,9 @@ impl Test<Reg32, Reg32> for Asm {
self.encode_rr(0x85, op1, op2);
}
}
+
+impl Test<MemOp, Imm16> for Asm {
+ fn test(&mut self, op1: MemOp, op2: Imm16) {
+ self.encode_mi(0xf7, 0, op1, op2);
+ }
+}