Sie befinden Sich nicht im Netzwerk der Universität Paderborn. Der Zugriff auf elektronische Ressourcen ist gegebenenfalls nur via VPN oder Shibboleth (DFN-AAI) möglich. mehr Informationen...
Ergebnis 3 von 271
Proceedings of ACM on programming languages, 2022-10, Vol.6 (OOPSLA2), p.1-29
2022
Volltextzugriff (PDF)

Details

Autor(en) / Beteiligte
Titel
AnICA: analyzing inconsistencies in microarchitectural code analyzers
Ist Teil von
  • Proceedings of ACM on programming languages, 2022-10, Vol.6 (OOPSLA2), p.1-29
Erscheinungsjahr
2022
Quelle
EZB Electronic Journals Library
Beschreibungen/Notizen
  • Microarchitectural code analyzers, i.e., tools that estimate the throughput of machine code basic blocks, are important utensils in the tool belt of performance engineers. Recent tools like llvm-mca, uiCA, and Ithemal use a variety of techniques and different models for their throughput predictions. When put to the test, it is common to see these state-of-the-art tools give very different results. These inconsistencies are either errors, or they point to different and rarely documented assumptions made by the tool designers. In this paper, we present AnICA, a tool taking inspiration from differential testing and abstract interpretation to systematically analyze inconsistencies among these code analyzers. Our evaluation shows that AnICA can summarize thousands of inconsistencies in a few dozen descriptions that directly lead to high-level insights into the different behavior of the tools. In several case studies, we further demonstrate how AnICA automatically finds and characterizes known and unknown bugs in llvm-mca, as well as a quirk in AMD's Zen microarchitectures.
Sprache
Englisch
Identifikatoren
ISSN: 2475-1421
eISSN: 2475-1421
DOI: 10.1145/3563288
Titel-ID: cdi_crossref_primary_10_1145_3563288
Format

Weiterführende Literatur

Empfehlungen zum selben Thema automatisch vorgeschlagen von bX