Számítógép sematikus felépítése. Little Man Computer (LMC)



Hasonló dokumentumok
7. Fejezet A processzor és a memória

Adatok ábrázolása, adattípusok. Összefoglalás

7. fejezet: A CPU és a memória

8. Fejezet Processzor (CPU) és memória: tervezés, implementáció, modern megoldások

8. Fejezet Processzor (CPU) és memória: tervezés, implementáció, modern megoldások

Memóriák - tárak. Memória. Kapacitás Ár. Sebesség. Háttértár. (felejtő) (nem felejtő)

Számítógépek felépítése, alapfogalmak

1. Fejezet: Számítógép rendszerek

Mikroprocesszor CPU. C Central Központi. P Processing Számító. U Unit Egység

Számítógépek felépítése

Mikrokontrollerek. Tihanyi Attila május 8

ELŐADÁS SZÁMÍTÓGÉP MŰKÖDÉSE FIZIKA ÉS INFORMATIKA

Számítógép Architektúrák

Programozás I gyakorlat

ARM Cortex magú mikrovezérlők

A Számítógépek felépítése, mőködési módjai

DSP architektúrák Texas Instruments DSP architektúrák

1. Az utasítás beolvasása a processzorba

Az integrált áramkörök kimenetének kialakítása

Egyszerű RISC CPU tervezése

Számítógép Architektúrák I-II-III.

A számítógép alapfelépítése

VHDL szimuláció. Tervezés. Labor II. Dr. Hidvégi Timót

Adatok ábrázolása, adattípusok

VLIW processzorok (Működési elvük, jellemzőik, előnyeik, hátrányaik, kereskedelmi rendszerek)

Számítógépek felépítése, alapfogalmak

4. Fejezet : Az egész számok (integer) ábrázolása

A MiniRISC processzor

Operandus típusok Bevezetés: Az utasítás-feldolgozás menete

A processzor. Dr. Seebauer Márta. Budapesti Műszaki Főiskola Regionális Oktatási és Innovációs Központ Székesfehérvár

I+K technológiák. Beágyazott rendszerek 1. előadás Aradi Szilárd

Digitális hálózatok: Digitális hálózati elemek struktúrális felépítése, CMOS alkalmazástechnika. Somogyi Miklós

Számítógép felépítése

Vezérlőegység. Dr. Seebauer Márta. Budapesti Műszaki Főiskola Regionális Oktatási és Innovációs Központ Székesfehérvár

2. Fejezet : Számrendszerek

Megszakítás, DMA, fejlett I/O módok Memória típusok, cache, MMU Párhuzamos végrehajtás, pipeline, szuperskalár, vektor proc.

1. ábra: Perifériára való írás idődiagramja

Számítógép architektúrák. Tartalom. A memória. A memória

6. óra Mi van a számítógépházban? A számítógép: elektronikus berendezés. Tárolja az adatokat, feldolgozza és az adatok ki és bevitelére is képes.

Számítógép hálózatok gyakorlat

Digitális rendszerek. Utasításarchitektúra szintje

The Architecture of Computer Hardware and Systems Software: An InformationTechnology Approach 3. kiadás, Irv Englander John Wiley and Sons 2003

Bevitel-Kivitel. Eddig a számítógép agyáról volt szó. Szükség van eszközökre. Processzusok, memória, stb

2016/08/31 02:45 1/6 Hardver alapok

Lemezkezelés, RAID, partícionálás, formázás, defragmentálás.

2016/06/23 07:47 1/13 Kérdések

Egyszerű áramkörök vizsgálata

1. Fejezet: Számítógép rendszerek. Tipikus számítógép hirdetés

Számoló és számítógépek

Máté: Számítógép architektúrák

A számítógép egységei

Számítógép architektúrák I. Várady Géza

TANMENET. Tantárgy: Informatika Osztály: 9B. Heti óraszám: 2

Számítógép Architektúrák (MIKNB113A)

Elemi adatszerkezetek

3. Térvezérlésű tranzisztorok

Vodafone ReadyPay. Használati útmutató

2017/12/16 21:33 1/7 Hardver alapok

Gábor Dénes Főiskola Győr. Mikroszámítógépek. Előadás vázlat. 2004/2005 tanév 4. szemeszter. Készítette: Markó Imre 2006

HÁLÓZATSEMLEGESSÉG - EGYSÉGES INTERNET SZOLGÁLTATÁS-LEÍRÓ TÁBLÁZAT

Számítógép Architektúrák (MIKNB113A)

Programozás alapjai Bevezetés

Bevezetés az informatikába

Járműfedélzeti rendszerek I. 3. előadás Dr. Bécsi Tamás

Dr. Oniga István. DIGITÁLIS TECHNIKA 10 Memóriák

Bevitel-Kivitel. Bevitel-Kivitel és Perifériák. Algoritmusok és Alkalmazásaik Tanszék Budapest december 16.

1. Mit tárol a memória? 1 pont. 2. Miért kell rendszerlemezzel rendelkeznünk? 1 pont Karikázza be a helyes válasz betűjelét

Autóipari beágyazott rendszerek. Fedélzeti elektromos rendszer

BEVEZETÉS. A felsorolt eszközök közül melyik periféria? a) VLSI b) ALU c) CPU d) Modem

2. Számítógépek működési elve. Bevezetés az informatikába. Vezérlés elve. Külső programvezérlés... Memória. Belső programvezérlés

EPER E-KATA integráció

DIGITÁLIS ADATTÁRAK (MEMÓRIÁK)

Számítógép Architektúrák

Dr. Schuster György február 21. Real-time operációs rendszerek RTOS

Digitális technika II. (vimia111) 5. gyakorlat: Tervezés adatstruktúra-vezérlés szétválasztással, vezérlőegység generációk

Dr. Oniga István. DIGITÁLIS TECHNIKA 10 Memóriák

Mágneses szuszceptibilitás vizsgálata

9. Fejezet: Input/Output

Multimédia hardver szabványok

BEVEZETÉS AZ INFORMATIKÁBA - SZÁMÍTÓGÉP ARCHITEKTÚRÁK. Háber István Ihaber@pmmik.pte.hu

Digitális technika (VIMIAA01) Laboratórium 1

Számítógép Architektúrák

Szervezeti formák bemutatása

DIGITÁLIS TECHNIKA 7. Előadó: Dr. Oniga István

MATEMATIKA ÉRETTSÉGI TÍPUSFELADATOK KÖZÉPSZINT Függvények

Az első lépések. A Start menüből válasszuk ki a Minden program parancsot. A megjelenő listában kattintsunk rá az indítandó program nevére.

Processzor (CPU - Central Processing Unit)

A PC története. Informatika alapjai-9 Személyi számítógép (PC) 1/12. (Personal computer - From Wikipedia, the free encyclopedia)

Számítógépes alapismeretek

Egyre nagyobb profitot generálnak a mobiltelefonnal végzett vásárlások, és egyre többet hezitálunk vásárlás előtt

Párhuzamos programozás

Az INTEL D-2920 analóg mikroprocesszor alkalmazása

A mikroprocesszor egy RISC felépítésű (LOAD/STORE), Neumann architektúrájú 32 bites soft processzor, amelyet FPGA val valósítunk meg.

5-6. ea Created by mrjrm & Pogácsa, frissítette: Félix

ELEKTRONIKAI ALAPISMERETEK

Vektoros elemzés végrehajtása QGIS GRASS moduljával 1.7 dr. Siki Zoltán

Fábián Zoltán Hálózatok elmélet

A SZÁMÍTÓGÉP FELÉPÍTÉSE.

DSP architektúrák dspic30f család

Felhasználói kézikönyv

Átírás:

7. Fejezet A processzor és a memória Hardver és Szoftver rendszerek architektúrája: Egy Információ Technológiai Szemlélet 3. kiadás, Irv Englander John Wiley and Sons 2003 Wilson Wong, Bentley College Linda Senne, Bentley College A CPU három fő része ALU (Arithmetic/Logic Unit = Aritmetikai/Logikai Egység) Számítási (aritmetikai és logikai), ill. összehasonlító műveleteket hajt végre a tárolt adatokon (regiszterek tartalma változik) CU (ControlUnit = Vezérlő Egység) Vezérli az utasítás-végrehajtást (fetch/executeciklusokat) Funkciók: p A CPU regisztereiben az adatokkal végez műveleteket (nem változnak meg az adatok) p Beolvassa a program utasításait és parancsokat ad az ALU-nak Részei: p Memory Management Unit (Memória Vezérlő Egység): p Felügyeli a fetch -elését, az utasításoknak és adatoknak p I/O Interfész p néha egybeépítik a memória vezérlővel, melyet Bus Interface Unit-nak nevezünk Regiszterek Példa: Program counter (PC program számláló) vagy instruction pointer (utasítás mutató) meghatározza a következő utasítást a futtatáshoz 7-2 1

Számítógép sematikus felépítése 7-3 Little Man Computer (LMC) 7-4 2

Regiszterek A regiszterek tulajdonságai Kicsi, permanens (nem múlékony) tárolóhelyek a CPU-n belül, amiket a számolások részeredményeinek tárolására használ A Vezérlő Egység (CU) vezérli őket Speciális használatra vannak tervezve általában mindegyik adott feladatot lát el Tároló méretük néhány bit, ill. byte Tárolhat adatot, címet és utasítást Hány regisztere van az LMC-nek? 7-6 3

Regiszterek Regiszterek használata Scratchpad ( vázltfüzet ) az aktuálisan futó program számára p A gyakran használt, ill. gyorsan elérendő adatokat tárolja A CPU és a futó programra vonatkozó információt tárolja p A következő program utasítás címe p Külső eszközökből érkező jelek általános, ill. speciális célú regisztereket különböztetünk meg Általános célú regiszterek Felhasználó számára láthatóak Megszakítási és adat értékeket tartalmaz Megegyezik az LMC számológépével Minden processzorban van néhány tucat 7-7 Speciális célú regiszterek Program Count Register = Program számláló regiszter (PC) Instruction pointernek (utasítás mutatónak) is hívjuk Instruction Register = Utasítás regiszter (IR) Memóriából származó utasításokat tartalmaz Memory Address Register = Memória Cím Regiszter (MAR) Memory Data Register = Memória Adat Regiszter (MDR) Status Registers = Állapot Regiszterek A processzor és a futó program állapotát tartalmazza Flag-eket (jelzőbit) (egybites logikai változókat) tartalmaz, p p nyomon követhessük a számítógép működését túlcsordulás, ill. carry, elektromos kimaradás, egyéb belső hibák stb. 7-8 4

Regiszter műveletek Más helyekről származó értékek tárolása (regiszterek és memóriák) Összeadás és kivonás Bit műveletek (Shift, Rotate Eltolás, Felcserélés) A regiszter tartalmának ellenőrzése, pl.: nulla vagy pozitív 7-9 Memória 5

A memória működése Minden memóriatartomány egyedi címmel rendelkezik Az utasítás címe a Memória Cím Regiszterbe kerül, amely megtalálja a helyét a memóriában A processzor határozza meg, hogy tároljon vagy olvasson adatot A Memória Adat Regiszter és a memória közötti szállítási helyet igényel A Memória Adat Regiszter kétirányú regiszter 7-11 Kapcsolatok a MAR, a MDR és a memoria között Cím adatok 7-12 6

MAR-MDR példa 7-13 A memória működésének vizuális leírása 7-14 7

Egy memória cella működése Két kapcsoló: Olvasás (Read) Írás (write) Két vezérlő áramkör (AND), három vezérlő jellel: address line activate line R/W line Információt tároló memória cella 7-15 Memória-kapacitás Két tényező határozza meg 1. A MAR bit-jeinek száma p LMC = 100 (00-99) p 2 K, ahol K = a regiszter szélessége bit-ekben 2. Az utasításban szereplő cím rész (operandus) mérete p 4 bit 16 helyet tudunk megkülönböztetni p 8 bit enged 256 helyet tudunk megkülönböztetni p 32 bit 4,294,967,296 vagy 4 Giga helyet tudunk megkülönböztetni A memória mérete lényegesen befolyásolja a számítógép teljesítményét A kevés memória arra kényszeríthetheti a processzort, hogy 50%-alatt dolgozzon 7-16 8

RAM: Random Access Memory (Véletlen elérésű memória) RAM eredetileg mágnesezhető tároló cellák, ma DRAM és SRAM DRAM (Dynamic RAM=Dinamikus memória) Ma a legáltalánosabban használt, olcsó Volatilis tároló: feszültség kikapcsolásával elvész a tartalma Tartalmát hamar elveszti : másodpercenként kb. 1000-szer kell újraírni a tartalmát az értékek tárolásához SRAM (Statikus RAM) Gyorsabb és drágább, mint a DRAM (más gyártási technológiája) Volatilis tároló: feszültség kikapcsolásával elvész a tartalma Keveset használnak belőle a cache memóriában, a gyors eléréshez 7-17 ROM - Read Only Memory (Csak olvasható memória) Stabil, nem volatilis tároló olyan programok tárolásához, amelyek nem változnak Mágneses magmemória EEPROM Electrically Erasable Programmable ROM (Elektromosan törölhető és programozható ROM) Lassabb és kevésbé rugalmasan használható, mint a FLASH ROM Flash ROM Gyorsabb, mint a merevlemezek, de sokkal drágább is Felhasználási területek: p p BIOS: BOOT program, diagnosztikai programok Digitális kamerák 7-18 9

CPU utasítások végrehajtása Fetch-Execute ciklus A CPU műveletek végrehajtása két ciklusra osztjuk (két memória hozzáférésre) mind a utasítás kódja, mind az az adat, amin a utasítást végrehajtjuk a memóriában van tárolva Fetch Megkeressük, ill. dekódoljuk az utasítást, a memóriából a regiszterekbe töltjük és jelzést küldünk az ALU-nak Execute Végrehajtjuk azt a műveletet, amit az utasítás kódol Adatokat mozgatjuk, ill. módosítjuk 7-20 10

LMC vs. CPU Fetch és Execute ciklus 7-21 A LOAD utasítás Fetch/Execute ciklusa 1. PC -> MAR 2. MDR -> IR 3. IR(address) -> MAR 4. MDR -> A 5. PC + 1 -> PC Az adatokat a PC-ből a MARba mozgatja Az adatokat az IR-be mozgatja Az utasítás cím része (operandus) betöltődik a MARba Az aktuális adatokat a tároló regiszterbe mozgatja A programszámláló növelése 7-22 11

A STORE utasítás Fetch/Execute ciklusa 1. PC -> MAR 2. MDR -> IR Az adatokat a PC-ből a MARba mozgatja Az adatokat az IR-be mozgatja 3. IR(address) -> MAR 4. A -> MDR* 5. PC + 1 -> PC Az utasítás cím részletei betöltődnek a MAR-ba A tároló regiszterből az MDRbe mozgatja az adatokat A programszámláló növelése *Vegyük észre, hogy a 4. pont hogyan változott meg a LOAD utasításhoz képest! Mikor történik a memória használata a két esetben? 7-23 Az ADD utasítás Fetch/Execute Ciklusa 1. PC -> MAR 2. MDR -> IR 3. IR(address) -> MAR 4. A + MDR -> A 5. PC + 1 -> PC Az adatokat a PC-ből a MARba mozgatja Az adatokat az IR-be mozgatja Az utasítások cím részletei betöltődnek a MAR-ba Az MDR tartalma a tár tartalmához adódik A programszámláló növelése 7-24 12

LMC utasításainak Fetch/Execute ciklusai Kivonás PC MDR IR[addr] MAR A MDR PC + 1 IR MAR A PC Bemenet PC MDR IOR PC + 1 MAR A IR PC Ugró (elágazás) utasítás PC MDR IR[addr] MAR IR PC Kimenet PC MDR A MAR IOR PC + 1 IR PC Szünet PC MDR MAR IR Feltételes (elágazás) ugró utasítás PC MDR MAR IR Ha a feltétel hamis: PC + 1 Ha a feltétel igaz: IR[addr] PC PC 7-25 Buszok 13

Busz Fizikai kapcsolat, ami lehetővé teszi az adatátvitelt a számítógépben két pont között Elektromos csatlakozások csoportja a két csomópont közötti jelátvitelhez Line (vonal): csatlakozási pont a buszon A jeleknek négy fajtáját különböztetjük meg 1. Adat (alfa-numerikus, numerikus, utasítások stb.) 2. Cím 3. Vezérlő jelek 4. Táp (néha) 7-27 Buszok a számítógépben Processzor és memória közötti busz Az I/O perifériák lehetnek azonos buszon acpu-val és a memóriával vagy külön buszon Ha a (plug-in) I/O elemek a CPU és a memória közötti buszt használják, akkor a fizikai egységet backplane-nek hívják Rendszerbusznak és külső busznak is hívják Ez jó példa a broadcast buszra A PC-kben általában ezeket az elemeket egy nyomtatott áramköri lapra az alaplapra (motherboard) integrálják p ez tartalmazza a CPU-t és összekapcsolja azt a többi komponenssel 7-28 14

Busz jellemzői Protokoll A kommunikáció jól dokumentált leírása Világosan megmagyarázza az összes vonal és a vonalakon lévő minden jel jelentését Adatátviteli kapacitás: az adat átvitel mértékegysége bit/másodperc Adatbusz szélessége: Az egyszerre átvihető adatok szélessége bitekben 7-29 Busz topológiák és üzenetváltás Pont-pont kapcsolat Többpontos kapcsolat Broadcast busz : minden elem megkapja a buszra kitett adatokat 7-30 15

Pont-pont kapcsolat vs. több pontos Plug-in eszköz Broadcast bus példa: Ethernet Az összetett eszközök mindegyike között van kapcsolat 7-31 Az alaplap Nyomtatott áramkör, melyen a processzor és egyéb fő elemek találhatók 7-32 16

Összeköttetések egy tipikus PC-ben Busz interface bridge-ek: különböző típusú buszokat kapcsolnak össze, átviszik az adatokat az egyik buszról a másikra 7-33 PCI bus-on használt jelek 7-34 17

Utasítások Utasítás A számítógépet vezérlő parancsok Végrehajtásukkor elektromos jelek hatására a számítógép egyes áramkörei különböző műveleteket hajtanak végre Utasítás készlet A tervező által meghatározott funkciók, melyet a processzor végre tud hajtani A különböző architektúrájú számítógépek között különbséget tehetünk a következő szempontok alapján: p Végrehajtható utasítások száma p Az egy utasítással végrehajtható műveletek bonyolultsága szerint p Támogatott (feldolgozható) adattípusok p Utasítások formátuma (kötött vagy változó hosszúság) p Regiszterek használata p Címzés (cím mérete, címzési módok) 7-35 Utasítás részei Műveleti kód (OP code): a feladat, amit a számítógépnek végre kell hajtani Forrás operandus Címek Eredmény operandus Adat helyének meghatározása (regiszter, memória) p Explicit: tartalmazza az utasítás p Implicit: alapértelmezés szerinti helyen OP code Forrás operandus Eredmény operandus 7-36 18

Utasítások formátuma Számítógép-specifikus leírás, mely meghatározza: műveleti kód hosszát Operandusok számát Operandusok hosszát Egy egyszerű 32-bites utasítás formátum 7-37 Utasítás formátumok: CISC 7-38 19

Utasítás formátumok: RISC 7-39 Utasítások típusai Adat átviteli műveletek (load: betöltés, store: tárolás) Általánosan használt, változatos megvalósítások A memória és a regiszterek közötti kapcsolat Mekkora a word adattípus? 16? 32? 64 bit? Aritmetikai utasítások operátorok: + - / * ^ Egész és lebegőpontos adatokon is végezhető Boolean logikai műveletek és relációs operátorok Relációs operátorok: > < = Logikai operátorok: AND, OR, XOR, NOR, és NOT Egyetlen operandusot használó utasítások Negáció, dekrementálás, inkrementálás 7-40 20

Egyéb utasítás típusok Bitmanipuláló utasítások Flag-ek (jelzőbitek) a feltételek tesztelésére Bitenkénti eltolás, ill. forgatás Program vezérlő utasítások Verem tár kezelő utasítások Összetett adatelemeken végzett utasítások I/O elemeket és számítógépet vezérlő utasítások 7-41 Regiszterben tárolt értékek eltolása és forgatása 7-42 21

Program vezérlő utasítások Program vezérlése Ugrás és elágazás utasítások Szubrutin hívása és visszatérés 7-43 Veremtár kezelő utasítások Veremtár kezelő utasítások LIFO (utolsó be, első ki) működés, információ tárolása Elemek kivétele fordított sorrendben történik, mint az elemek belehelyezése Beszúrás Kivétel 7-44 22

Szubrutin visszatérési címének tárolása állandó helyen : Oops! Hibás működés lehetséges!! 7-45 Veremtár a szubrutin visszatérési címének tárolására 7-46 23

Összetett adatkezelő utasítások Párhuzamosan hajt végre egyszerű műveleteket adatok csoportján SIMD: Single Instruction, Multiple Data p egy utasítás, több adat Intel MMX : 57 multimédiás utasítás Általánosan használják vektorok és tömbök feldolgozásakor 7-47 24