微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

推测执行和 malloc

如何解决推测执行和 malloc

在阅读了 Spectre & Meltdown 漏洞之后,我了解了推测执行。

给定以下简单的 C++ 程序:

#include <stdlib.h>

void mallocBranch(int i) {
   if (i < 500) {
      malloc(i);
   }
}

int main(int argc,char** argv){
   for (i := 0; i < 5000; i++) {
      mallocBranch(1);
   }
   mallocBranch(500000000);

   return 0;
}
  • 我假设编译器没有优化 malloc 调用

问:调用 mallocBranch(500000000) 时会发生什么? cpu 会查看分支预测缓存并看到过去对 if (i < 500)调用成功并推测性地执行带有 malloc(500000000) 的分支吗? malloc 中的分支数量会不会每次都覆盖分支预测缓存的全部内容?如果 malloc(500000000) 实际上是推测执行的,是否会为进程分配 5 亿字节的内存,如果只是暂时的?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。