Skip to main content

TEEC_OpenSession

Function TEEC_OpenSession 

Source
#[unsafe(no_mangle)]
pub extern "C" fn TEEC_OpenSession( ctx: *mut TEEC_Context, session: *mut TEEC_Session, destination: *const TEEC_UUID, connection_method: u32, _connection_data: *const c_void, operation: *mut TEEC_Operation, ret_origin: *mut u32, ) -> TEEC_Result
Expand description

TEEC_OpenSession() - 与指定的受信任应用打开一个新会话。

@param ctx 已初始化的 TEE 上下文,在其作用域内打开会话。 @param session 要初始化的会话结构体指针。 @param destination 标识要打开会话的受信任应用的 UUID 结构。 @param connection_method 要使用的连接方法。 @param connection_data 与所选连接方法有关的连接数据。本实现不支持, 应设置为 NULL。 @param operation 用于会话的操作结构。若不需要则传入 NULL。 @param ret_origin 若函数返回非 TEEC_SUCCESS,此参数将保存错误来源。

@return TEEC_SUCCESS 成功打开会话。 @return TEEC_Result 出现错误。

Examples found in repository?
examples/cc-teec.rs (lines 78-86)
66    fn new(uuid: &raw::TEEC_UUID) -> Result<Self> {
67        // SAFETY: `TEEC_Context` 和 `TEEC_Session` 是 POD 类型,没有无效的位模式。
68        // `mem::zeroed()` 在这里是安全的,因为这些结构体只包含整数和指针。
69        let mut ctx: Box<raw::TEEC_Context> = Box::new(unsafe { mem::zeroed() });
70        let mut session: raw::TEEC_Session = unsafe { mem::zeroed() };
71        let mut origin = 0_u32;
72
73        let res = TEEC_InitializeContext(ptr::null(), ctx.as_mut());
74        if res != raw::TEEC_SUCCESS {
75            return Err(Error::from_raw_os_error(res as i32));
76        }
77
78        let res = TEEC_OpenSession(
79            ctx.as_mut(),
80            &mut session,
81            uuid,
82            raw::TEEC_LOGIN_PUBLIC,
83            ptr::null(),
84            ptr::null_mut(),
85            &mut origin,
86        );
87
88        if res != raw::TEEC_SUCCESS {
89            TEEC_FinalizeContext(ctx.as_mut());
90            return Err(Error::from_raw_os_error(res as i32));
91        }
92
93        Ok(Self { ctx, session })
94    }