use crate::{exit, read_noise};
use super::Op;
#[derive(Debug)]
pub struct Xor {
b: u64,
}
impl Default for Xor {
fn default() -> Xor {
Xor {
b: 0b_01010101_01010101_01010101_01010101_01010101_01010101_01010101_01010101,
}
}
}
impl Op for Xor {
fn op(&mut self, addr: &mut u64, challenge: [u8; 32], nonce: [u8; 8], noise: &[u8]) -> bool {
self.update_state(addr, challenge, nonce, noise);
*addr ^= self.b;
self.update_state(addr, challenge, nonce, noise);
exit(addr)
}
fn update_state(&mut self, addr: &mut u64, challenge: [u8; 32], nonce: [u8; 8], noise: &[u8]) {
self.b ^=
self.b.rotate_right(1) ^ u64::from_le_bytes(read_noise(addr, challenge, nonce, noise));
}
}