Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

Explicitly parallel instruction computing

From Wikipedia, the free encyclopedia
Instruction set architecture
This articleneeds additional citations forverification. Please helpimprove this article byadding citations to reliable sources. Unsourced material may be challenged and removed.
Find sources: "Explicitly parallel instruction computing" – news ·newspapers ·books ·scholar ·JSTOR
(October 2010) (Learn how and when to remove this message)

Explicitly parallel instruction computing (EPIC) is a term coined in 1997 by theHP–Intel alliance[1] to describe acomputing paradigm that researchers had been investigating since the early 1980s.[2] This paradigm is also calledIndependence architectures. It was the basis forIntel andHP development of the IntelItanium architecture,[3] andHP later asserted that "EPIC" was merely an old term for the Itanium architecture.[4] EPIC permits microprocessors to execute software instructions in parallel by using thecompiler, rather than complex on-die circuitry, to control parallel instruction execution. This was intended to allow simple performance scaling without resorting to higherclock frequencies.

Roots in VLIW

[edit]

By 1989, researchers at HP recognized thatreduced instruction set computer (RISC) architectures were reaching a limit at oneinstruction per cycle.[clarification needed] They began an investigation into a new architecture, later namedEPIC.[3] The basis for the research wasVLIW, in which multiple operations are encoded in every instruction, and then processed by multiple execution units.

One goal of EPIC was to move the complexity of instruction scheduling from the CPU hardware to the softwarecompiler, which can do the instruction scheduling statically (with help of trace feedback information). This eliminates the need for complex scheduling circuitry in the CPU, which frees up space and power for other functions, including additional execution resources. An equally important goal was to further exploitinstruction-level parallelism (ILP) by using the compiler to find and exploit additional opportunities forparallel execution.

VLIW (at least the original forms) has several short-comings that precluded it from becoming mainstream:

EPIC architecture evolved from VLIW architecture, but retained many concepts of thesuperscalar architecture.

Moving beyond VLIW

[edit]

EPIC architectures add several features to get around the deficiencies ofVLIW:

  • Each group of multiple software instructions is called abundle. Each of the bundles has astop bit indicating if this set of operations is depended upon by the subsequent bundle. With this capability, future implementations can be built to issue multiple bundles in parallel. The dependency information is calculated by the compiler, so the hardware does not have to perform operand dependency checking.
  • A software prefetch instruction is used as a type of data prefetch. This prefetch increases the chances for a cache hit for loads, and can indicate the degree of temporal locality needed in various levels of the cache.
  • A speculative load instruction is used to speculatively load data before it is known whether it will be used (bypassing control dependencies), or whether it will be modified before it is used (bypassing data dependencies).
  • A check load instruction aids speculative loads by checking whether a speculative load was dependent on a later store, and thus must be reloaded.

TheEPIC architecture also includes agrab-bag of architectural concepts to increaseILP:

  • Predicated execution is used to decrease the occurrence of branches and to increase thespeculative execution of instructions. In this feature, branch conditions are converted to predicate registers which are used to kill results of executed instructions from the side of the branch which is not taken.
  • Delayed exceptions, using anot a thing bit within the general purpose registers, allow speculative execution past possible exceptions.
  • Very large architecturalregister files avoid the need forregister renaming.
  • Multi-way branch instructions improve branch prediction by combining many alternative branches into one bundle.

TheItanium architecture also addedrotating register files, a tool useful forsoftware pipelining since it avoids having to manuallyunroll and rename registers.

Other research and development

[edit]

There have been other investigations into EPIC architectures that are not directly tied to the development of the Itanium architecture:

  • TheIMPACT project atUniversity of Illinois at Urbana–Champaign, led byWen-mei Hwu, was the source of much influential research on this topic.
  • ThePlayDoh architecture from HP-labs was another major research project.
  • Gelato was an open source development community in which academic and commercial researchers worked to develop more effective compilers for Linux applications running on Itanium servers.

See also

[edit]

References

[edit]
  1. ^Schlansker and Rau (February 2000)."EPIC: An Architecture for Instruction-Level Parallel Processors"(PDF).HP Laboratories Palo Alto, HPL-1999-111. Retrieved2008-05-08.
  2. ^US 4847755, Morrison, Gordon E.; Brooks, Christopher B. & Gluck, Frederick G., "Parallel processing method and apparatus for increasing processing throughout by parallel processing low level instructions having natural concurrencies", published 1989-07-11, assigned to MCC Development Ltd. 
  3. ^ab"Inventing Itanium: How HP Labs Helped Create the Next-Generation Chip Architecture".HP Labs. June 2001. Archived fromthe original on 2012-03-04. Retrieved2007-12-14.
  4. ^De Gelas, Johan (November 9, 2005)."Itanium–Is there light at the end of the tunnel?".AnandTech. Retrieved2008-05-08.

External links

[edit]
Models
Architecture
Instruction set
architectures
Types
Instruction
sets
Execution
Instruction pipelining
Hazards
Out-of-order
Speculative
Parallelism
Level
Multithreading
Flynn's taxonomy
Processor
performance
Types
By application
Systems
on chip
Hardware
accelerators
Word size
Core count
Components
Functional
units
Logic
Registers
Control unit
Datapath
Circuitry
Power
management
Related
Retrieved from "https://en.wikipedia.org/w/index.php?title=Explicitly_parallel_instruction_computing&oldid=1255786652"
Categories:
Hidden categories:

[8]ページ先頭

©2009-2025 Movatter.jp