DocumentCode
2363803
Title
Out-of-order instruction fetch using multiple sequencers
Author
Oberoi, Paramjit ; Sohi, Gurindar
Author_Institution
Dept. of Comput. Sci., Wisconsin Univ., Madison, WI, USA
fYear
2002
fDate
2002
Firstpage
14
Lastpage
23
Abstract
Conventional instruction fetch mechanisms fetch contiguous blocks of instructions in each cycle. They are difficult to scale since taken branches make it hard to increase the size of these blocks beyond eight instructions. Trace caches have been proposed as a solution to this problem, but they use cache space inefficiently. We show that fetching large blocks of contiguous instructions, or wide fetch, is inefficient for modern out-of-order processors. Instead of the usual approach of fetching large blocks of instructions from a single point in the program, we propose a high-bandwidth fetch mechanism that fetches small blocks of instructions from multiple points in a program. In this paper, we demonstrate that it is possible to achieve high-bandwidth fetch by using multiple narrow fetch units operating in parallel. Our mechanism performs as well as a trace cache, does not waste cache space, is more resilient to instruction cache misses, and is a natural fit for techniques that require fetching multiple threads, like multithreading, dual-path execution, and speculative threads.
Keywords
cache storage; multi-threading; contiguous instructions; dual-path execution; high-bandwidth fetch mechanism; instruction cache misses; multiple narrow fetch units; multiple sequencers; multiple threads; multithreading; out-of-order instruction fetch; speculative threads; trace cache; Bandwidth; Computer aided instruction; Multithreading; Out of order; Parallel processing; Yarn;
fLanguage
English
Publisher
ieee
Conference_Titel
Parallel Processing, 2002. Proceedings. International Conference on
ISSN
0190-3918
Print_ISBN
0-7695-1677-7
Type
conf
DOI
10.1109/ICPP.2002.1040855
Filename
1040855
Link To Document