]> Joshua Wise's Git repositories - fpgaboy.git/commitdiff
Instructions: ld hl, sp+imm8 and add sp, imm8
authorJoshua Wise <joshua@rebirth.joshuawise.com>
Sat, 10 May 2008 08:14:53 +0000 (04:14 -0400)
committerJoshua Wise <joshua@rebirth.joshuawise.com>
Sat, 10 May 2008 08:14:53 +0000 (04:14 -0400)
core/allinsns.v
core/insn_add_sp_imm8.v [new file with mode: 0644]
core/insn_ldhl_sp_imm8.v [new file with mode: 0644]
opcodes

index dfdf04fc536e6b244e54ec78bc27a8b4a877e568..4ecd2b1a110d4ae3065d1ca8967472c52c1404bf 100644 (file)
@@ -30,3 +30,5 @@
 `include "insn_bit.v"
 `include "insn_alu_ext.v"
 `include "insn_add_hl.v"
 `include "insn_bit.v"
 `include "insn_alu_ext.v"
 `include "insn_add_hl.v"
+`include "insn_ldhl_sp_imm8.v"
+`include "insn_add_sp_imm8.v"
diff --git a/core/insn_add_sp_imm8.v b/core/insn_add_sp_imm8.v
new file mode 100644 (file)
index 0000000..06d58cc
--- /dev/null
@@ -0,0 +1,26 @@
+`define INSN_ADD_SP_IMM8               9'b011101000
+
+`ifdef EXECUTE
+       `INSN_ADD_SP_IMM8: begin
+               case (cycle)
+               0:      begin
+                               `EXEC_INC_PC
+                       end
+               1:      begin
+                               `EXEC_READ(`_PC)
+                       end
+               3:      begin
+                               `EXEC_NEWCYCLE
+                               `EXEC_INC_PC
+                       end
+               endcase
+       end
+`endif
+
+`ifdef WRITEBACK
+       `INSN_ADD_SP_IMM8: begin
+               case (cycle)
+               2:      `_HL <= `_SP + {rdata[7] ? 8'hFF : 8'h00, rdata};
+               endcase
+       end
+`endif
diff --git a/core/insn_ldhl_sp_imm8.v b/core/insn_ldhl_sp_imm8.v
new file mode 100644 (file)
index 0000000..688465a
--- /dev/null
@@ -0,0 +1,26 @@
+`define INSN_LDHL_SP_IMM8              9'b011111000
+
+`ifdef EXECUTE
+       `INSN_LDHL_SP_IMM8: begin
+               case (cycle)
+               0:      begin
+                               `EXEC_INC_PC
+                       end
+               1:      begin
+                               `EXEC_READ(`_PC)
+                       end
+               2:      begin
+                               `EXEC_NEWCYCLE
+                               `EXEC_INC_PC
+                       end
+               endcase
+       end
+`endif
+
+`ifdef WRITEBACK
+       `INSN_LDHL_SP_IMM8: begin
+               case (cycle)
+               2:      `_HL <= `_SP + {rdata[7] ? 8'hFF : 8'h00, rdata};
+               endcase
+       end
+`endif
diff --git a/opcodes b/opcodes
index 451a6b6f88a8bc6756308bad670800b8551cc5fe..8aa627ef1282f814625c09ad3eed15de3325490b 100644 (file)
--- a/opcodes
+++ b/opcodes
@@ -11,8 +11,6 @@ bits         insn                 notes
 0001 0000    STOP
 0111 0110    HALT                 Danger! Helvetica!
 1100 1011    -     -     -        see two-byte opcodes below
 0001 0000    STOP
 0111 0110    HALT                 Danger! Helvetica!
 1100 1011    -     -     -        see two-byte opcodes below
-1110 1000    ADD   SP,   imm8
-1111 1000    LDHL  SP,   imm8     load SP+n (signed n) into HL
 
 *****************************
 
 
 *****************************
 
This page took 0.028874 seconds and 4 git commands to generate.