Kas yra netvarkingas vykdymas?

Kompiuteriai yra sudėtingi įrenginiai, kurių dalis nėra sudėtingesnė už centrinį procesorių. Atrodo, kad pagrindinės apžvalgos lygiu CPU turėtų būti gana paprastas. Ji paima eilę komandų, jas apdoroja ir išveda duomenis. Tačiau tai mažai panašu į faktinį šiuolaikinių procesorių veikimą.

Subskaliarinis iki superskaliarinis

Ankstyvieji procesoriai buvo tokie, kokių tikėjotės. Jie priimdavo instrukcijas individualiai tokia tvarka, kokia jiems buvo duotos, iki galo apdorojo, tada pereidavo prie kito nurodymo. Šio tipo procesoriai buvo subskaliariniai, galintys atlikti mažiau nei vieną komandą per laikrodžio ciklą. CPU dizaineriai nustatė, kad buvo daug skirtingų instrukcijų vykdymo etapų. Kiekvienam iš šių etapų reikėjo skirtingos aparatūros. Tai reiškė, kad vykdant vieną komandą per visą seką vienu metu, kai kurios aparatinės įrangos dalys neveikė. Bet kokio tipo procesoriuose neveikianti aparatinė įranga yra nenaudinga.

Norint panaudoti šią neveikiančią aparatinę įrangą, procesoriaus dizainas buvo atnaujintas, kad būtų naudojamas konvejerinis metodas. Tai dar labiau atskyrė kiekvieno etapo aparatinę įrangą, tačiau leido jas visas naudoti vienu metu, naudojant daugybę instrukcijų. Nors vis tiek prireikė kelių ciklų, kad kiekviena instrukcija būtų atlikta per dujotiekį, bendras pralaidumas buvo viena instrukcija per ciklą. Dėl to CPU tapo skaliarinis.

Kad būtų galima nuveikti daugiau, procesorius reikėjo padaryti superskalariniais. Norėdami tai pasiekti, buvo įdiegti keli lygiagrečiai vamzdynai.

Dujotiekių aprūpinimas duomenimis

Pagrindinė kompiuterių veikimo problema paprastai yra atminties delsa. Daugelis instrukcijų veikia su duomenimis, todėl norint vykdyti komandą, duomenys turi būti prieinami. Kyla klausimas, ką daryti, jei reikia laukti tų duomenų, nes jie nėra iš karto pasiekiami? Tradiciškai atsakymas buvo tiesiog sustabdyti ir laukti, kol jis bus prieinamas. Taip visas dujotiekis lieka tuščias, galbūt šimtams procesoriaus ciklų. Viskas dar blogiau, kai dviem instrukcijoms lygiagrečiuose konvejeriuose reikia palaukti atminties, nes pirmoji sulaikys net antrojo duomenų užklausą. Nors procesoriaus talpyklos atmintis gali padėti išspręsti šią problemą, ji vis tiek negali jos išspręsti. Jai išspręsti reikėjo naujos paradigmos. Tas paradigmos pokytis buvo Out Of Order Execution arba OOO.

Pirmasis dujotiekio etapas yra instrukcijos iššifravimas. Tai reiškia, kad reikia išsiaiškinti, ką reikia padaryti, ir patikrinti, ar yra operacijai reikalingi duomenys. OOO procesoriuje dekoduotos instrukcijos įtraukiamos į eilę. Jie pašalinami iš eilės ir faktiškai apdorojami tik tada, kai pasiekiami jiems reikalingi duomenys. Kritiškai nesvarbu, kokia tvarka instrukcijos buvo įtrauktos į eilę. Jei išankstinė instrukcija laukia duomenų, naujesnė instrukcija gali būti praleista, jei ji paruošta. OOO procesoriai gali pertvarkyti instrukcijas, kurias jie turėtų apdoroti, atsižvelgdami į būsimų instrukcijų eilę ir tai, kurios iš jų yra paruoštos vykdyti.

Kritinės priklausomybės

Šis procesas apima du dalykus. Visų pirma, kad galima patikimai nustatyti ir valdyti tikrąsias priklausomybes. Antra, galite patikimai valdyti ir nustatyti klaidingas priklausomybes. Koks skirtumas? Na, tikroji priklausomybė yra priklausomybė, kurios OOO sistemoje niekaip negalima sumažinti. Lengviausias pavyzdys yra skaitymas po rašymo. Jei turite vieną instrukciją, kuri turėtų įrašyti kai kuriuos duomenis, o kitą, kuri turėtų tuos duomenis nuskaityti, tų instrukcijų niekaip nepavyks pertvarkyti. Jie turi būti užpildyti tokia tvarka, kokia jie buvo pateikti, kitaip gausite nesąmonių duomenų.

Klaidinga priklausomybė yra ta, kurią galima paslėpti naudojant kitą protingą triuką. Paimkime rašymo po skaitymo pavyzdį. Iš pirmo žvilgsnio galite pamanyti, kad negalite perrašyti duomenų, kol neperskaitysite. Tačiau viskas nėra taip paprasta. Ką daryti, jei turite kitą vietą, kurioje galite įrašyti naujus duomenis, o tada galite tiesiog sukeisti naujus ir senus duomenis, kai tik bus nuskaityti seni duomenys? Tai yra registro pervadinimo procesas ir jis yra labai svarbus OOO apdorojimui.

Paprastai komandų rinkinys apibrėžia sistemoje naudojamų architektūrinių registrų skaičių. Jūs tiesiogine prasme negalite kreiptis į kitus. Bet ką daryti, jei registruojate perteklinį aprūpinimą? Galite tiesiog paslėpti juos didžiąja dalimi, naudoti juos duomenims, kurie dar neturėjo būti apdoroti, saugoti, o tada tiesiog sukeisti paslėptų ir architektūrinių registrų etiketes, kai laiko juosta vėl bus teisinga. Bet kuriuo metu yra tiksliai reikiamas architektūrinių registrų skaičius, tik jie nebūtinai visada yra toje pačioje vietoje. Realaus pasaulio analogija būtų karštas stalas.

Išvada

Vykdymas ne pagal užsakymą yra apdorojimo paradigma, kai CPU vykdymo metu gali dinamiškai pertvarkyti instrukcijas. Tai daroma remiantis anksčiausiai išleistomis instrukcijomis, turinčiomis turimų duomenų. Tai reiškia, kad į dujotiekį įkeliamos instrukcijos visada yra paruoštos vykdyti ir laukiant duomenų nėra vėlavimų. Žinoma, reikia turėti pakankamai ilgą eilę, kad ji nebūtų užpildyta instrukcijomis, laukiančiomis duomenų, tačiau tai yra įgyvendinimo iššūkis. OOO vykdymas priklauso nuo registro pervadinimo, kad būtų paslėptos klaidingos priklausomybės. Net jei šios instrukcijos iš tikrųjų vykdomos netvarkingai, registrai pervadinami taip, kad šis faktas būtų paslėptas nuo likusio kompiuterio.


Kaip klonuoti standųjį diską

Kaip klonuoti standųjį diską

Šiuolaikiniame skaitmeniniame amžiuje, kai duomenys yra vertingas turtas, kietojo disko klonavimas sistemoje „Windows“ daugeliui gali būti labai svarbus procesas. Šis išsamus vadovas

Kaip pataisyti tvarkyklę, kurios WUDFRd nepavyko įkelti sistemoje „Windows 10“?

Kaip pataisyti tvarkyklę, kurios WUDFRd nepavyko įkelti sistemoje „Windows 10“?

Ar paleidžiant kompiuterį matote klaidos pranešimą, kuriame rašoma, kad tvarkyklės WUDFRd nepavyko įkelti į kompiuterį?

Kaip ištaisyti „NVIDIA GeForce Experience“ klaidos kodą 0x0003

Kaip ištaisyti „NVIDIA GeForce Experience“ klaidos kodą 0x0003

Ar jūsų darbalaukyje yra NVIDIA GeForce patirties klaidos kodas 0x0003? Jei taip, perskaitykite tinklaraštį, kad sužinotumėte, kaip greitai ir paprastai ištaisyti šią klaidą.

Kas yra SMPS?

Kas yra SMPS?

Prieš rinkdamiesi SMPS savo kompiuteriui, sužinokite, kas yra SMPS ir ką reiškia skirtingi efektyvumo rodikliai.

Kas yra izoliacija pagrįstas saugumas?

Kas yra izoliacija pagrįstas saugumas?

Ketinau įsigilinti į temą, kuri tampa vis svarbesnė kibernetinio saugumo pasaulyje: izoliacija pagrįstas saugumas. Šis požiūris į

Kaip naudoti „Auto Clicker“, skirtą „Chromebook“.

Kaip naudoti „Auto Clicker“, skirtą „Chromebook“.

Šiandien ketinome įsigilinti į įrankį, kuris gali automatizuoti pasikartojančias spustelėjimo užduotis jūsų „Chromebook“ įrenginyje: automatinį spustelėjimą. Šis įrankis gali sutaupyti laiko ir

Roomba sustoja, sustoja ir apsisuka – pataisykite

Roomba sustoja, sustoja ir apsisuka – pataisykite

Išspręskite problemą, kai Roomba robotas siurblys sustoja, prilimpa ir vis sukasi.

Kodėl „Chromebook“ neįsijungia

Kodėl „Chromebook“ neįsijungia

Gaukite atsakymus į klausimą, kodėl „Chromebook“ neįsijungia? Šiame naudingame „Chromebook“ naudotojams skirtame vadove.

Kaip pakeisti grafikos nustatymus „Steam Deck“.

Kaip pakeisti grafikos nustatymus „Steam Deck“.

„Steam Deck“ siūlo tvirtą ir įvairiapusę žaidimo patirtį, kuri yra jūsų rankose. Tačiau norėdami optimizuoti savo žaidimus ir užtikrinti geriausią įmanomą

Kaip pakeisti laikrodžio ciferblatą „Fitbit Versa 4“.

Kaip pakeisti laikrodžio ciferblatą „Fitbit Versa 4“.

Pakeiskite savo Fitbit Versa 4 laikrodžio ciferblatą, kad kasdien nemokamai atrodytumėte kitaip. Pažiūrėkite, kaip tai greita ir paprasta.