From 8369f061948bf85d18da0124e24f773a2f27dff1 Mon Sep 17 00:00:00 2001 From: Denis-Cosmin NUTIU Date: Sun, 8 Dec 2024 12:25:35 +0200 Subject: [PATCH] decode keypad instructions --- src/emulator.rs | 9 +++++++++ src/instruction.rs | 42 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 51 insertions(+) diff --git a/src/emulator.rs b/src/emulator.rs index 3d1aa3a..a0ab2a1 100644 --- a/src/emulator.rs +++ b/src/emulator.rs @@ -379,6 +379,15 @@ where self.memory[memory_index] = self.registers[i as usize]; } } + ProcessorInstruction::GetKeyBlocking(_vx) => { + todo!("must implement") + } + ProcessorInstruction::SkipIfKeyIsPressed(_vx) => { + todo!("must implement") + } + ProcessorInstruction::SkipIfKeyIsNotPressed(_vx) => { + todo!("must implement") + } _ => { warn!("Unknown instruction: {:04x}, skipping.", instruction); } diff --git a/src/instruction.rs b/src/instruction.rs index cbcff2d..3ec6525 100644 --- a/src/instruction.rs +++ b/src/instruction.rs @@ -78,6 +78,12 @@ pub enum ProcessorInstruction { StoreMemory(u8), /// Loads the general purpose registers from memory at index register address. LoadMemory(u8), + /// Blocks execution and waits for input. If a key is pressed it will be put in VX. + GetKeyBlocking(u8), + /// Skips one instruction if a key value stored in VX is pressed. Doesn't block execution. + SkipIfKeyIsPressed(u8), + /// Skips one instruction if a key value stored in VX is NOT pressed. Doesn't block execution. + SkipIfKeyIsNotPressed(u8), /// Unknown instruction UnknownInstruction, } @@ -225,6 +231,15 @@ impl Instruction { } (0xF, _, 0x5, 0x5) => ProcessorInstruction::StoreMemory(Self::grab_first_nibble(data)), (0xF, _, 0x6, 0x5) => ProcessorInstruction::LoadMemory(Self::grab_first_nibble(data)), + (0xE, _, 0x9, 0xE) => { + ProcessorInstruction::SkipIfKeyIsPressed(Self::grab_first_nibble(data)) + } + (0xE, _, 0xA, 0x1) => { + ProcessorInstruction::SkipIfKeyIsNotPressed(Self::grab_first_nibble(data)) + } + (0xF, _, 0x0, 0xA) => { + ProcessorInstruction::GetKeyBlocking(Self::grab_first_nibble(data)) + } // Unknown instruction _ => ProcessorInstruction::UnknownInstruction, } @@ -570,4 +585,31 @@ mod tests { ProcessorInstruction::LoadMemory(0xA) ) } + + #[test] + fn test_instruction_skip_if_key_pressed() { + let instruction = Instruction::new([0xEF, 0x9E]); + assert_eq!( + instruction.processor_instruction, + ProcessorInstruction::SkipIfKeyIsPressed(0xF) + ) + } + + #[test] + fn test_instruction_skip_if_key_not_pressed() { + let instruction = Instruction::new([0xEF, 0xA1]); + assert_eq!( + instruction.processor_instruction, + ProcessorInstruction::SkipIfKeyIsNotPressed(0xF) + ) + } + + #[test] + fn test_instruction_get_key() { + let instruction = Instruction::new([0xFE, 0x0A]); + assert_eq!( + instruction.processor_instruction, + ProcessorInstruction::GetKeyBlocking(0xE) + ) + } }