发明名称 Load Lookahead Prefetch for Microprocessors
摘要 The present invention allows a microprocessor to identify and speculatively execute future load instructions during a stall condition. This allows forward progress to be made through the instruction stream during the stall condition which would otherwise cause the microprocessor or thread of execution to be idle. The data for such future load instructions can be prefetched from a distant cache or main memory such that when the load instruction is re-executed (non speculative executed) after the stall condition expires, its data will reside either in the L1 cache, or will be enroute to the processor, resulting in a reduced execution latency. When an extended stall condition is detected, load lookahead prefetch is started allowing speculative execution of instructions that would normally have been stalled. In this speculative mode, instruction operands may be invalid due to source loads that miss the L1 cache, facilities not available in speculative execution mode, or due to speculative instruction results that are not available via forwarding and are not written to the architected registers. A set of status bits are used to dynamically keep track of the dependencies between instructions in the pipeline and a bit vector tracks invalid architected facilities with respect to the speculative instruction stream. Both sources of information are used to identify load instructions with valid operands for calculating the load address. If the operands are valid, then a load prefetch operation is started to retrieve data from the cache ahead of time such that it can be available for the load instruction when it is non-speculatively executed.
申请公布号 US2008077776(A1) 申请公布日期 2008.03.27
申请号 US20070950495 申请日期 2007.12.05
申请人 EICKEMEYER RICHARD J;LE HUNG Q;NGUYEN DUNG Q;STOLT BENJAMIN W;THOMPTO BRIAN W 发明人 EICKEMEYER RICHARD J.;LE HUNG Q.;NGUYEN DUNG Q.;STOLT BENJAMIN W.;THOMPTO BRIAN W.
分类号 G06F9/38 主分类号 G06F9/38
代理机构 代理人
主权项
地址