A Tale of Three Runtimes

Nicolas Vasilache,Muthu Baskaran,Tom Henretty,Benoit Meister,M. Harper Langston,Sanket Tavarageri,Richard Lethin
DOI: https://doi.org/10.48550/arXiv.1409.1914
2014-09-06
Abstract:This contribution discusses the automatic generation of event-driven, tuple-space based programs for task-oriented execution models from a sequential C specification. We developed a hierarchical mapping solution using auto-parallelizing compiler technology to target three different runtimes relying on event-driven tasks (EDTs). Our solution benefits from the important observation that loop types encode short, transitive relations among EDTs that are compact and efficiently evaluated at runtime. In this context, permutable loops are of particular importance as they translate immediately into conservative point-to-point synchronizations of distance 1. Our solution generates calls into a runtime-agnostic C++ layer, which we have retargeted to Intel's Concurrent Collections (CnC), ETI's SWARM, and the Open Community Runtime (OCR). Experience with other runtime systems motivates our introduction of support for hierarchical async-finishes in CnC. Experimental data is provided to show the benefit of automatically generated code for EDT-based runtimes as well as comparisons across runtimes.
Distributed, Parallel, and Cluster Computing,Programming Languages
What problem does this paper attempt to address?