如何在英特尔 SGX 围圈内实施动态加载
How to implement dynamic loading inside an Intel SGX Enclave?
因为英特尔 SGX 围圈内不能使用任何标准库。如何在安全区内实现动态加载?例如,我在扩展名为 .so 的文件中foo1()
和foo2()
函数。
我需要在安全区内动态加载一个函数。然后,Enclave 外部的主函数可以调用加载的函数。
应用.cpp
status = ecall_dynamicLoading(enclave_id,func);
// func is a function pointer loaded from .so
// for example, func = &foo1;
飞地.cpp
ecall_dynamicLoading(func){
(*func)(/* some inputs */);
}
可能吗?
谢谢。
根据英特尔自己的文档,您无法在 ENCLAVE 内加载shared_object (.so(。您需要将其转换为静态库。
https://software.intel.com/en-us/node/708963https://software.intel.com/en-us/node/708964
即便如此,静态库也有很多限制。
相关文章:
- std::向量与传递值的动态数组
- 在c++中用vector填充一个简单的动态数组
- C++中的动态铸造故障
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 使用动态分配的数组会导致代码分析发出虚假的C6386缓冲区溢出警告
- 控制允许动态运行c++的并发操作数
- 如何将这个C++哈希表转换为动态扩展和收缩,而不是使用硬设置的最大值
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 输出没有重复元素的动态数组(收缩数组)C++
- C++为线程工作动态地分割例程
- 正在插入动态数组
- 在c++中使用动态分配的问题
- C++中的动态对象与非动态对象
- 如何在动态数组上使用搜索函数
- 视觉studo 2019中的漫画和静态/动态绑定
- 从C++中的数字输入动态创建矩阵
- 如何从QToolBox中动态创建的QLineEdit中获取文本
- C++ 动态数组每次添加时将大小增加 1 - 错误
- C 将1D动态数组施放到2D数组以使用常规索引(例如ARR [i] [J])