[go: up one dir, main page]

seckey 0.7.3

Use `memsec` protected secret memory.
Documentation
//! Use [memsec](https://github.com/quininer/memsec) protected secret memory.

extern crate memsec;

mod tempkey;
mod bytes;
mod seckey;

use std::mem;
use memsec::memzero;
pub use bytes::*;
pub use tempkey::*;
pub use seckey::*;


/// Zero a value
///
/// ```
/// use seckey::zero;
///
/// let mut v = [1, 2, 3];
/// zero(&mut v);
/// assert_eq!(v, [0, 0, 0]);
/// ```
pub fn zero<T: Copy>(t: &mut T) {
    unsafe { memzero(t, mem::size_of::<T>()) };
}

/// Zero a slice
///
/// ```
/// use seckey::zero_slice;
///
/// let v = &mut [1, 2, 3][..];
/// zero_slice(v);
/// assert_eq!(v, [0, 0, 0]);
/// ```
pub fn zero_slice<T: Copy>(t: &mut [T]) {
    unsafe { memzero(t.as_mut_ptr(), t.len() * mem::size_of::<T>()) };
}