1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
use enum_primitive::FromPrimitive;
use faucon_asm::{Instruction, Operand};
use super::{Cpu, CpuFlag, Trap, PC};
pub fn iret(cpu: &mut Cpu, _: &Instruction) -> usize {
cpu.registers[PC] = cpu.stack_pop();
cpu.registers
.set_flag(CpuFlag::IE0, cpu.registers.get_flag(CpuFlag::IS0));
cpu.registers
.set_flag(CpuFlag::IE1, cpu.registers.get_flag(CpuFlag::IS1));
cpu.registers
.set_flag(CpuFlag::IE2, cpu.registers.get_flag(CpuFlag::IS2));
cpu.increment_pc = true;
1
}
pub fn trap(cpu: &mut Cpu, insn: &Instruction) -> usize {
let trap = insn.operands()[0];
if let Operand::UnsignedImmediate(imm) = trap {
cpu.trigger_trap(Trap::from_u32(imm).unwrap());
} else {
unreachable!();
}
cpu.increment_pc = false;
1
}