Compiler Support for Speculation in Decoupled Access/Execute Architectures
University of Glasgow, Glasgow, United Kingdom
arXiv:2501.13553 [cs.PF], (23 Jan 2025)
@article{szafarczyk2025compiler,
title={Compiler Support for Speculation in Decoupled Access/Execute Architectures},
author={Szafarczyk, Robert and Nabi, Syed Waqar and Vanderbauwhede, Wim},
journal={arXiv preprint arXiv:2501.13553},
year={2025}
}
Irregular codes are bottlenecked by memory and communication latency. Decoupled access/execute (DAE) is a common technique to tackle this problem. It relies on the compiler to separate memory address generation from the rest of the program, however, such a separation is not always possible due to control and data dependencies between the access and execute slices, resulting in a loss of decoupling. In this paper, we present compiler support for speculation in DAE architectures that preserves decoupling in the face of control dependencies. We speculate memory requests in the access slice and poison mis-speculations in the execute slice without the need for replays or synchronization. Our transformation works on arbitrary, reducible control flow and is proven to preserve sequential consistency. We show that our approach applies to a wide range of architectural work on CPU/GPU prefetchers, CGRAs, and accelerators, enabling DAE on a wider range of codes than before.
February 10, 2025 by hgpu