1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
use crate::{
handles::KeyHandle,
structures::{Data, PcrSelectionList},
tss2_esys::*,
utils::Signature,
Context, Error, Result,
};
use log::error;
use mbox::MBox;
use std::ptr::null_mut;
impl Context {
pub fn quote(
&mut self,
signing_key_handle: KeyHandle,
qualifying_data: &Data,
signing_scheme: TPMT_SIG_SCHEME,
pcr_selection_list: PcrSelectionList,
) -> Result<(TPM2B_ATTEST, Signature)> {
let mut quoted = null_mut();
let mut signature = null_mut();
let ret = unsafe {
Esys_Quote(
self.mut_context(),
signing_key_handle.into(),
self.optional_session_1(),
self.optional_session_2(),
self.optional_session_3(),
&qualifying_data.clone().into(),
&signing_scheme,
&pcr_selection_list.into(),
&mut quoted,
&mut signature,
)
};
let ret = Error::from_tss_rc(ret);
if ret.is_success() {
let quoted = unsafe { MBox::<TPM2B_ATTEST>::from_raw(quoted) };
let signature = unsafe { MBox::from_raw(signature) };
Ok((*quoted, unsafe { Signature::try_from(*signature)? }))
} else {
error!("Error in quoting PCR: {}", ret);
Err(ret)
}
}
}