Co to jest rejestr?

Jeśli nie jesteś szczególnie zainteresowany komputerami, wybaczono by ci założenie, że jedynymi formami pamięci w komputerze były dysk twardy i pamięć RAM. Ci z was, którzy interesują się komputerami, prawdopodobnie wiedzą, że tak nie jest i że procesor ma również zestaw pamięci podręcznych, które służą do buforowania danych z pamięci RAM, aby procesor mógł uzyskać do nich szybszy dostęp. Wszystkie te funkcje są reklamowane, głównie dlatego, że szybkość i/lub pojemność jest przyzwoitą zaletą i ogólnie wpływa na poziom wydajności.

W rzeczywistości jest jeszcze jedna warstwa pamięci. O ile mogłoby się wydawać, że pamięć podręczna L1 jest jak najbliżej rzeczywistego rdzenia przetwarzającego, w hierarchii pamięci znajduje się jeszcze jedna wyższa warstwa. To są rejestry procesora. Powodem, dla którego tak naprawdę nie są one reklamowane ani wspominane, jest to, że tak naprawdę w ogóle się nie zmieniają. Technicznie rzecz biorąc, mogą być, jednak liczba i rozmiar rejestrów jest w rzeczywistości fundamentalna dla architektury. Oznacza to, że wszystkie procesory x86-64 mają taką samą liczbę rejestrów. Nie są sprzedawane, ponieważ nie są punktem konkurencyjnym.

Co robi rejestr?

Rejestr to szybko dostępne miejsce przechowywania dla procesora. Dostęp do rejestru jest natychmiastowy z zerowym opóźnieniem, podczas gdy nawet pamięć podręczna L1 ma opóźnienie około 4-5 cykli w nowoczesnych procesorach. Ta natychmiastowość dostępu wskazuje na przypadek użycia rejestrów. Rejestry służą do przechowywania instrukcji aktywnie obsługiwanych przez procesor. Przechowują również punkty danych, które mają zostać przetworzone. Niektóre rejestry są ogólnego przeznaczenia, podczas gdy inne mają bardzo specyficzny cel. Przykładem rejestru specjalnego przeznaczenia byłby licznik programu, w którym procesor śledzi swoją pozycję w sekwencji programu.

Wiele rejestrów uważa się za dostępne dla użytkownika. Nie oznacza to jednak, że użytkownik komputera może wybrać, jaką wartość w nich umieścić. Oznacza to, że działające oprogramowanie może określić dane, które mają zostać załadowane do tych rejestrów. Mniejsza liczba rejestrów jest wewnętrzna, co oznacza, że ​​oprogramowanie w ogóle nie może ich adresować. Przykładem rejestru wewnętrznego jest rejestr instrukcji, w którym przechowywana jest aktualnie wykonywana instrukcja.

Zarejestruj zmianę nazwy

Chociaż architektura procesora może zezwalać tylko na jedną konfigurację rejestrów, w rzeczywistości jest w tym trochę niuansów. Wszystkie nowoczesne procesory wykorzystują zmianę nazwy rejestru. Jest to technika, w której można mieć więcej fizycznych rejestrów i używać ich do wstępnego ładowania danych lub przechowywania danych związanych z rozkazami poza kolejnością, które w przeciwnym razie zostałyby nadpisane. Kiedy procesor dochodzi do punktu, w którym potrzebuje danych w dodatkowych rejestrach, po prostu zmienia ich nazwę, aby był adresowalny, jednocześnie czyniąc wcześniej adresowalny rejestr nieadresowalnym.

Proces zmiany nazwy rejestru może być bardzo pomocny przy wykonywaniu poza kolejnością. Na przykład, jeśli miejsce w pamięci jest zaprogramowane do odczytu, a następnie zapisu do niego, a instrukcje zostały wykonane w tej kolejności, jest to w porządku. Jeśli jednak kolejność instrukcji zostanie zmieniona, aby najpierw wykonać zapis, instrukcja odczytu otrzyma niewłaściwą wartość. Aby temu zapobiec, oryginalna wartość do odczytania jest przechowywana w nieużywanym rejestrze, którego nazwa jest następnie zmieniana podczas przetwarzania odpowiedniej instrukcji.

Wniosek

Rejestry są najwyższym poziomem w hierarchii pamięci. Są jedyną częścią bezpośrednio adresowaną przez procesor i nie mają opóźnień. Rejestry służą do przechowywania danych aktywnie wykonywanych przez CPU. Służą również do przechowywania innych punktów danych, takich jak licznik programu, który śledzi, która instrukcja jest następna do wykonania. Dostępna jest bardzo ograniczona liczba rejestrów w architekturze x86-64 z 16 rejestrami ogólnego przeznaczenia i 16 lub 32 rejestrami zmiennoprzecinkowymi, w zależności od tego, czy AVX-512 jest obsługiwany.



Leave a Comment

Jak sklonować dysk twardy

Jak sklonować dysk twardy

We współczesnej epoce cyfrowej, gdzie dane są cennym zasobem, klonowanie dysku twardego w systemie Windows może być dla wielu kluczowych procesów. Ten obszerny przewodnik

Jak naprawić błąd ładowania sterownika WUDFRd w systemie Windows 10?

Jak naprawić błąd ładowania sterownika WUDFRd w systemie Windows 10?

Czy podczas uruchamiania komputera pojawia się komunikat o błędzie informujący, że nie udało się załadować sterownika WUDFRd na Twój komputer?

Jak naprawić błąd NVIDIA GeForce Experience o kodzie 0x0003

Jak naprawić błąd NVIDIA GeForce Experience o kodzie 0x0003

Czy na pulpicie pojawia się błąd NVIDIA GeForce o kodzie 0x0003? Jeśli tak, przeczytaj blog, aby dowiedzieć się, jak szybko i łatwo naprawić ten błąd.

How to Use Auto Clicker for Chromebook

How to Use Auto Clicker for Chromebook

Today, were going to delve into a tool that can automate repetitive clicking tasks on your Chromebook: the Auto Clicker. This tool can save you time and

Jak usunąć procesor graficzny z komputera z systemem Windows w 2023 r

Jak usunąć procesor graficzny z komputera z systemem Windows w 2023 r

Czy musisz usunąć GPU z komputera? Dołącz do mnie, gdy wyjaśnię, jak usunąć procesor graficzny z komputera w tym przewodniku krok po kroku.

Jak zainstalować dysk SSD NVMe na komputerze stacjonarnym i laptopie

Jak zainstalować dysk SSD NVMe na komputerze stacjonarnym i laptopie

Kupiłeś nowy dysk SSD NVMe M.2, ale nie wiesz, jak go zainstalować? Czytaj dalej, aby dowiedzieć się, jak zainstalować dysk SSD NVMe na laptopie lub komputerze stacjonarnym.

Co to jest bomba logiczna?

Co to jest bomba logiczna?

Bomba logiczna to incydent związany z bezpieczeństwem, w którym osoba atakująca przeprowadza opóźnioną akcję. Czytaj dalej, aby dowiedzieć się więcej.

Co to jest SoC?

Co to jest SoC?

Jeśli kiedykolwiek zajrzałeś do wnętrza wieży PC, możesz zobaczyć, że jest tam wiele różnych komponentów. Twój przeciętny laptop zawiera większość tych samych komponentów

Co to jest szyfrowanie asymetryczne?

Co to jest szyfrowanie asymetryczne?

Algorytmy szyfrowania asymetrycznego wykorzystują dwa różne klucze. Jeden klucz służy do szyfrowania, a drugi do deszyfrowania.

Steam Deck: Jak sformatować kartę SD

Steam Deck: Jak sformatować kartę SD

Steam Deck jest dostępny w trzech opcjach przechowywania: 64 GB eMMC, 256 GB NVMe SSD i 512 GB NVMe SSD. W zależności od biblioteki gier i rozmiaru gier