sgx飞地内存测量工具

之前研究SGX的linux版本,感觉开发不太友好,转了window 10,visual studio 2017

EMMT的目的是使Windows开发人员能够测量其飞地的实际内存使用情况,以便他们可以相应地调整分配的值。

 

一、EMMT简介

EMMT应用程序是Intel SGX SDK的一部分。在安装完SGX SDK后系统中会有两个sgx_emmt.exe的版本,一个是32位,一个是64位,分别位于C:\Program Files (x86)\Intel\IntelSGXSDK\bin\win32\Release和C:\Program Files (x86)\Intel\IntelSGXSDK\bin\x64\Release目录下。32位的emmt只能测量x86的enclave程序,64位的emmt也只能测量x64的enclave程序,二者不能混着用。

EMMT在混合模式应用程序上不起作用。如果主应用程序是用.NET *编写的,则无法直接在最终应用程序上使用EMMT。需要编写一个本机前端应用程序,以根据要求对安全区进行压力测试。

sgx_emmt.exe的执行很简单:

sgx_emmt [ –-enclave=enclaves ] program [ arguments ... ]

--enclaves参数是可选的:如果应用程序有多个安全区,则可以列出要定位的一个或多个安全区。否则,EMMT会测量应用程序中的每个飞地。

应用程序退出后,EMMT将为每个测得的安全区打印内存使用情况摘要。下图显示了一个安全区的结果,该安全区在执行期间使用了2 KB的堆栈空间和4 KB的堆空间。

Enclave: "Enclave.signed.dll"
[Peak stack use]: 0x2KB
[Peak heap use]: 0x4KB

二、实例测试

使用VS2017编译SGX SDK安装目录下的SampleEnclave程序,我的拷贝到了别的目录,打开powershell程序,依次输入下面的命令,结果如下图所示:

cd D:\vs2017-source\repos\SampleEnclave\Debug

& "C:\Program Files (x86)\Intel\IntelSGXSDK\bin\win32\Release\sgx_emmt.exe" --enclave=Enclave.signed.dll App.exe

 

 

  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值