decfszInstruction #12

Merged
Darkress merged 2 commits from decfszInstruction into main 2023-05-31 20:51:00 +02:00
3 changed files with 12 additions and 4 deletions
Showing only changes of commit 89f4845df6 - Show all commits

View File

@@ -15,8 +15,11 @@ class Main
int input1 = 0x27FF; int input1 = 0x27FF;
program.add(CommandDecoder.decode(0x3011)); //Write 0x11 to W program.add(CommandDecoder.decode(0x3011)); //Write 0x11 to W
Memory.setRegister(0x14, 0x01); Memory.setRegister(0x14, 0x01);
program.add(CommandDecoder.decode(0x0314)); program.add(CommandDecoder.decode(0x0B94));
for(int i = 0; i < 2; i++) program.add(CommandDecoder.decode(0x0B94));
program.add(CommandDecoder.decode(0x0B94));
program.add(CommandDecoder.decode(0x3F05));
for(int i = 0; i < program.size(); i++)
{ {
program.get(ProgramCounter.getPc()).execute(); program.get(ProgramCounter.getPc()).execute();
} }

View File

@@ -22,6 +22,12 @@ public class Decfsz extends FileRegisterCommandUtils implements Command
checkZeroBit(result); checkZeroBit(result);
writeToDestination(destinationBit, address, result % 256); // Catch underflow writeToDestination(destinationBit, address, result % 256); // Catch underflow
if((result % 256) == 0)
{
Nop nop = new Nop();
nop.execute();
}
ProgramCounter.incPC(); ProgramCounter.incPC();
} }
} }

View File

@@ -17,8 +17,7 @@ public class CommandDecoder
case 0x300: case 0x300:
return new Decf(input); return new Decf(input);
case 0xB00: case 0xB00:
//decfsz(); return new Decfsz(input);
break;
case 0xA00: case 0xA00:
//incf(); //incf();
break; break;