blob: d517f530c1b94d2dd433d67d4d263e59801337bc [file] [log] [blame]
// Copyright (C) 2017-2018 Baidu, Inc. All Rights Reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in
// the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Baidu, Inc., nor the names of its
// contributors may be used to endorse or promote products derived
// from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
use sgx_rand::*;
use sgx_tseal::*;
use sgx_types::*;
use sgx_types::marker::*;
fn to_sealed_log<T: Copy + ContiguousMemory>(sealed_data: &SgxSealedData<T>,
sealed_log: * mut u8,
sealed_log_size: u32)
-> Option<* mut sgx_sealed_data_t> {
unsafe {
sealed_data.to_raw_sealed_data_t(sealed_log as * mut sgx_sealed_data_t, sealed_log_size)
}
}
fn from_sealed_log<'a, T: Copy + ContiguousMemory>(sealed_log: * mut u8, sealed_log_size: u32) -> Option<SgxSealedData<'a, T>> {
unsafe {
SgxSealedData::<T>::from_raw_sealed_data_t(sealed_log as * mut sgx_sealed_data_t, sealed_log_size)
}
}
pub fn test_seal_unseal () {
#[derive(Copy, Clone, Default, Debug)]
struct RandData {
key: u32,
rand: [u8; 16],
}
unsafe impl ContiguousMemory for RandData {}
let mut data = RandData::default();
data.key = 0x1234;
let mut rand = StdRng::new().unwrap();
rand.fill_bytes(&mut data.rand);
let aad: [u8; 0] = [0_u8; 0];
let sealed_data = SgxSealedData::<RandData>::seal_data(&aad, &data).unwrap();
let mut sealed_log_arr:[u8;2048] = [0;2048];
let sealed_log = sealed_log_arr.as_mut_ptr();
let sealed_log_size : u32 = 2048;
let opt = to_sealed_log(&sealed_data, sealed_log, sealed_log_size);
assert_eq!(opt.is_some(), true);
let sealed_data = from_sealed_log::<RandData>(sealed_log, sealed_log_size).unwrap();
let unsealed_data = sealed_data.unseal_data().unwrap();
let udata = unsealed_data.get_decrypt_txt();
assert_eq!(data.key, udata.key);
assert_eq!(data.rand, udata.rand);
}
pub fn test_number_sealing() {
let data: u64 = 123456789;
let aad: [u8; 0] = [0_u8; 0];
let sealed_data = SgxSealedData::<u64>::seal_data(&aad, &data).expect("error while sealing u64");
let unsealed_data = sealed_data.unseal_data().expect("error while unsealing u64");
assert_eq!(*unsealed_data.get_decrypt_txt(), data);
}
pub fn test_array_sealing() {
let data: [u8; 10] = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
let aad: [u8; 0] = [0_u8; 0];
let sealed_data = SgxSealedData::<[u8]>::seal_data(&aad, &data).expect("error while sealing array");
let unsealed_data = sealed_data.unseal_data().expect("error while unsealing array");
assert_eq!(unsealed_data.get_decrypt_txt(), data);
}
pub fn test_mac_aadata_number() {
use std::boxed::Box;
let aad_data : u64 = 123456789;
let mmac = SgxMacAadata::<u64>::mac_aadata(&aad_data).expect("error while mac data");
let unsealed_mac = mmac.unmac_aadata().expect("error when unmac data");
let inner = Box::into_raw(unsealed_mac);
let inner_val = unsafe { * (inner as *mut u64) };
assert_eq!(inner_val, aad_data);
}
pub fn test_mac_aadata_slice() {
use std::slice;
use std::boxed::Box;
let aad_data : [u8;10] = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
let mmac = SgxMacAadata::<[u8]>::mac_aadata(&aad_data).expect("error while mac data");
let unsealed_mac = mmac.unmac_aadata().expect("error when unmac data");
let inner = Box::into_raw(unsealed_mac);
let inner_slice = unsafe {slice::from_raw_parts(inner as *mut u8, 10)};
assert_eq!(inner_slice, aad_data);
}