Počítadlo programu - Program counter

Přední panel IBM 701 počítač představený v roce 1952. Světla uprostřed zobrazují obsah různých registrů. The počítadlo instrukcí je vlevo dole.

The počítadlo programů (PC), běžně nazývaný ukazatel instrukce (IP) v Intel x86 a Itanium mikroprocesory, a někdy nazýván registr adresy instrukce (IAR),[1] the počítadlo instrukcí,[2] nebo jen část instrukčního řadiče,[3] je registr procesoru to naznačuje, kde a počítač je v jeho program sekvence.[poznámka 1]

Počítač se obvykle po načtení zvýší návod a drží adresa paměti z („bodů až ") další instrukce, která by byla provedena.[4][pozn. 2]

Procesory obvykle načítají instrukce postupně z paměti, ale kontrolní přenos instrukce mění sekvenci umístěním nové hodnoty do PC. Tyto zahrnují větve (někdy nazývané skoky), podprogram hovory a se vrací. Převod, který je podmíněn pravdivostí nějakého tvrzení, umožňuje počítači sledovat jinou sekvenci za různých podmínek.

Větev poskytuje, že další instrukce je načtena z jiného místa v paměti. Volání podprogramu nejen větví, ale někde uloží předchozí obsah počítače. Návrat načte uložený obsah počítače a umístí jej zpět do počítače a pokračuje v postupném provádění pomocí instrukce následující po volání podprogramu.

Hardwarová implementace

Jednoduše centrální procesorová jednotka (CPU), PC je a digitální počítadlo (což je původ výrazu „čítač programu“), který může být jedním z několika hardwaru registry. The instruktážní cyklus[6] začíná na vynést, ve kterém CPU umístí hodnotu PC na adresní sběrnice poslat do paměti. Paměť reaguje odesláním obsahu tohoto paměťového umístění na datová sběrnice. (To je počítač s uloženým programem model, ve kterém jeden paměťový prostor obsahuje jak spustitelné instrukce, tak běžná data.[7]) Po načtení CPU pokračuje do provedení, provedením určité akce na základě obsahu paměti, který získal. V určitém okamžiku tohoto cyklu bude počítač upraven tak, aby následující prováděná instrukce byla odlišná (obvykle se zvýší tak, že další instrukce je ta, která začíná na adrese paměti bezprostředně následující po posledním paměťovém místě aktuální instrukce) .

Stejně jako ostatní registry procesorů může být PC bankou binárních západek, z nichž každý představuje jeden bit hodnoty PC.[8] Počet bitů (šířka PC) se vztahuje k architektuře procesoru. Například „32bitový“ procesor může používat 32 bitů, aby byl schopen adresovat 232 jednotky paměti. U některých procesorů závisí šířka programového čítače místo toho na adresovatelné paměti; například některé Řadiče AVR mít počítač, který se omotá po 12 bitech.[9]

Pokud je PC binární čítač, může se zvýšit, když se na jeho vstup COUNT UP aplikuje puls, nebo CPU může vypočítat nějakou jinou hodnotu a načíst ji do PC pulzem na svůj vstup LOAD.[10]

K identifikaci aktuální instrukce může být PC kombinováno s jinými registry, které identifikují a segment nebo strana. Tento přístup umožňuje PC s méně bity za předpokladu, že většina požadovaných paměťových jednotek je v aktuálním okolí.

Důsledky v architektuře strojů

Použití počítače, který obvykle zvyšuje, předpokládá, že to, co počítač dělá, je provádění obvykle lineární sekvence pokynů. Takový počítač je pro von Neumannova architektura. Programátoři tak píší sekvenčně regulační tok i pro algoritmy, které nemusí být sekvenční. Výsledný "von Neumann úzké místo “Vedlo k výzkumu paralelních výpočtů,[11] včetně non-von Neumanna nebo datový tok modely, které nepoužívaly počítač; například namísto zadání postupných kroků může programátor na vysoké úrovni určit požadované funkce a nízkoúrovňový programátor to může určit pomocí kombinační logika.

Tento výzkum také vedl ke způsobům, jak zajistit rychlejší běh konvenčních procesorů založených na PC, včetně:

Důsledky v programování na vysoké úrovni

Moderní programovací jazyky na vysoké úrovni stále sledují model sekvenčního provádění a běžným způsobem identifikace programovacích chyb je skutečně „provedení procedury“, při kterém prst programátora identifikuje místo provedení jako PC. Jazyk na vysoké úrovni je v podstatě strojovým jazykem virtuálního stroje,[12] příliš složitý na to, aby byl vytvořen jako hardware, ale místo toho emulovaný nebo interpretován softwarem.

Nové programovací modely však převyšují programování sekvenčního provádění:

  • Při psaní a vícevláknové program, programátor může zapsat každé vlákno jako posloupnost pokynů, aniž by specifikoval načasování jakékoli instrukce vzhledem k instrukcím v jiných vláknech.
  • v programování řízené událostmi může programátor psát sekvence pokynů, na které má reagovat Události bez zadání celkové posloupnosti programu.
  • v programování toku dat, programátor může zapsat každou část výpočtu potrubí bez zadání časování vzhledem k ostatním částem.

Symbol

Prodejci používají různé znaky, aby symbolizovali počítadlo programu montážní jazyk programy. Zatímco použití znaku "$" převládá v Intel, Zilog, Texas Instruments, Toshiba, NEC, Siemens a AMD dokumentace procesoru, Motorola, Rockwell Semiconductor, Technologie mikročipů a Hitachi místo toho použijte znak „*“,[9] zatímco Mikroelektronika SGS-Thomson používá „PC“.[9]

Viz také

Poznámky

  1. ^ Pro moderní procesory je koncept „tam, kde je v pořadí“ příliš zjednodušující paralelismus na úrovni instrukcí a provedení mimo objednávku může nastat.
  2. ^ V procesoru, kde přírůstek předchází načtení, počítač ukazuje na právě prováděnou instrukci. V některých procesorech počítač ukazuje určitou vzdálenost za aktuální instrukcí; například v ARM7, hodnota PC viditelná programátorem ukazuje za aktuální instrukci a za slot pro zpoždění.[5]

Reference

  1. ^ Medovina, Carver; Conway, Lynn (1980). Úvod do systémů VLSI. Reading, USA: Addison-Wesley. ISBN  0-201-04358-0.
  2. ^ Principy provozu, typ 701 a související zařízení (PDF). IBM. 1953.
  3. ^ Harry Katzan (1971), Organizace počítačů a systém / 370, Společnost Van Nostrand Reinhold, New York, USA, LCCCN 72-153191
  4. ^ Silberschatz, Abraham; Gagne, Greg; Galvin, Peter B. (duben 2018). Koncepty operačního systému. Spojené státy: Wiley. 27, G-29. ISBN  978-1-119-32091-3.
  5. ^ „ARM Developer Suite, Assembler Guide. Verze 1.2“. ARM Limited. 2001. Citováno 2019-10-18.
  6. ^ John L. Hennessy a David A. Patterson (1990), Počítačová architektura: kvantitativní přístup, Nakladatelé Morgan Kaufmann, Palo Alto, USA, ISBN  1-55860-069-8
  7. ^ B. Randall (1982), Počátky digitálních počítačů, Springer-Verlag, Berlín, D
  8. ^ C. Gordon Bell a Allen Newell (1971), Počítačové struktury: čtení a příklady, McGraw-Hill Book Company, New York, USA
  9. ^ A b C Arnold, Alfred (2020) [1996, 1989]. "E. Předdefinované symboly". Macro Assembler AS - Uživatelská příručka. V1.42. Přeložil Arnold, Alfred; Hilse, Stefan; Kanthak, Stephan; Sellke, Oliver; De Tomasi, Vittorio. p. Tabulka E.3: Předdefinované symboly - část 3. Archivováno od původního dne 2020-02-28. Citováno 2020-02-28. 3.2.12. WRAPMODE […] AS bude předpokládat, že čítač programu procesoru nemá plnou délku 16 bitů danou architekturou, ale délku, která je přesně dostatečná pro adresování interní ROM. Například v případě AT90S8515, to znamená 12 bitů, což odpovídá 4 kB nebo 8 kB. Tento předpoklad umožňuje relativní větve od začátku do konce ROM a naopak, což by při použití přísné aritmetiky vedlo k chybě mimo větev. Zde fungují, protože přenosové bity vyplývající z výpočtu cílové adresy jsou zahozeny. […] V případě výše uvedené AT90S8515 je tato možnost dokonce nezbytná, protože je to jediný způsob, jak provést přímý skok přes celý adresní prostor […]
  10. ^ Walker, B. S. (1967). Úvod do počítačového inženýrství. Londýn, Velká Británie: University of London Press. ISBN  0-340-06831-0.
  11. ^ F. B. Chambers, D. A. Duce a G. P. Jones (1984), Distribuované výpočty, Akademický tisk, Orlando, USA, ISBN  0-12-167350-2
  12. ^ Douglas Hofstadter (1980), Gödel, Escher, Bach: věčný zlatý cop, Knihy tučňáků, Harmondsworth, Velká Británie, ISBN  0-14-005579-7