specifyng wrapping add
This commit is contained in:
@@ -309,7 +309,7 @@ fn op2(s: &str, n: usize, l: &str) -> Op2 {
|
||||
"r15" => 15,
|
||||
_ => match parse_int::parse::<i64>(s) {
|
||||
Ok(v) => {
|
||||
if -0xFFFF <= v && v <= 0xFFFF {
|
||||
if -0x10000 <= v && v <= 0xFFFF {
|
||||
return Op2::Direct(v as i32);
|
||||
} else {
|
||||
println!("Error: constant {s} is too large to fit in {l} at line {n}");
|
||||
|
||||
@@ -266,7 +266,7 @@ impl<'a, 'b> Computer<'a, 'b> {
|
||||
self.pc += 1
|
||||
}
|
||||
Instruction::Store(reg, op2, reg1) => {
|
||||
let addr = (self.rg_r(reg) + self.resolve(op2)) as usize;
|
||||
let addr = (self.rg_r(reg).wrapping_add(self.resolve(op2))) as usize;
|
||||
if !addr.is_multiple_of(4) {
|
||||
iot();
|
||||
}
|
||||
@@ -287,7 +287,7 @@ impl<'a, 'b> Computer<'a, 'b> {
|
||||
self.pc += 1;
|
||||
}
|
||||
Instruction::Load(reg, reg1, op2) => {
|
||||
let addr = (self.rg_r(reg1) + self.resolve(op2)) as usize;
|
||||
let addr = (self.rg_r(reg1).wrapping_add(self.resolve(op2))) as usize;
|
||||
if !addr.is_multiple_of(4) {
|
||||
iot();
|
||||
}
|
||||
@@ -306,8 +306,10 @@ impl<'a, 'b> Computer<'a, 'b> {
|
||||
res
|
||||
} else if addr == 0x01200000 {
|
||||
self.key.load(std::sync::atomic::Ordering::Relaxed)
|
||||
} else if addr == 0x01200004{
|
||||
time::Instant::now().duration_since(self.creation).as_millis() as u32
|
||||
} else if addr == 0x01200004 {
|
||||
time::Instant::now()
|
||||
.duration_since(self.creation)
|
||||
.as_millis() as u32
|
||||
} else {
|
||||
iot();
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user