如何找出内存访问粒度

How to find out memory access granularity?

本文关键字:粒度 访问 内存 何找出      更新时间:2023-10-16

我已经阅读了这篇关于对齐的文章:http://www.ibm.com/developerworks/library/pa-dalign/

出现的问题是,如何找出特定处理器的内存访问粒度?

例如英特尔至强。不幸的是,当我尝试"内存访问粒度英特尔至强"或"内存对齐英特尔至强"时,谷歌对我没有帮助。

对于至强,请查看英特尔优化手册(谷歌)。粗略地说,体系结构希望数据类型与其大小或处理器的本机宽度中的较大值对齐。所以 x86 需要 4 字节对齐,但__m128应该是 16 字节对齐。x64 需要 8 字节对齐。不过,这不是一个硬性规定,因为一些 64 位架构只关心 4 字节对齐。

还有一件事:至强是一个商标,而不是一个架构。事实上,已经有多种架构作为至强销售。因此,"内存对齐英特尔至强"不会给您太多;"内存对齐x64"会给你很多。在同一架构的多个实现中,内存对齐要求将几乎相同。