Intel Architecture Code Analyzer (IACA) est un outil d'analyse statique puissant qui fournit des informations précieuses sur la planification des instructions exécutées sur les ordinateurs modernes. Processeurs Intel. Malgré son statut de fin de vie en 2019, IACA reste une ressource utile pour analyser les performances du code.
IACA permet l'analyse du code en assembleur C/C ou x86. Il fonctionne selon trois modes :
Pour analyser le code avec IACA, vous devez injecter des marqueurs dans le compilé binaire.
C/C :
#include "iacaMarks.h" while (cond) { IACA_START /* Loop body */ /* ... */ } IACA_END
Assemblage (x86) :
; NASM usage of IACA mov ebx, 111 ; Start marker bytes db 0x64, 0x67, 0x90 ; Start marker bytes .innermostlooplabel: ; Loop body ; ... jne .innermostlooplabel ; Conditional branch backwards to top of loop mov ebx, 222 ; End marker bytes db 0x64, 0x67, 0x90 ; End marker bytes
IACA génère des rapports textuels et des diagrammes Graphviz qui détaillent l’analyse du planning. Ces rapports mettent en évidence les goulots d'étranglement potentiels dans l'exécution des instructions. Par exemple, le résultat suivant d'une analyse de processeur Haswell identifie les ports frontaux et AGU comme des goulots d'étranglement en termes de performances :
Throughput Analysis Report -------------------------- Block Throughput: 1.55 Cycles Throughput Bottleneck: FrontEnd, PORT2_AGU, PORT3_AGU
IACA a quelques limitations :
Malgré ses limites, l'IACA fournit des informations précieuses sur la planification des instructions et peut aider à optimiser les performances du code. Cependant, pour une analyse plus récente, pensez à utiliser un outil alternatif, tel que LLVM-MCA.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!