Imperial College London > Talks@ee.imperial > CAS Talks > The Semantics of Shared Memory in CPU/FPGA Systems
Log inImperial users Other users No account?Information onFinding a talk Adding a talk Syndicating talks Who we are Everything else |
The Semantics of Shared Memory in CPU/FPGA SystemsAdd to your list(s) Download to your calendar using vCal
If you have a question about this talk, please contact George A Constantinides. Fundamental limits of hardware scaling mean that modern computing systems feature an increasing variety of heterogeneous parallel computing units. Applications must be partitioned across these units to run in a performant and energy-efficient manner. To run reliably, applications must issue sufficient synchronization operations when accessing shared memory. This is challenging: the rules governing shared-memory behaviour in modern systems are often under-specified, especially when compute-units expose a low-level interface to shared memory and are rarely specified in a formal manner that facilitates rigorous reasoning. Our work takes steps to address this by providing rigorous formal foundations for such emerging systems, to support programmers, compiler writers and designers of analysis tools in navigating the complexities of these systems and unlocking their potential efficiencies. As a case study, we focus on Intel platforms that combine Intel FPG As with multicore Xeon CPUs. Via a detailed study of documentation and empirical testing, we show that the low-level shared-memory interface for FPGA computations allows a variety of complex behaviours, e.g. allowing sequential computation streams to observe stale values. including many not seen in mainstream CPUs. This talk is part of the CAS Talks series. This talk is included in these lists:Note that ex-directory lists are not shown. |
Other listsMetamaterials isn_talks@ee.imperial Talks@ee.imperialOther talks |