Teknologi Informasi    
   
Daftar Isi
(Sebelumnya) Hypertext Transfer ProtocolHypothesis (Berikutnya)

Hyper-threading

Intel's Hyper-Threading Technology scheme.

Hyper-threading (officially Hyper-Threading Technology or HT Technology, abbreviated HTT or HT) is Intel's proprietary simultaneous multithreading (SMT) implementation used to improve parallelization of computations (doing multiple tasks at once) performed on PC microprocessors. It first appeared in February 2002 on Xeon server processors and in November 2002 on Pentium 4 desktop CPUs.[1] Later, Intel included this technology in Itanium, Atom, and Core 'i' Series CPUs, among others.

For each processor core that is physically present, the operating system addresses two virtual or logical cores, and shares the workload between them when possible. The main function of hyper-threading is to decrease the number of dependent instructions on the pipeline. It takes advantage of superscalar architecture (multiple instructions operating on separate data in parallel). They appear to the OS as two processors, thus the OS can schedule two processes at once. In addition two or more processes can use the same resources. If one process fails then the resources can be readily re-allocated.

Hyper-threading requires not only that the operating system supports SMT, but also that it be specifically optimized for HTT,[2] and Intel recommends disabling HTT when using operating systems that have not been optimized for this chip feature.

Contents

Details

Intel Pentium 4 processor that incorporates Hyper-Threading Technology[3]

Hyper-threading works by duplicating certain sections of the processor—those that store the architectural state—but not duplicating the main execution resources. This allows a hyper-threading processor to appear as the usual "physical" processor and an extra "logical" processor to the host operating system (legacy operating systems see two "physical" processors), allowing the operating system to schedule two threads or processes simultaneously and appropriately. When execution resources would not be used by the current task in a processor without hyper-threading, and especially when the processor is stalled, a hyper-threading equipped processor can use those execution resources to execute another scheduled task. (The processor may stall due to a cache miss, branch misprediction, or data dependency.)

This technology is transparent to operating systems and programs. The minimum that is required to take advantage of hyper-threading is symmetric multiprocessing (SMP) support in the operating system, as the logical processors appear as standard separate processors.

It is possible to optimize operating system behavior on multi-processor hyper-threading capable systems. For example, consider an SMP system with two physical processors that are both hyper-threaded (for a total of four logical processors). If the operating system's thread scheduler is unaware of hyper-threading it will treat all four processors as being the same. If only two threads are eligible to run, it might choose to schedule those threads on the two logical processors that happen to belong to one of the physical processors; that processor would become extremely busy while the other would be idle, leading to poorer performance than is possible with better scheduling. This problem can be avoided by improving the scheduler to treat logical processors differently from physical processors; in a sense, this is a limited form of the scheduler changes that are required for NUMA systems.

History

Delencor introduced multi-threading with the HEP (Heterogeneous Element Processor) in 1982. The HEP pipeline could not hold multiple instructions that were independent because they belonged to different processes. Only one instruction from a given process was allowed to be present in the pipeline at any point in time. Should an instruction from a given process block in the pipe, instructions from the other processes would continue after the pipeline drained.

Intel implemented hyper-threading on an x86 architecture processor in 2002 with the Foster MP-based Xeon. It was also included on the 3.06 GHz Northwood-based Pentium 4 in the same year, and then remained as a feature in every Pentium 4 HT, Pentium 4 Extreme Edition and Pentium Extreme Edition processor since. Previous generations of Intel's processors based on the Core microarchitecture do not have Hyper-Threading, because the Core microarchitecture is a descendant of the P6 microarchitecture used in iterations of Pentium since the Pentium Pro through the Pentium III and the Celeron (Covington, Mendocino, Coppermine and Tualatin-based) and the Pentium II Xeon and Pentium III Xeon models.

Intel released the Nehalem (Core i7) in November 2008 in which hyper-threading made a return. The first generation Nehalem contained four cores and effectively scaled eight threads. Since then, both two- and six-core models have been released, scaling four and twelve threads respectively.[4]

The Intel Atom is an in-order processor with hyper-threading, for low power mobile PCs and low-price desktop PCs.[5]

The Itanium 9300 launched with eight threads per processor (two threads per core) through enhanced hyper-threading technology. Poulson, the next-generation Itanium, is scheduled to have additional hyper-threading enhancements.

The Intel Xeon 5500 server chips also utilize two-way hyper-threading.[6][7]

Performance claims

The advantages of hyper-threading are listed as: improved support for multi-threaded code, allowing multiple threads to run simultaneously, improved reaction and response time.

According to Intel the first implementation only used 5% more die area than the comparable non-hyperthreaded processor, but the performance was 15–30% better.[8]

Intel claims up to a 30% performance improvement compared with an otherwise identical, non-simultaneous multithreading Pentium 4. Tom's Hardware states "In some cases a P4 running at 3.0 GHz with HT on can even beat a P4 running at 3.6 GHz with HT turned off."[9] Intel also claims significant performance improvements with a hyper-threading-enabled Pentium 4 processor in some artificial intelligence algorithms. The performance improvement seen is very application-dependent; however, when running two programs that require full attention of the processor it can actually seem like one or both of the programs slows down slightly when Hyper-Threading Technology is turned on.[10] This is due to the replay system of the Pentium 4 tying up valuable execution resources, equalizing the processor resources between the two programs which adds a varying amount of execution time. The Pentium 4 Prescott core gained a replay queue, which reduces execution time needed for the replay system. This is enough to completely overcome that performance hit.[11]

Overall the performance history of hyper-threading is mixed. As one commentary on high performance computing notes:

Hyper-Threading can improve the performance of some MPI applications, but not all. Depending on the cluster configuration and, most importantly, the nature of the application running on the cluster, performance gains can vary or even be negative. The next step is to use performance tools to understand what areas contribute to performance gains and what areas contribute to performance degradation.[12]

Drawback history

When the first HT processors were released it was difficult for some users to decide whether to enable it, because many of them were still using operating systems that were not optimized for hyper-threading technology (e.g. Windows 2000 and Linux older than 2.4).[13] Also, since most computers had previously had single-threaded processors, few programs were able to take advantage of the feature on their own.

In 2006, hyper-threading was criticised for being energy-inefficient. For example, specialist low-power CPU design company ARM has stated simultaneous multithreading (SMT) can use up to 46% more power than dual-core designs. Furthermore, they claim SMT increases cache thrashing by 42%, whereas dual core results in a 37% decrease.[14] Intel has disputed this claim, stating that hyper-threading is highly efficient because it simply uses resources that would otherwise be idle. In 2010, ARM said that it might include simultaneous multithreading in its chips in the future,[15] however this was rejected for their 2012 64 bit design.[16]

Security

In May 2005 Colin Percival demonstrated that on the Pentium 4, a malicious thread can use a timing attack to monitor the memory access patterns of another thread with which it shares a cache, allowing the theft of cryptographic information.[17] Potential solutions to this include the processor changing its cache eviction strategy, or the operating system preventing the simultaneous execution, on the same physical core, of threads with different privileges.[17]

See also

References

  1. ^ http://www.xbitlabs.com/articles/cpu/ display/pentium4-3066.html
  2. ^ Intel Required Components Interchangeability List for the Intel Pentium 4 Processor with HT Technology, includes list of Operating Systems that include optimizations for Hyper-Threading Technology; they are Windows XP Professional 64, Windows XP MCE, Windows XP Home, Windows XP Professional, some versions of Linux such as COSIX Linux 4.0, RedHat Linux 9 (Professional and Personal versions), RedFlag Linux Desktop 4.0 and SuSe Linux 8.2 (Professional and Personal versions)
  3. ^ Intel Processor Spec Finder: SL6WK
  4. ^ Intel explains the new Core i7 CPU
  5. ^ "Intel® Atom™ Processor Microarchitecture". Intel.com. 2011-03-18. http://www.intel.com/technology/atom/ microarchitecture.htm. Retrieved 2011-04-05.
  6. ^ "Server Processor Index Page". Intel.com. 2011-03-18. http://www.intel.com/p/en_US/products /server/processor. Retrieved 2011-04-05.
  7. ^ "Intel® Xeon® Processor 5500 Series". Intel.com. http://www.intel.com/business/resourc es/demos/xeon5500/performance/demo.ht m. Retrieved 2011-04-05.
  8. ^ http://www.intel.com/technology/itj/2 002/volume06issue01/vol6iss1_hyper_th reading_technology.pdf
  9. ^ "Summary: In Some Cases The P4 3.0HT Can Even Beat The 3.6 GHz Version : Single CPU in Dual Operation: P4 3.06 GHz with Hyper-Threading Technology". Tomshardware.com. 2002-11-14. http://www.tomshardware.com/reviews/s ingle-cpu-dual-operation,549-25.html. Retrieved 2011-04-05.
  10. ^ CPU performance evaluation Pentium 4 2.8 and 3.0
  11. ^ "Replay: Unknown Features of the NetBurst Core. Page 15". Replay: Unknown Features of the NetBurst Core.. http://www.xbitlabs.com. http://www.xbitlabs.com/articles/cpu/ display/replay_15.html#sect0. Retrieved 24 April 2011.
  12. ^ "A Study of Hyperthreading in High-Performance Computing Clusters". Dell. http://ftp.dell.com/app/4q02-Len.pdf. Retrieved November 10, 2012.
  13. ^ "Hyper-Threading Technology — Operating systems that include optimizations for Hyper-Threading Technology". Intel.com. 2011-09-19. http://www.intel.com/support/processo rs/pentium4/sb/cs-017371.htm#1c. Retrieved 2012-02-29.
  14. ^ "ARM is no fan of HyperThreading". theinquirer.net. 2006-08-02. http://www.theinquirer.net/inquirer/n ews/1037948/arm-fan-hyperthreading. Retrieved 2012-02-29.
  15. ^ Tom Jermoluk, SGI (1990s) (2010-10-13). "About MIPS and MIPS | TOP500 Supercomputing Sites". Top500.org. http://www.top500.org/blog/2010/10/13 /about_mips_and_mips. Retrieved 2011-04-05.
  16. ^ "ARM’s 64bit shift provides clean-up opportunity."
  17. ^ a b Cache Missing for Fun and Profit

External links

(Sebelumnya) Hypertext Transfer ProtocolHypothesis (Berikutnya)