A Data Structure Centric Method and Execution Model for Partitioning Sequential Programs into Multiple Speculative Threads

Yanning Du,Yinliang Zhao,Bo Han,Yuancheng Li
DOI: https://doi.org/10.1109/HPCC.2012.81
2012-01-01
Abstract:Speculative Multithreading (SpMT) approaches have gained wide popularity because they can get more parallelism by allowing two pieces of potentially conflicting code to execute in parallel while ensuring the correctness of the results by recovering from conflicts. However, the dividing-along-the-control-flow-path method employed by the traditional SpMT approach is unsuitable for a number of programs in which operations on different data structures are interleaved in the control flow path. If we linearly divide the program into threads along the control flow path, the operations on the same data structure will be divided among the different threads that are doomed to be prone to conflict when being executed concurrently. To effectively parallelize these programs, we proposed a data structure centric approach, in which the objects of a program are organized into different groups and the operations on the objects within the same group are dispatched to the same thread to be executed, thereby reducing the likelihood of conflict on the same data structure.
What problem does this paper attempt to address?