From 4a4e63c30f6db5678f3e6033270a0894d421d39b Mon Sep 17 00:00:00 2001 From: Lonami Exo Date: Fri, 1 Mar 2024 22:10:40 +0100 Subject: [PATCH] Use individual boxed slices in HashBuffers --- miniz_oxide/src/deflate/buffer.rs | 19 ++++++++++++------- miniz_oxide/src/deflate/core.rs | 4 ++-- 2 files changed, 14 insertions(+), 9 deletions(-) diff --git a/miniz_oxide/src/deflate/buffer.rs b/miniz_oxide/src/deflate/buffer.rs index f246c07d..110836c9 100644 --- a/miniz_oxide/src/deflate/buffer.rs +++ b/miniz_oxide/src/deflate/buffer.rs @@ -2,6 +2,9 @@ //! to avoid stack copies. Box::new() doesn't at the moment, and using a vec means we would lose //! static length info. +use alloc::boxed::Box; +use alloc::vec; + use crate::deflate::core::{LZ_DICT_SIZE, MAX_MATCH_LEN}; /// Size of the buffer of lz77 encoded data. @@ -23,24 +26,26 @@ pub fn update_hash(current_hash: u16, byte: u8) -> u16 { } pub struct HashBuffers { - pub dict: [u8; LZ_DICT_FULL_SIZE], - pub next: [u16; LZ_DICT_SIZE], - pub hash: [u16; LZ_DICT_SIZE], + pub dict: Box<[u8]>, + pub next: Box<[u16]>, + pub hash: Box<[u16]>, } impl HashBuffers { #[inline] pub fn reset(&mut self) { - *self = HashBuffers::default(); + self.dict.fill(0); + self.next.fill(0); + self.hash.fill(0); } } impl Default for HashBuffers { fn default() -> HashBuffers { HashBuffers { - dict: [0; LZ_DICT_FULL_SIZE], - next: [0; LZ_DICT_SIZE], - hash: [0; LZ_DICT_SIZE], + dict: vec![0; LZ_DICT_FULL_SIZE].into_boxed_slice(), + next: vec![0; LZ_DICT_SIZE].into_boxed_slice(), + hash: vec![0; LZ_DICT_SIZE].into_boxed_slice(), } } } diff --git a/miniz_oxide/src/deflate/core.rs b/miniz_oxide/src/deflate/core.rs index b0a532dc..79cdeb44 100644 --- a/miniz_oxide/src/deflate/core.rs +++ b/miniz_oxide/src/deflate/core.rs @@ -1195,7 +1195,7 @@ struct DictOxide { pub max_probes: [u32; 2], /// Buffer of input data. /// Padded with 1 byte to simplify matching code in `compress_fast`. - pub b: Box, + pub b: HashBuffers, pub code_buf_dict_pos: usize, pub lookahead_size: usize, @@ -1214,7 +1214,7 @@ impl DictOxide { fn new(flags: u32) -> Self { DictOxide { max_probes: probes_from_flags(flags), - b: Box::default(), + b: HashBuffers::default(), code_buf_dict_pos: 0, lookahead_size: 0, lookahead_pos: 0,