Mine sisu juurde

Hüperhargtöötlus

Allikas: Vikipeedia
(Ümber suunatud leheküljelt Hyper-Threading)
Inteli hüperhargtöötlust kasutava protsessori skeem

Hüperhargtöötlus (Hyper-Threading Technology, lühendatult HTT või HT) on Inteli välja töötatud tehnoloogia, mis võimaldab ühel protsessoril samaaegselt käitada mitut programmiharu või lõime. Seda on kasutatud Intel Pentium 4, Pentium D, Itanium, Atom, Core i3, Core i5, Core i7 ja Xeon seeria protsessorites.

Hüperhargtöötlus parandab arvutisüsteemi efektiivsust ja arvutusjõudlust juhul, kui operatsioonisüsteem ja kasutatavad programmid toetavad HT-tehnoloogiat. Iga protsessorituuma jaoks adresseerib operatsioonisüsteem kaks virtuaalset protsessorit ja võimaluse korral jagab koormuse nende vahel. Kui operatsioonisüsteem või kasutatavad programmid HT-tehnoloogiat ei toeta, siis kasvu jõudluses ei toimu või jõudlus koguni väheneb. Intel soovitab hüperhargtöötluse välja lülitada, kui kasutatav operatsioonisüsteem seda ei toeta.[1]

Hüperhargtöötlust hakati välja töötama Digital Equipment Corporationi[2] käe all, kuid selle tõi turule Intel. HT-tehnoloogiat tutvustati esmakordselt Foster MP Xeon protsessoris 2002. aastal. Samal aastal ilmus see ka Pentium 4 Northwood 3,06 GHz protsessoris. Seejärel leidis HT-tehnoloogia kasutust igas Pentium 4 HT, Pentium 4 Extreme Edition ja Pentium Extreme Edition protsessoris.

2006. aastal tutvustatud Core mikroarhitektuuril põhinevad protsessorid ei oma HT-tehnoloogiat, sest Core mikroarhitektuur on P6 mikroarhitektuuri järglane, mida kasutati Pentiumi seerias alates Pentium Pro loomisest kuni Pentium III-ni ning Celeroni seerias (protsessorites koodnimedega Covington, Mendocino, Coppermine ja Tualatini), Pentium II Xeon ja Pentium III Xeon mudelites.

Novembris 2008 turule toodud Inteli Nehalemi mikroarhitektuuriga protsessoritega tuli HT-tehnoloogia tagasi. HT-tehnoloogia on leitav nii kahe, nelja kui ka kuue tuumaga protsessorite mudelites.[3]

Inteli hüperhargtöötlust kasutav Core i7-940 protsessor

Intel Atom, mis on mõeldud vähese elektritarbega personaalarvutitele, kasutab HT-tehnoloogiat.[4]

Intel Xeon protsessorid, mis põhinevad Nehalemi arhitektuuril, kasutavad HT-tehnoloogiat.[5]

Intel Itanium 9300 kasutab arendatud HT-tehnoloogiat. Poulson, järgmise generatsiooni Itanium, omab edasisi HT-tehnoloogia täiustusi.[6][7]

Aastal 2005 demonstreeris Colin Percival turvariski, mille ta leidis kasutades HT-tehnoloogiaga P4-protsessorit. Piiratud privileegidega pahatahtlikul lõimel on võimalik jälgida teise lõime käitamist ja varastada krüptovõtmeid, kasutades selleks jagatud vahemälu.[8] Eelkõige ohustab risk servereid. Viga pole ainult hüperhargtöötlusele omane, vaid ohustab kõiki protsessoreid, mis jagavad ressursse samal viisil nagu HTT. Intel väitis, et turvaviga pole siiski kriitiline ja vajab eelnevalt serveri turvalisuse murdmist, mis omakorda annab lihtsamad meetodid andmete varastamiseks, viga parandatakse aga sellest hoolimata.[9]

Tehnoloogia

[muuda | muuda lähteteksti]

Tavaline ühetuumaline protsessor suudab ainult ühe lõimega korraga tegeleda, mistõttu on vajalik pidev lõimede vahetamine. Peaaegu alati on operatsioonisüsteemis tööl rohkem kui üks lõim. Üks lõim aga ei pruugi kasutada ära tervet protsessori arvutusvõimsust. Lõimega tegelemisel üle jääv ressurss seisab kasutult. HT-tehnoloogia põhineb eeldusel, et igal antud ajahetkel läheb programmikoodi täitmiseks vaja ainult osa protsessori võimekusest. Kasutamata ressursiga oleks võimalik järgmist lõime käivitada. Selleks tekib ühest füüsilisest protsessorist kaks loogilist protsessorit, mis kasutavad ühe ja sama füüsilise protsessorituuma ressursse. Näimaks operatsioonisüsteemile kahe loogilise protsessorina, paljundatakse teatud osad protsessorist – osad, mis salvestavad arhitektuurilist olekut. Kahe loogilise protsessori olemasolu võimaldab operatsioonisüsteemil planeerida kahe lõime samaaegset töötlemist. HT-tehnoloogiata protsessoril see võimalik ei ole ja ühe lõime töötlemisel üle jääv ressurss jääb ootele.

HT-tehnoloogiaga riistvarast kasu saamiseks on vaja, et operatsioonisüsteem toetaks vähemalt sümmeetrilist multitöötlust (ingl. k. symmetric multiprocessing – SMP), et loogilised protsessorid paistaksid eraldiseisvate protsessoritena. Tehnoloogiast täieliku kasu saamiseks on vaja aga HT tuge. Näiteks kahetuumalise HT toega protsessori korral käsitleb SMP toega, kuid ilma HT toeta operatsioonisüsteem nelja loogilist protsessorit füüsilistena. Sel juhul võib kaks aktiivset lõime planeerida jooksma kahel loogilisel tuumal, mis jagavad sama füüsilist protsessorituuma. Nii töötab üks füüsiline tuum täies mahus, samal ajal kui teine seisab ootel. Vajalik on, et operatsioonisüsteem suudaks tuvastada loogilisi protsessoreid ja neid teisiti käsitleda.

Nõuded HT-tehnoloogia jaoks:[10]

  • protsessor, mis toetab Inteli HT-tehnoloogiat;
  • Inteli HT-tehnoloogia võimalusega kiibistik;
  • Inteli HT-tehnoloogia võimalusega BIOS;
  • Inteli HT-tehnoloogiat toetav operatsioonisüsteem.

Hüperhargtöötluse eelised on parem tugi mitmelõimelistele programmidele, võime mitmel lõimel samaaegselt käia ning kiiremad toimingud ja reageerimine. Hüperhargtöötlus võimaldab protsessori ressursse efektiivsemalt kasutada. See tagab süsteemi reageerivuse nõudlike programmidega töötamisel.[11]

Inteli esimestel HT-tehnoloogia katsetel suurenes kiibi pindala 5%, kuid jõudlus paranes 15–30% olenevalt olukorrast.[12]

Pentium 4 seeria puhul tõestasid katsed, et P4 3,0 GHz HT toega protsessor võis teatud juhtudel olla kiirem kui ilma HT-tehnoloogiata P4 3,6 GHz protsessor.[13] Jõudluse kasv oleneb siiski väga palju protsessorit kasutatavast tarkvarast. Käitades kahte ressursinõudlikku programmi samal ajal, võivad mõlemad programmid aeglasemalt töötada.

HT-tehnoloogia Nehalemi protsessoritel on üldjoontes sama, mida kasutati Pentium 4 seerias. Intel väidab, et tänu mikroarhitektuuri arengule on HT-tehnoloogia märksa efektiivsem kui varem.[14] Jõudluse muutus protsentuaalselt Nehalemi arhitektuuril põhinevatel HT-tehnoloogia toega protsessoritel pole aga muutunud – olenevalt kasutatavast programmist ja programmi lõimede arvust võib jõudlus HT-tehnoloogiaga suureneda kuni 30% võrra, mõnel üksikul juhul isegi 50%. Samas võib jõudlus ka väheneda kuni 20%. Mitmelõimeliste programmide puhul on üks loogiline protsessor võrdne keskmiselt 1/3-ga ühest lisatuumast.[15] Tehnoloogia käitumist igas olukorras on raske välja selgitada keeruliste mitmetuumaliste protsessorite puhul, kuid üldjuhul on HT-tehnoloogia näol tegemist eelisega.

Tarkvaraline HT tugi

[muuda | muuda lähteteksti]

Pentium 4 3,06 GHz HT toega protsessori väljastamisel oli mõnedel programmeerijatel algul raske otsustada, kas kasutada HT-tehnoloogiat oma rakenduste loomisel või mitte.[16] Programmeerijad kasutasid rakenduste testimiseks veel operatsioonisüsteeme, mis polnud optimeeritud HT-tehnoloogia jaoks.[1] Enamik personaalarvuteid kasutasid siiski protsessoreid, mis olid võimelised ainult ühe lõimega korraga tegelema.

Kuna Intel ei kasutanud HT-tehnoloogiat Core mikroarhitektuuriga protsessorites, on ka Nehalemi hüperhargtöötlusega protsessoritel probleemiks vähene tarkvaraline tugi HT-tehnoloogiale, sest tarkvaraarendajad ei pidanud HT-tehnoloogia tuge oma rakendustes tähtsaks.

Aastal 2006 kritiseeriti hüperhargtöötlust ebaefektiivse voolutarbe tõttu. Väikese voolutarbega protsessorite looja ARM väitis, et sümmeetrilise multitöötlusega lahendused (nagu seda on Hyper-Threading) võivad tarbida 46% rohkem elektrit kui kahetuumalised protsessorilahendused. Lisati, et SMP-töötlus võib suurendada vahemälu mitteotstarbekat kasutust 42% võrra, samas kui kahetuumalisel protsessoril väheneb see 37% võrra.[17] Aastal 2010 teatas ARM siiski, et hakkab tulevikus SMP-töötlusega lahendusi oma kiipides kasutama.[18]

Suurem voolutarve on tingitud asjaolust, et kõik protsessori tuuma osad peavad olema sisse lülitatud ja seda isegi ooteolekus. Suur voolutarve on aga halb nähtus, eriti serveriruumide ja sülearvutite puhul. Sellest hoolimata võib hüperhargtöötlus neil juhtudel kasulikuks osutuda. Näiteks tänapäeval on ühel füüsilisel serveril tööl mitu virtualiseeritud serverit, seega on vajalik ühest protsessori tuumast maksimum võtta. Lihtne tuumade lisamine toob kaasa ka voolutarbe kasvu ja muid lisakulutusi.

Probleemid jõudlusega

[muuda | muuda lähteteksti]

Kuigi üldiselt HT-tehnoloogia annab kasvu jõudluses, võib jõudlus ka väheneda. Sel juhul on lahenduseks lihtsalt HT väljalülitamine. Probleemid on tingitud kas arvuti riistvara konfiguratsioonist või kasutatava tarkvara eripäradest.[19][20] Kasutegur on suhteliselt väike või olematu personaalarvuti puhul, kus protsessoril võib olla isegi 4 tuuma või rohkem. Üldjuhul ei leidu tavakasutajale veel programme, mis oskaks kasu lõigata näiteks kaheksa lõime üheaegsest töötlemisest.

Samuti on probleeme täheldatud serveritel, mis peaksid mitme lõime üheaegsest töötlemisest suurima jõudluse kasvu saama. Koormuse all serveri protsessori kasutus suureneb märgatavalt, samal ajal kui serveri jõudlus väheneb. Hüperhargtöötluse väljalülitamine BIOSist lahendab aga probleemi. Probleem seisneb arvatavasti asjaolus, et loogilised protsessorid jagavad vahemälu ning vahemälu ei jõua mõlema protsessori nõudmisi täita, mis vähendab kogu süsteemi võimekust protsessidega tegelemises.[21][22]

Soojuseraldus

[muuda | muuda lähteteksti]

HT-tehnoloogia kasutamisel on märgatud ka suuremat soojuse eraldust protsessorist täiskoormuse all. Protsessori temperatuur võib tõusta 5–10 °C.[20]

  1. 1,0 1,1 http://www.intel.com/support/processors/sb/CS-017343.htm Inteli HT tehnoloogiat toetavad operatsioonisüsteemid.
  2. http://www.zdnet.com.au/intel-hyperthreading-shows-digital-roots-120268992.htm[alaline kõdulink] Inteli HT juured.
  3. http://ark.intel.com/MySearch.aspx?HyperThreading=true Inteli HT toega protsessorid.
  4. http://www.intel.com/technology/atom/microarchitecture.htm Intel Atom.
  5. http://www.intel.com/p/en_US/products/server/processor Inteli protsessorid serveritele.
  6. https://web.archive.org/web/20110524131756/http://www.zdnetasia.com/intel-updates-itanium-line-with-kittson-62021436.htm Intel Itanium 9300.
  7. https://web.archive.org/web/20110708124839/http://microelectronics.cbronline.com/news/intel_launches_new_itanium_9300_series_processor_100208 Intel Itanium 9300.
  8. http://www.daemonology.net/hyperthreading-considered-harmful/ HT tehnoloogia turvarisk.
  9. https://web.archive.org/web/20100325161129/http://www.xbitlabs.com/news/cpu/display/20050515030244.html Inteli vastus turvariski avastamisele.
  10. http://www.intel.com/products/ht/hyperthreading_more.htm?iid=tech_ht+rhc_ht Inteli HT nõuded.
  11. http://www.intel.com/technology/platform-technology/hyper-threading/index.htm Inteli HT tehnoloogia eelised.
  12. https://web.archive.org/web/20080224023922/http://download.intel.com/technology/itj/2002/volume06issue01/vol6iss1_hyper_threading_technology.pdf Intel HT tehnoloogiast.
  13. http://www.tomshardware.com/reviews/single-cpu-dual-operation,549-25.html HT toega P4 ja ilma HT toeta P4 protsessori võrdlus.
  14. http://software.intel.com/en-us/articles/performance-insights-to-intel-hyper-threading-technology/ Intel HT tehnoloogiast.
  15. http://ixbtlabs.com/articles3/cpu/archspeed-2009-4-p2.html HT jõudlus i7 protsessoril.
  16. "Arhiivikoopia". Originaali arhiivikoopia seisuga 19. juuni 2010. Vaadatud 12. detsembril 2010.{{netiviide}}: CS1 hooldus: arhiivikoopia kasutusel pealkirjana (link)
  17. https://web.archive.org/web/20090906005322/http://www.theinquirer.net/inquirer/news/1037948/arm-fan-hyperthreading ARM kriitika HT tehnoloogiale.
  18. https://web.archive.org/web/20110613203023/http://www.top500.org/blog/2010/10/13/about_mips_and_mips ARM hakkab HT tehnoloogiat tulevikus kasutama.
  19. www.novell.com/support/viewContent.do?externalId=3407939 HT tehnoloogia tingitud probleemid.
  20. 20,0 20,1 http://www.overclockers.com/forums/showthread.php?t=609734.
  21. http://www.zdnet.co.uk/news/processors/2005/11/18/hyperthreading-hurts-server-performance-say-developers-39237341/ HT tehnoloogia probleemid serveritega.
  22. http://support.microsoft.com/kb/322385 HT serverites.

Välislingid

[muuda | muuda lähteteksti]