Publication: Reusetracker: fast yet accurate multicore reuse distance analyzer
dc.contributor.coauthor | Chabbi, Milind | |
dc.contributor.department | Department of Computer Engineering | |
dc.contributor.department | Graduate School of Sciences and Engineering | |
dc.contributor.kuauthor | Erten, Didem Unat | |
dc.contributor.kuauthor | Marzijarani, Mandana Bagheri | |
dc.contributor.kuauthor | Sasongko, Muhammad Aditya | |
dc.contributor.schoolcollegeinstitute | College of Engineering | |
dc.contributor.schoolcollegeinstitute | GRADUATE SCHOOL OF SCIENCES AND ENGINEERING | |
dc.date.accessioned | 2024-11-09T23:00:48Z | |
dc.date.issued | 2022 | |
dc.description.abstract | One widely used metric that measures data locality is reuse distance-the number of unique memory locations that are accessed between two consecutive accesses to a particular memory location. State-of-the-art techniques that measure reuse distance in parallel applications rely on simulators or binary instrumentation tools that incur large performance and memory overheads. Moreover, the existing sampling-based tools are limited to measuring reuse distances of a single thread and discard interactions among threads in multi-threaded programs. In this work, we propose REUSETRACKER a fast and accurate reuse distance analyzer that lever-ages existing hardware features in commodity CPUs. REUSETRACKER is designed for multi-threaded programs and takes cache-coherence effects into account. By utilizing hardware features like performance monitoring units and debug registers, REUSETRACKER can accurately profile reuse distance in parallel applications with much lower overheads than existing tools. It introduces only 2.9x runtime and 2.8x memory overheads. Our tool achieves 92% accuracy when verified against a newly developed configurable benchmark that can generate a variety of different reuse distance patterns. We demonstrate the tool's functionality with two use-case scenarios using PARSEC, Rodinia, and Synchrobench benchmark suites where REUSETRACKER guides code refactoring in these benchmarks by detecting spatial reuses in shared caches that are also false sharing and successfully predicts whether some benchmarks in these suites can benefit from adjacent cache line prefetch optimization. | |
dc.description.indexedby | WOS | |
dc.description.indexedby | Scopus | |
dc.description.issue | 1 | |
dc.description.openaccess | YES | |
dc.description.publisherscope | International | |
dc.description.sponsoredbyTubitakEu | TÜBİTAK | |
dc.description.sponsorship | Scientific and Technological Research Council of Turkey (TUBITAK) [120E492] | |
dc.description.sponsorship | Royal Society-Newton Advanced Fellowship The work is supported by the Scientific and Technological Research Council of Turkey (TUBITAK), Grant No. 120E492. Dr. Didem Unat is supported by the Royal Society-Newton Advanced Fellowship. | |
dc.description.volume | 19 | |
dc.identifier.doi | 10.1145/3484199 | |
dc.identifier.eissn | 1544-3973 | |
dc.identifier.issn | 1544-3566 | |
dc.identifier.scopus | 2-s2.0-85127188216 | |
dc.identifier.uri | https://doi.org/10.1145/3484199 | |
dc.identifier.uri | https://hdl.handle.net/20.500.14288/8127 | |
dc.identifier.wos | 771937000003 | |
dc.keywords | Reuse distance | |
dc.keywords | Hardware performance counters | |
dc.keywords | Debug registers | |
dc.keywords | Address sampling | |
dc.language.iso | eng | |
dc.publisher | Assoc Computing Machinery | |
dc.relation.ispartof | ACM Transactions on Architecture and Code Optimization | |
dc.subject | Computer science | |
dc.subject | Computer architecture | |
dc.title | Reusetracker: fast yet accurate multicore reuse distance analyzer | |
dc.type | Journal Article | |
dspace.entity.type | Publication | |
local.contributor.kuauthor | Sasongko, Muhammad Aditya | |
local.contributor.kuauthor | Marzijarani, Mandana Bagheri | |
local.contributor.kuauthor | Erten, Didem Unat | |
local.publication.orgunit1 | College of Engineering | |
local.publication.orgunit1 | GRADUATE SCHOOL OF SCIENCES AND ENGINEERING | |
local.publication.orgunit2 | Department of Computer Engineering | |
local.publication.orgunit2 | Graduate School of Sciences and Engineering | |
relation.isOrgUnitOfPublication | 89352e43-bf09-4ef4-82f6-6f9d0174ebae | |
relation.isOrgUnitOfPublication | 3fc31c89-e803-4eb1-af6b-6258bc42c3d8 | |
relation.isOrgUnitOfPublication.latestForDiscovery | 89352e43-bf09-4ef4-82f6-6f9d0174ebae | |
relation.isParentOrgUnitOfPublication | 8e756b23-2d4a-4ce8-b1b3-62c794a8c164 | |
relation.isParentOrgUnitOfPublication | 434c9663-2b11-4e66-9399-c863e2ebae43 | |
relation.isParentOrgUnitOfPublication.latestForDiscovery | 8e756b23-2d4a-4ce8-b1b3-62c794a8c164 |