mirror of
https://git.um-react.app/um/lib_um_crypto_rust.git
synced 2026-03-08 04:29:54 +00:00
[kgm/ncm/kwm] refactor: improve performance for large file
This commit is contained in:
@@ -15,9 +15,8 @@ impl DecipherV2 {
|
||||
|
||||
impl Decipher for DecipherV2 {
|
||||
fn decrypt(&self, buffer: &mut [u8], offset: usize) {
|
||||
let key_stream = self.key.iter().cycle().skip(offset % self.key.len());
|
||||
for (datum, &k) in buffer.iter_mut().zip(key_stream) {
|
||||
*datum ^= k;
|
||||
for (datum, offset) in buffer.iter_mut().zip(offset..) {
|
||||
*datum ^= self.key[offset % self.key.len()];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -25,34 +25,27 @@ impl DecipherV3 {
|
||||
|
||||
Ok(Self { slot_key, file_key })
|
||||
}
|
||||
|
||||
fn offset_key(offset: usize) -> u8 {
|
||||
let offset_key = (offset as u32).to_ne_bytes();
|
||||
offset_key[0] ^ offset_key[1] ^ offset_key[2] ^ offset_key[3]
|
||||
}
|
||||
}
|
||||
|
||||
impl Decipher for DecipherV3 {
|
||||
fn decrypt(&self, buffer: &mut [u8], offset: usize) {
|
||||
let slot_key_stream = self
|
||||
.slot_key
|
||||
.iter()
|
||||
.cycle()
|
||||
.skip(offset % self.slot_key.len());
|
||||
let file_key_stream = self
|
||||
.file_key
|
||||
.iter()
|
||||
.cycle()
|
||||
.skip(offset % self.file_key.len());
|
||||
for (datum, offset) in buffer.iter_mut().zip(offset..) {
|
||||
let offset_key = Self::offset_key(offset);
|
||||
|
||||
let mut offset = offset as u32;
|
||||
let key_stream = slot_key_stream.zip(file_key_stream);
|
||||
for (datum, (&slot_key, &file_key)) in buffer.iter_mut().zip(key_stream) {
|
||||
let offset_key = offset.to_ne_bytes().iter().fold(0, |acc, &x| acc ^ x);
|
||||
let file_key = self.file_key[offset % self.file_key.len()];
|
||||
let slot_key = self.slot_key[offset % self.slot_key.len()];
|
||||
|
||||
let mut temp = *datum;
|
||||
temp ^= file_key;
|
||||
temp ^= temp.wrapping_shl(4);
|
||||
temp ^= temp << 4;
|
||||
temp ^= slot_key;
|
||||
temp ^= offset_key;
|
||||
*datum = temp;
|
||||
|
||||
offset = offset.wrapping_add(1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user