请输入您要查询的百科知识:

 

词条 Memory-level parallelism
释义

  1. See also

  2. References

Memory-level parallelism (MLP) is a term in computer architecture referring to the ability to have pending multiple memory operations, in particular cache misses or translation lookaside buffer (TLB) misses, at the same time.

In a single processor, MLP may be considered a form of instruction-level parallelism (ILP). However, ILP is often conflated with superscalar, the ability to execute more than one instruction at the same time, e.g. a processor such as the Intel Pentium Pro is five-way superscalar, with the ability to start executing five different microinstructions in a given cycle, but it can handle four different cache misses for up to 20 different load microinstructions at any time.

It is possible to have a machine that is not superscalar but which nevertheless has high MLP.

Arguably a machine that has no ILP, which is not superscalar, which executes one instruction at a time in a non-pipelined manner, but which performs hardware prefetching (not software instruction-level prefetching) exhibits MLP (due to multiple prefetches outstanding) but not ILP. This is because there are multiple memory operations outstanding, but not instructions. Instructions are often conflated with operations.

Furthermore, multiprocessor and multithreaded computer systems may be said to exhibit MLP and ILP due to parallelism—but not intra-thread, single process, ILP and MLP. Often, however, we restrict the terms MLP and ILP to refer to extracting such parallelism from what appears to be non-parallel single threaded code.

See also

  • Memory disambiguation
  • Memory dependence prediction
  • Hardware scout
  • Runahead

References

  • {{Cite conference |last1=Glew |first1=A. |year=1998 |title=MLP yes! ILP no! |booktitle=ASPLOS Wild and Crazy Idea Session '98

|department=Wild and Crazy Ideas (WACI) I |conference=ASPLOS VIII |postscript=. (abstract / slides)}}
  • {{Cite journal |last1=Ronen |first1=R. |last2=Mendelson |first2=A. |last3=Lai |first3=K. |last4=Shih-Lien Lu |last5=Pollack |first5=F. |last6=Shen |first6=J. P. |year=2001 |title=Coming challenges in microarchitecture and architecture |journal=Proc. IEEE |volume=89 |issue=3 |pages=325–340 |citeseerx=10.1.1.136.5349 |doi=10.1109/5.915377}}
  • {{Cite conference |last1=Zhou |first1=H. |last2=Conte |first2=T. M. |year=2003 |title=Enhancing memory level parallelism via recovery-free value prediction |booktitle=Proceedings of the 17th annual international conference on Supercomputing |conference=ICS'03 |pages=326–335 |citeseerx=10.1.1.14.4405 |doi=10.1145/782814.782859 |isbn=1-58113-733-8}}
  • {{Cite conference |last1=Yuan Chou |last2=Fahs |first2=B. |last3=Abraham |first3=S. |year=2004 |title=Microarchitecture optimizations for exploiting memory-level parallelism |booktitle=Proceedings. 31st Annual International Symposium on Computer Architecture, 2004 |conference=ISCA'04 |pages=76–87 |citeseerx=10.1.1.534.6032 |doi=10.1109/ISCA.2004.1310765 |isbn=0-7695-2143-6}}
  • {{Cite conference |last1=Qureshi |first1=M. K. |last2=Lynch |first2=D. N. |last3=Mutlu |first3= O. |last4=Patt |first4=Y. N. |year=2006 |title=A Case for MLP-Aware Cache Replacement |booktitle=33rd International Symposium on Computer Architecture |conference=ISCA'06 |pages=167–178 |citeseerx=10.1.1.94.4663 |doi=10.1109/ISCA.2006.5 |isbn=0-7695-2608-X}}
  • {{Cite conference |last1=Van Craeynest |first1=K. |last2=Eyerman |first2=S. |last3=Eeckhout |first3=L. |year=2009 |title=MLP-Aware Runahead Threads in a Simultaneous Multithreading Processor |booktitle=High Performance Embedded Architectures and Compilers |conference=HiPEAC 2009 |series=LNCS |volume=5409 |pages=110–124 |citeseerx=10.1.1.214.3261 |doi=10.1007/978-3-540-92990-1_10 |isbn=978-3-540-92989-5}}
{{Parallel Computing}}{{CPU technologies}}

2 : Instruction processing|Parallel computing

随便看

 

开放百科全书收录14589846条英语、德语、日语等多语种百科知识,基本涵盖了大多数领域的百科知识,是一部内容自由、开放的电子版国际百科全书。

 

Copyright © 2023 OENC.NET All Rights Reserved
京ICP备2021023879号 更新时间:2024/9/24 22:38:38