From ba2ec57eae26724ebd0c2e760781dc35418a1e4b Mon Sep 17 00:00:00 2001 From: Brian Smith Date: Tue, 31 Dec 2024 16:04:40 -0800 Subject: [PATCH] inout: Avoid implicit conversions to `error::Unspecified`. --- src/aead/aes_gcm.rs | 10 +++++++--- src/inout/overlapping/base.rs | 7 ------- src/inout/overlapping/mod.rs | 2 +- 3 files changed, 8 insertions(+), 11 deletions(-) diff --git a/src/aead/aes_gcm.rs b/src/aead/aes_gcm.rs index b4bd6234e..566912ff1 100644 --- a/src/aead/aes_gcm.rs +++ b/src/aead/aes_gcm.rs @@ -18,6 +18,7 @@ use super::{ }; use crate::{ cpu, error, + inout::overlapping::SrcIndexError, polyfill::{slice, sliceutil::overwrite_at_start, usize_from_u64_saturated}, }; use core::ops::RangeFrom; @@ -276,7 +277,8 @@ pub(super) fn open( src: RangeFrom, ) -> Result { #[cfg(any(target_arch = "aarch64", target_arch = "x86_64"))] - let in_out = Overlapping::new(in_out_slice, src.clone())?; + let in_out = + Overlapping::new(in_out_slice, src.clone()).map_err(error::erase::)?; let mut ctr = Counter::one(nonce); let tag_iv = ctr.increment(); @@ -332,7 +334,8 @@ pub(super) fn open( let whole_len = slice::flatten(whole).len(); // Decrypt any remaining whole blocks. - let whole = Overlapping::new(&mut in_out[..(src.start + whole_len)], src.clone())?; + let whole = Overlapping::new(&mut in_out[..(src.start + whole_len)], src.clone()) + .map_err(error::erase::)?; aes_key.ctr32_encrypt_within(whole, &mut ctr); let in_out = match in_out.get_mut(whole_len..) { @@ -452,7 +455,8 @@ fn open_strided)?; aes_key.ctr32_encrypt_within(chunk, &mut ctr); output += chunk_len; input += chunk_len; diff --git a/src/inout/overlapping/base.rs b/src/inout/overlapping/base.rs index 25645dfca..dda091fb3 100644 --- a/src/inout/overlapping/base.rs +++ b/src/inout/overlapping/base.rs @@ -12,7 +12,6 @@ // OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN // CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -use crate::error; use core::ops::RangeFrom; pub struct Overlapping<'o, T> { @@ -63,9 +62,3 @@ impl SrcIndexError { Self(src) } } - -impl From for error::Unspecified { - fn from(_: SrcIndexError) -> Self { - Self - } -} diff --git a/src/inout/overlapping/mod.rs b/src/inout/overlapping/mod.rs index f8317d0f7..fb9bfb3d2 100644 --- a/src/inout/overlapping/mod.rs +++ b/src/inout/overlapping/mod.rs @@ -12,6 +12,6 @@ // OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN // CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. -pub use self::base::Overlapping; +pub use self::base::{Overlapping, SrcIndexError}; mod base;