Files
machine/Source/Instructions.rs
2021-11-19 17:55:40 -03:00

389 lines
9.0 KiB
Rust

use crate::Machine;
pub fn Nothing(vm: &mut Machine) -> bool {
vm.Next();
true
}
pub fn LoadRegister(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let addr = vm.ReadWord(None);
let val = vm.ReadWord(Some(addr));
vm.registry.Set(reg, val);
vm.Walk(5);
true
}
pub fn SaveRegister(vm: &mut Machine) -> bool {
let addr = vm.ReadWord(None);
let reg = vm.ReadByte(None);
let val = vm.registry.Get(reg);
vm.WriteWord(Some(addr), val);
vm.Walk(5);
true
}
#[allow(dead_code)]
pub fn Move(_vm: &mut Machine) -> bool {
false
}
pub fn Add(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 + op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn AddAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 + op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Subtract(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 - op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn SubtractAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 - op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Multiply(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 * op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn MultiplyAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 * op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Divide(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 / op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn DivideAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 / op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Remainder(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 % op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn RemainderAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 % op2).to_be_bytes());
vm.Walk(2);
true
}
#[allow(dead_code)]
pub fn Neg(_vm: &mut Machine) -> bool {
false
}
pub fn And(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 & op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn AndAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 & op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Or(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 | op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn OrAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 | op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Xor(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, (op1 ^ op2).to_be_bytes());
vm.Walk(3);
true
}
pub fn XorAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg1, (op1 ^ op2).to_be_bytes());
vm.Walk(2);
true
}
pub fn Not(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let op = u32::from_be_bytes(vm.registry.Get(reg));
vm.registry.Set(reg, (!op).to_be_bytes());
vm.Walk(2);
true
}
pub fn ShiftLeft(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
vm.registry.Set(reg, (op1 << 1).to_be_bytes());
vm.Walk(3);
true
}
pub fn ShiftLeftAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
vm.registry.Set(reg1, (op1 << 1).to_be_bytes());
vm.Walk(2);
true
}
pub fn ShiftRight(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
vm.registry.Set(reg, (op1 >> 1).to_be_bytes());
vm.Walk(3);
true
}
pub fn ShiftRightAssign(vm: &mut Machine) -> bool {
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
vm.registry.Set(reg1, (op1 >> 1).to_be_bytes());
vm.Walk(2);
true
}
pub fn Equals(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, ((op1 == op2) as u32).to_be_bytes());
vm.Walk(3);
true
}
pub fn NotEquals(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, ((op1 != op2) as u32).to_be_bytes());
vm.Walk(3);
true
}
pub fn LessThan(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, ((op1 < op2) as u32).to_be_bytes());
vm.Walk(3);
true
}
pub fn LessEquals(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, ((op1 <= op2) as u32).to_be_bytes());
vm.Walk(3);
true
}
pub fn GreaterThan(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, ((op1 > op2) as u32).to_be_bytes());
vm.Walk(3);
true
}
pub fn GreaterEquals(vm: &mut Machine) -> bool {
let reg = vm.ReadByte(None);
let reg1 = vm.ReadByte(None);
let op1 = u32::from_be_bytes(vm.registry.Get(reg1));
let reg2 = vm.ReadByte(None);
let op2 = u32::from_be_bytes(vm.registry.Get(reg2));
vm.registry.Set(reg, ((op1 >= op2) as u32).to_be_bytes());
vm.Walk(3);
true
}
pub fn Halt(_: &mut Machine) -> bool {
false
}