Home Bio Publications Contact

Dual-thread Speculation: A Simple Approach to Uncover Thread-level Parallelism on a Simultaneous Multithreaded Processor
Authors: Fredrik Warg and Per Stenström
Abstract:

As chip multiprocessors with simultaneous multithreaded cores are becoming commonplace, there is a need for simple approaches to exploit thread-level parallelism. In this paper, we consider thread-level speculation as a means to reap thread-level parallelism out of application binaries. We first investigate the tradeoffs between scheduling speculative threads on the same core and on different cores. While threads contend for the same resources using the former approach, the latter approach is plagued by the overhead for inter-core communication. Despite the impact of resource contention, our detailed simulations show that the first approach provides the best performance due to lower inter-thread communication cost. The key contribution of the paper is the proposed design and evaluation of the dual-thread speculation system. This design point has very low complexity and reaps most of the gains of a system.

Keywords: Multiprocessors, chip-multiprocessors, thread-level speculation, module-level parallelism, misspeculation prediction, performance evaluation, dual-thread speculation
Year-Month: 2008-04
Published: International Journal of Parallel Programming (IJPP)
Publication type: Journal paper
Vol: 36 No: 2 Pages: 166--183
Bibtex:
@article{DualThreadSpeculationSimpleApproach_ijpp2008,
  title     = {Dual-thread Speculation: A Simple Approach to Uncover Thread-level Parallelism on a Simultaneous Multithreaded Processor},
  author    = {Warg, Fredrik and Stenström, Per},
  year      = {2008},
  month     = {04},
  abstract  = {As chip multiprocessors with simultaneous multithreaded cores are becoming commonplace, there is a need for simple approaches to exploit thread-level parallelism. In this paper, we consider thread-level speculation as a means to reap thread-level parallelism out of application binaries. We first investigate the tradeoffs between scheduling speculative threads on the same core and on different cores. While threads contend for the same resources using the former approach, the latter approach is plagued by the overhead for inter-core communication. Despite the impact of resource contention, our detailed simulations show that the first approach provides the best performance due to lower inter-thread communication cost. The key contribution of the paper is the proposed design and evaluation of the dual-thread speculation system. This design point has very low complexity and reaps most of the gains of a system.},
  keywords  = {Multiprocessors, chip-multiprocessors, thread-level speculation, module-level parallelism, misspeculation prediction, performance evaluation, dual-thread speculation},
  journal   = {International Journal of Parallel Programming (IJPP)},
  doi       = {10.1007/s10766-007-0064-z},
  volume    = {36},
  number    = {2},
  pages     = {166--183},
  note      = {Publication data: https://warg.org/fredrik/publ/}
}