MIPS上C++和汇编代码的微架构分析

Microarchitectural profiling of C++ and assembly code on MIPS

本文关键字:代码 C++ 汇编 MIPS      更新时间:2023-10-16

作为课程项目的一部分,我需要分析一段C++代码的性能,并找出计算机体系结构的哪些部分(MIPS或x86)在运行代码时被最常使用,并且可能是性能的瓶颈。我正在寻找用于分析性能的各种分析器,并遇到了 SimpleScalar,这是一个很棒的工具,但遗憾的是仅适用于 C 代码。

由于我更熟悉MIPS架构,如果有像SimpleScalar这样的工具来模拟和分析MIPS的C++代码,那就太好了。我正在查看性能关键部分,如分支、缓存、指令集、寻址模式等。如果没有,提及任何可以为x86架构进行类似分析的工具也会很棒。

(澄清一下,我不是在寻找任何旧的分析器,而是寻找了解 CPU 微体系结构并知道 CPU 的哪些部分被利用或未充分利用的分析器。

CACTI 对缓存进行了详细的低级模拟。

SESC是一个支持MIPS的周期精确的计算机架构模拟器。SESC包括CACTI。

我怀疑你想要的是否可能。 C++是语言,但仍需要编译为目标体系结构。 优化(或缺乏优化)将决定您的许多性能标准,例如缓存使用等。 所以我想你需要寻找机器级别的分析器(希望它们支持编译器的调试格式,所以你会看到源代码上下文)。

我的理解是,SimpleScalar可以模拟和剖析MIPS机器代码,无论它是用什么原始语言编译的。(SimpleScalar 附带的源代码级调试器"DLite!"可能只支持几种语言,但听起来你不需要"调试"你的代码。