Intel SGX开发入门

sgx定义文件*.edl

enclave {

	/*引用外部.edl*/
	from "sgx_tstdc.edl" import *;
	
	/*安全区函数接口定义*/
	trusted {
		public int sgx_sdkinit([in,size=iplen] unsigned char *ip,size_t iplen,[in,size=portlen] unsigned char *port, size_t portlen);
	};

	/*非安全区函数接口定义*/
	untrusted {
		void ocall_print_string([in, string] const char *str);        
	};

};

初始化安全区

//ENCLAVE_FILE为安全动态库,可使用绝对路径
sgx_create_enclave(ENCLAVE_FILE, SGX_DEBUG_FLAG, &token, &token_updated, &eid, NULL);

释放安全区

sgx_destroy_enclave(eid);

安全区函数调用

//有返回值的char *类型,对应的长度要传入字符串真实sizeof长度,如传入0则在sgx中未申请空间变为NULL
sgx_sdkinit(eid,&i_ret,ip,iplen,port,portlen);

芯片真随机数及密封密钥加解密

sgx_read_rand		随机数
		sgx_read_rand(buf, buflen);
sgx_seal_data		密封密钥加密
		sgx_seal_data(0, NULL, key_len, key_buf, seal_len, (sgx_sealed_data_t*)seal_data);
sgx_unseal_data		密封密钥解密
		sgx_unseal_data((sgx_sealed_data_t*)seal_data, NULL, NULL, unseal_key, &len);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值