Issue No. 09 - September (1999 vol. 48)
DOI Bookmark: http://doi.ieeecomputersociety.org/10.1109/12.795219
<p><b>Abstract</b>—The common single-threaded execution model limits processors to exploiting only the relatively small amount of instruction-level parallelism available in application programs. The <it>superthreaded processor</it>, on the other hand, is a concurrent multithreaded architecture (CMA) that can exploit the multiple granularities of parallelism available in general-purpose application programs. Unlike other CMAs that rely primarily on hardware for run-time dependence detection and speculation, the superthreaded processor combines compiler-directed thread-level speculation of control and data dependences with run-time data dependence verification hardware. This hybrid of a superscalar processor and a multiprocessor-on-a-chip can utilize many of the existing compiler techniques used in traditional parallelizing compilers developed for multiprocessors. Additional unique compiler techniques, such as the conversion of data speculation into control speculation, are also introduced to generate the superthreaded code and to enhance the parallelism between threads. A detailed execution-driven simulator is used to evaluate the performance potential of this new architecture. It is found that a superthreaded processor can achieve good performance on complex application programs through this close coupling of compile-time and run-time information.</p>
Multithreading, run-time dependence checking, speculation, compilers, performance evaluation.
J. Tsai, D. J. Lilja, C. Amlo, P. Yew and J. Huang, "The Superthreaded Processor Architecture," in IEEE Transactions on Computers, vol. 48, no. , pp. 881-902, 1999.