Aliohjelmien toteutus Suoritin ja väylä

Samankaltaiset tiedostot
Luento 4 (verkkoluento 4) Aliohjelmien toteutus

Luento 4 (verkkoluento 4) Aliohjelmien toteutus

Luento 5 (verkkoluento 5) Suoritin ja väylä

Luento 4 Aliohjelmien toteutus. Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio

Luento 4 Aliohjelmien toteutus

Luento 4 Aliohjelmien toteutus

Luento 4 Aliohjelmien toteutus

Kertausluento 2 (lu04, lu05, lu06) Aliohjelmien toteutus Suoritin, väylä, tiedon esitys

Luento 4 Aliohjelmien toteutus

Tietokoneen toiminta Copyright Teemu Kerola Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio

Jakso 4 Aliohjelmien toteutus

Jakso 5 Suoritin ja väylä

Jakso 5 Suoritin ja väylä

Jakso 4 Aliohjelmien toteutus

Jakso 5 Suoritin ja väylä. Suorittimen rakenne Väylän rakenne Käskyjen suoritussykli Poikkeukset ja keskeytykset TTK-91:n ja KOKSI:n rakenne

Aliohjelmatyypit (2) Jakso 4 Aliohjelmien toteutus

Jakso 4 Aliohjelmien toteutus

Suoritin. Luento 5 Suoritin ja väylä. TTK-91 suorittimen rakenne (1) TTK-91 muistin rakenne. Käskyjen nouto- ja suoritussykli (5)

Luento 5 Suoritin ja väylä

Jakso 4 Aliohjelmien toteutus. Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio

Suoritin. Jakso 5 Suoritin ja väylä. TTK-91 muistin rakenne. TTK-91 suorittimen rakenne

Suoritin. Luento 5 Suoritin ja väylä. TTK-91 muistin rakenne. TTK-91 suorittimen rakenne

Aliohjelmatyypit (2) Jakso 4 Aliohjelmien toteutus

Luento 5 Suoritin ja väylä

Luento 5 (verkkoluento 5) Suoritin ja väylä

Luento 5 Suoritin ja väylä

Luento 5 Suoritin ja väylä

Suoritin. Luento 5 Suoritin ja väylä. TTK-91 suorittimen rakenne (1) TTK-91 muistin rakenne

Luento 2 (verkkoluento 2) Ttk-91 järjestelmä

Jakso 12 Yhteenveto. Keskeiset asiat Teemu Kerola, K2000

Tietokoneen toiminta, K Tavoitteet (4)

Luento 2 (verkkoluento 2) Ttk-91 järjestelmä

1. Keskusyksikön rakenne

LOAD R1, =2 Sijoitetaan rekisteriin R1 arvo 2. LOAD R1, 100

Sisältöä. Tietokoneen rakenne. Ch 1 - Ch 8 [Sta06] Valikoituja paloja TITO-kurssista. Tietokonejärjestelmä

Tietokonejärjestelmä. Tietokoneen rakenne. Ch 1 - Ch 8 [Sta06] Valikoituja paloja. TITO-kurssista. John von Neumann ja EDVAC, 1949.

Luento 3 (verkkoluento 3) Ttk-91 konekielinen ohjelmointi. Ohjelman esitysmuoto Konekielinen ohjelmointi ttk-91:llä (Titokone, TitoTrainer)

Muistihierarkia Kiintolevyt I/O:n toteutus

Monipuolinen esimerkki

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Jakso 2 TTK-91 -tietokone ja sen KOKSI -simulaattori

Teemun juustokakku Rekisterien, välimuistin, muistin, levymuistin ja magneettinauhan nopeudet suhteutettuna juuston hakuaikaan juustokakkua tehdessä?

Jakso 2 TTK-91 -tietokone ja sen KOKSI -simulaattori

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Luento 2 TTK-91 tietokone ja sen simulaattori. Miksi konekieltä? Tietokone TTK-91. Miksi ei oikeaa konekieltä? TTK-91 (1) TTK-91 laitteisto

Järjestelmän ulkoinen muisti I/O

Jakso 2 TTK-91-tietokone ja sen KOKSI-simulaattori

Miksi konekieltä? Jakso 2 TTK-91-tietokone ja sen KOKSI-simulaattori. Tietokone TTK-91. Miksi ei oikeaa konekieltä?

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori. Miksi konekieltä? Tietokone TTK-91. Miksi ei oikeaa konekieltä?

Miksi konekieltä? Jakso 2 TTK-91-tietokone ja sen KOKSI-simulaattori. Tietokone TTK-91. Miksi ei oikeaa konekieltä? TTK-91: rekisterit

Jakso 2 TTK-91-tietokone ja sen KOKSI-simulaattori

Miksi konekieltä? Jakso 2 TTK-91-tietokone ja sen KOKSI-simulaattori. Tietokone TTK-91. Miksi ei oikeaa konekieltä? TTK-91: tietotyypit (2)

Tietokoneen toiminta, Kevät Copyright Teemu Kerola Järjestelmän eri tasot Laitteiston nopeus

Ongelma(t): Miten mikro-ohjelmoitavaa tietokonetta voisi ohjelmoida kirjoittamatta binääristä (mikro)koodia? Voisiko samalla algoritmin esitystavalla

Kertausluento 1 (lu01, lu02, lu03) Tietokonejärjestelmän rakenne ttk-91 ja sillä ohjelmointi

Tavoitteet (4) Luento 12 Yhteenveto. Keskeisiä asioita. Mitä hyötyä tästä on? (2) Esimerkkikone: TTK-91 laitteisto suoritin - CPU

Luento 12 Yhteenveto. Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat?

Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Teemu Kerola, Copyright Tavoitteet (4)

Kertausluento luennoista 1-3 1

Luento 12 Yhteenveto. Tavoitteet. Keskeisiä asioita. Mitä hyötyä tästä on? Esimerkkikone: TTK-91 laitteisto. Tietokoneen toiminta 27.4.

Tietokoneen toiminta Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Teemu Kerola, Copyright 2003

Luento 12 Yhteenveto. Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Teemu Kerola, Copyright 2010

Luento 12 Yhteenveto

Tietokoneen toiminta Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Teemu Kerola, Copyright 2010

Muistihierarkia Kiintolevyt I/O:n toteutus

Jakso 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Tieto ja sen osoite (3) Jakso 3 Konekielinen ohjelmointi (TTK-91, KOKSI) Osoitinmuuttujat. Tieto ja sen osoite (5)

Luento 12 Yhteenveto

Jakso 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Luento 12 Yhteenveto. Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? 29/01/2001 Teemu Kerola, Copyright 2001

Tietokoneen toiminta, K Tavoitteet (4)

Luento 12 Yhteenveto. Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Teemu Kerola, K2000

Luento 12 Yhteenveto

Ttk-91 esimerkkitietokone ja sen simulaattori

Tiedon sijainti suoritusaikana (3) Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI) Miten tietoon viitataan? (4)

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Jakso 3 Konekielinen ohjelmointi (TTK-91, KOKSI) Muuttujat Tietorakenteet Kontrolli Optimointi Tarkistukset

Jakso 8 Ohjelman toteutus järjestelmässä

Luento 1 (verkkoluento 1) Ohjelman sijainti Ohjelman esitysmuoto Laitteiston nopeus

Ongelma(t): Miten tietokoneen käyttöjärjestelmä toimii sisäisesti, jotta resurssit saadaan tehokkaaseen käyttöön?

Jakso 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Jakso 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI) Muuttujat Tietorakenteet Kontrolli Optimointi Tarkistukset

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Luento 1 Tietokonejärjestelmän rakenne

Luento 1 (verkkoluento 1) Tietokonejärjestelmä

Luento 1 Tietokonejärjestelmän rakenne. Järjestelmän eri tasot Laitteiston nopeus

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI) Muuttujat Tietorakenteet Kontrolli Optimointi Tarkistukset

Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI) Muuttujat Tietorakenteet Kontrolli Optimointi Tarkistukset

Jakso 10 Ohjelman suoritus järjestelmässä

TIEP114 Tietokoneen rakenne ja arkkitehtuuri, 3 op. Assembly ja konekieli

Tiedon sijainti suoritusaikana. Luento 3 Konekielinen ohjelmointi (TTK-91, KOKSI)

Luento 10 Käännös, linkitys ja lataus

Jakso 10 Ohjelman suoritus järjestelmässä. Käännös Linkitys Dynaaminen linkitys Lataus

2 Konekieli, aliohjelmat, keskeytykset

Jakso 10 Ohjelman suoritus järjestelmässä

Transkriptio:

Aliohjelmien toteutus Suoritin ja väylä Tyypit, Parametrit Aktivointitietue (AT) AT-pino, rekursio Käskyjen suoritussykli Suorittimen tilat Poikkeukset ja keskeytykset 1

Aliohjelmatyypit Korkean tason ohjelmointikielen käsitteet aliohjelma, proseduuri parametrit funktio parametrit, paluuarvo metodi parametrit, ehkä paluuarvo Konekielitason vastaava käsite aliohjelma parametrit ja paluuarvo(t) 2

Parametrit ja paluuarvo Muodolliset parametrit määritelty aliohjelmassa ohjelmointihetkellä tietty järjestys ja tyyppi paluuarvot käsittely hyvin samalla tavalla kuin parametreillekin Todelliset parametrit ja paluuarvo todelliset parametrit sijoitetaan muodollisten parametrien Tulosta (int x, y) void Tulosta (int x, y) Laske(int x): int int Laske(int x) paikalle kutsuhetkellä suoritusaikana paluuarvo saadaan paluuhetkellä ja sitä käytetään kuten mitä tahansa arvoa Tulosta (5, apu); x = Laske( y+234); 3

Parametrityypit Arvoparametri välitetään parametrin arvo (eli sen kopio) kutsuhetkellä arvo voidaan lukea alkuperäistä arvoa ei voi muuttaa, mutta arvon kopiota voi muuttaa Viiteparametri välitetään parametrin osoite arvo ja osoite voidaan lukea, arvoa voi muuttaa Nimiparametri (ei yleensä käytetä) välitetään parametrin nimi nimi (merkkijono) kuvataan arvoksi kutsuhetkellä semantiikka määräytyy vasta kutsuhetkellä Swap(i, k); Swap(i, T[i]); tmp = i; i = T[i]; T[i] = tmp; #? 4

Aliohjelmien toteutuksen osat Paluuosoite kutsukohtaa seuraavan käskyn osoite Parametrien välitys Paluuarvon välitys Paikalliset muuttujat Rekisterien varaus (allokointi) Kutsuva ohjelman osa haluaa säilyttää käyttämiensä rekisterien arvot! pääohjelma, toinen aliohjelma, sama aliohjelma, metodi, Aliohjelman pitää aluksi tallettaa muistiin käytettävien rekisterien arvot ja lopuksi palauttaa ne ennalleen 5

Aktivointitietue (activation record, activation frame) Aliohjelman toteutus (ttk-91) funktion paluuarvo (tai kaikki paluuarvot) kaikkien (sisäänmeno- ja ulostulo-) parametrien arvot paluuosoite kutsukohdan aktivointitietue kaikki paikalliset muuttujat ja tietorakenteet FP aliohjelman ajaksi talletettujen rekistereiden alkuperäiset arvot int funca (int x,y); paluuarvo param x param y vanha PC vanha FP paik. m. i1 paik. m. i2 vanha R1 vanha R2-2 +1 kasvava muistiosoite 6

Aktivointitietueiden hallinta Aktivointitietueet (AT) varataan ja vapautetaan dynaamisesti (suoritusaikana) pinosta (muistista) SP (=R6) osoittaa pinon pinnalle Aktivointitietuepino FP (R7) osoittaa voimassa olevan AT:n sovittuun kohtaan (ttk-91: vanhan FP:n osoite) Pinossa olevaa AT:tä rakennetaan ja puretaan käskyillä: PUSH, POP, PUSHR, POPR CALL, EXIT (SVC, IRET) Talleta R0-R5 pinoon FP SP AT main AT sum AT funca kasvava muistiosoite 7

Aliohjelmakutsun toteutus Toteutus jaettu eri yksiköille Kutsuva rutiini CALL käsky Kutsuttu rutiini EXIT käsky Kutsuva rutiini varaa tilaa paluuarvolle pinosta laita parametrit (arvot tai osoitteet) pinoon talleta vanha PC ja FP, aseta uudet PC ja FP varaa tilaa paikallisille muuttujille talleta käytettävien rekistereiden vanhat arvot pinoon (itse aliohjelman toteutus varsinainen työ) palauta rekistereiden arvot vapauta paikallisten muuttujien tila palauta PC ja FP vapauta parametrien tila ota paluuarvo pinosta prolog epilog 8

int fa (int x, y) { int z = 5; } Aliohjelmaesimerkki z = x * z + y; return (z); käyttö: R DC 24 PUSH SP,=0 ; tila paluuarvolle PUSH SP, =200 PUSH SP, R muistista muistiin!! tämänhetkinen, nykyinen FP T = fa (200, R); FP arvo=1024 paluuarvo par x=200 par y=24 CALL SP, fa POP SP, R1 STORE R1, T 3.2.2011 Copyright Teemu Kerola 2003 talleta PC, FP aseta PC, kutsu & paluu palauta FP, PC 2. operandi aina rekisteri 9

(ei animointia) int fa (int x, y) { int z = 5; } Aliohjelmaesimerkki z = x * z + y; return (z); käyttö: R DC 24 PUSH SP,=0 ; ret. value space PUSH SP, =200 PUSH SP, R muistista muistiin!! tämänhetkinen, nykyinen FP T = fa (200, R); FP paluuarvo par x=200 par y=24 CALL SP, fa POP SP, R1 STORE R1, T 3.2.2011 Copyright Teemu Kerola 2003 talleta PC, FP aseta PC, kutsu & paluu palauta FP, PC 2. operandi aina rekisteri 10

Aliohjelmaesimerkki int fa (int x, y) { int z = 5; } Kaikki viitteet näihin tehdään suhteessa FP:hen z = x * z + y; return (z); T = fa (200, R); FP SP paluuarvo param x param y vanha PC vanha FP paik. z vanha R1 aliohjelman toteutus: retfa EQU -4 # params parx EQU -3 pary EQU -2 locz EQU 1 # local vars fa 3.2.2011 Copyright Teemu Kerola 2003 PUSH SP, =0 ; alloc Z PUSH SP, R1 ; save R1 LOAD R1,=5; init Z STORE R1, locz (FP) LOAD R1, parx (FP) MUL R1, locz (FP) ADD R1, pary (FP) STORE R1, locz (FP) STORE R1, retfa (FP) POP SP, R1; recover R1 SUB SP, =1 ; free Z EXIT SP, =2 ; 2 param. prolog epilog 11

(ei animointia) Aliohjelmaesimerkki int fa (int x, y) { int z = 5; } Kaikki viitteet näihin tehdään suhteessa FP:hen z = x * z + y; return (z); T = fa (200, R); FP SP paluuarvo param x param y vanha PC vanha FP paik. z vanha R1 aliohjelman toteutus: retfa EQU -4 parx EQU -3 pary EQU -2 locz EQU 1 fa 3.2.2011 Copyright Teemu Kerola 2003 PUSH SP, =0 ; alloc Z PUSH SP, R1 ; save R1 LOAD R1,=5; init Z STORE R1, locz (FP) LOAD R1, parx (FP) MUL R1, locz (FP) ADD R1, pary (FP) STORE R1, locz (FP) STORE R1, retfa (FP) POP SP, R1; recover R1 SUB SP, =1 ; free Z EXIT SP, =2 ; 2 param. prolog epilog 12

Porinaa Mieti ja kirjaa ttk-91 käskyt, joilla voisit Kutsua taulukon alkioiden keskiarvon laskevaa funktiota, esim: tulos = ka(tauluos, koko) Käyttää parametreja funktiossa Välittää tuloksen funktiosta kutsujalle Miksi KJ:n kutsurutiinista palataan IRET eikä EXIT käskyllä? Aliohjelmakutsun toteutukseen kuluu aika monta konekäskyä. Miten sen voisi tehdä nopeammaksi suorittaa? 13

Samalla tavalla kuin aliohjelman kutsu CALL käskyn asemesta SVC Tila paluuarvolle? Parametrit pinoon vai rekistereissä? SVC kutsu KJ-palvelun kutsu (proseduraalisesti) Kutsuttavan rutiinin numero operandina IRET paluu Paluuarvo (OK, virhe) pois pinosta tarkistusta varten fok = ReadBlock (fp, 64)... PUSH SP, =0 ;paluuarvo PUSH SP, =FileBuffer PUSH SP, CharCnt PUSH SP, FilePtr SVC SP, =ReadFile POP SP, R1 JNZER R1, FileTrouble 14

TTK-91 suorittimen rakenne regs R0 R1 sisäinen väylä ALU R2 R3 R4 R6 R5 R7 Kontrollisignaalit PC IR CU SR TR MMU muistiväylä BASE LIMIT MAR MBR kontrolliväylä osoiteväylä dataväylä Bus ctl 15

Käskyn suorittaminen Titokone näyttää vaiheet simuloimalla Store R4, @10(R1) ol. R1 =20, R4=15 Käskyn nouto ja ohjelmalaskurin kasvatus: PC->MAR, PC+1 -> PC, mem -> MBR, MBR -> IR Käskyn suoritus: R1+10->MAR, mem->mbr, MBR->MAR, R4->MBR, MBR->mem 16

TTK-91 konekäskyn rakenne Käskyn esitys bittitasolla on aina: OPER käskykoodi 8 bit field Rj 3 bit M 2 bit Ri 3 bit ADDR osoiteosa 16 bit field 31 24 21 19 16 15 0 Rj = käskyn ensimmäinen operandi Ri = indeksirekisteri (0 ei käytetä) M = muistinoutojen määrä toiseen operandiin (ennen mahdollista muistiin talletusta) (pienehkö) muistiosoite tai vakio (addressing mode) 00 eli 0 kpl, välitön osoitus (STORE: suora osoitus) 01 eli 1 kpl, suora osoitus (STORE: epäsuora osoit.) 10 eli 2 kpl, epäsuora osoitus (STORE: epäkelpo arvo) ( 11 eli 3 kpl, epäkelpo arvo poikkeustilanne ) 17

Käskyn purku ja tehollisen muistiosoitteen (EA) laskemisvaihe OPER käskykoodi Rj M Ri ADDR osoiteosa 8 bit field 3 bit 2 bit 3 bit 16 bit field 31 24 21 19 16 15 (bitti:) 0 Purku automaattisesti langoitettuna käskyrekisteristä (IR) Muistiosoitteen lasku, tulos tilapäisrekisteriin (TR) jos Ri=0, niin TR ADDR muutoin TR (Ri)+ADDR ALU suorittaa laskutoimituksen jos ADDR = 0, niin TR (Ri) Effective Address (EA) on nyt TR:ssä 3.2.2011 Copyright Teemu Kerola 2003 18

TTK-91 virtuaalimuisti Virtuaalinen osoiteavaruus 0 23 511 MMU < LIMIT? + BASE BASE: 1000 LIMIT: 512 Fyysinen osoiteavaruus 0 1023 1048575 suorittimen käyttämät osoitteet muistipiirien käyttämät osoitteet 19

Virtuaalimuistin osoitteenmuunnosmenetelmiä Kanta- ja rajarekisteriin perustuva base ja limit rekisterit (esim. ttk-91, 8086,...) Sivuttava sivutaulut virtuaaliavaruus jaettu saman kokoisiin sivuihin Segmentoiva Lisää tietoa? virtuaaliavaruus jaettu ohjelman mukaan erillisiin eri kokoisiin Lisää segmentteihin tietoa? koodi segmentti, data segmentti, käyttöjärjestelmä kurssi käyttöjärjestelmä kurssi 20

Keskeytysten käsittely Jokainen mahdollinen keskeytystyyppi on ennalta tunnettu, eli mitään todella yllättävää ei tapahdu Jokaiselle keskeytystyypille on oma käyttöjärjestelmän tuntema keskeytyskäsittelyrutiini Jokaisen käskyn suorituksen jälkeen tarkistetaan keskeytysten olemassaolo SR:stä ja haaraudutaan keskeytyskäsittelijään tarvittaessa joskus keskeytykset on estetty (ttk-91:ssä SR:n bitti D) paluu käsittelijästä return-from-interrupt-handler käskyllä (esim. IRET, tms) Yllättävä aliohjelmakutsu interrupt handler 21

Keskeytyskäsittelijä Osa käyttöjärjestelmää Ennen keskeytyskäsittelijään hyppäämistä asetetaan suoritin ja MMU etuoikeutettuun käyttöjärjestelmätilaan (supervisor state) SR:n bitti P on päällä => etuoikeutettu tila eli (P = Priviledged) käyttöjärjestelmä tila käyttöjärjestelmätilassa saa viitata mihin tahansa kohtaan muistia (MMU: BASE=0, LIMIT= hyvin iso ) käyttöjärjestelmätilassa saa käyttää kaikkia konekäskyjä (esim. IRET tai ClearCache) Käsittelijästä paluun yhteydessä MMU:n tila ja suorittimen tila asetetaan ennalleen 22

Suorittimen tilan muuttaminen user SVC, INT IRET Käyttäjätila etuoikeutettu tila keskeytys tai suora KJ:n palvelupyyntö (SVC käsky) keskeytyskäsittelijä tarkistaa onko (oliko) oikeutta tilan vaihtoon (interrupt handler) Etuoikeutettu tila käyttäjätila kernel etuoikeutettu konekäsky return from interrupt handler esim. IRET (Pentium II) palauttaa kontrollin keskeytyneeseen kohtaan ja suorittimen tilan keskeytystä edeltäneeseen tilaan 23

TTK-91 Nouto- ja suoritussykli vielä vähän tarkemmin Hae käsky PC++ M=2 M>0 pura käsky, laske osoite lue muistista M=0 pushr kirj. muistiin store push pushr suorita operaatio tarkista keskeytykset noutosykli Noutosykli suoritussykli 24

Porinaa Miten laitteisto tietää, onko kyseessä suora muistiosoitus tai epäsuora muistiosoitus? Voisiko seuraavaksi suoritettavaa käskyä hakea muistista samaan aikaan kun edellistä vasta suoritetaan? Mitä kaikkea keskeytyskäsittelijä tekee, jos tulee kokonaislukujen nollalla jako keskeytys? Hae käsky PC++ M=2 lue muistista M>0 pura käsky, M=0 laske osoite suorita operaatio pushr kirj. muistiin store push pushr tarkista keskeytykset noutosykli Noutosykli suoritussykli 25

TTK-91 koneen simulaattori Tavallinen Javalla kirjoitettu ohjelma TTK-91 koneen osat tietorakenteina rekisterit, MMU, CU, muisti Simuloi käskyjen suoritussykliä käsky kerrallaan Toteuttaa myös TTK-91 koneen käyttöjärjestelmän osat osana tavallista ohjelmaa assembler kääntäjä, lataaja, debugger, kesk. käsittelijät Graafinen käyttöliittymä Ks. Processor.java Titokoneen koodissa titokone.jar\fi\hu\cs\titokone\processor.java 26

TTK-91 käskyn suoritussykli hae käsky simuloidusta muistista IR = mem[pc] pura käsky osiin (OPER, Rj, M, Ri, ADDR) ja laske osoiteosan arvo TR (ADDR tai regs[ri]+addr) ADDR = IR mod 32768 TR = regs[ri] +ADDR tee tarvittava määrä (M) operandin hakuja muistista rekisteriin TR TR = mem[tr] valitse aliohjelma operaatiokoodin (OPER) perusteella if (opcodeok[oper] = FALSE) then SR.U = 1; simuloi konekäskyn suorituksen muutokset rekistereihin (R0 R7, SR, PC, MAR, MBR) ADD Rj, M ADDR(Ri) regs[rj] += TR; lopeta suoritus jos SVC tai keskeytys SR.O = 27

Väylät Kullakin laitteella oma osoite Yksi lähettää, kaikki kuulevat, vain oikea laite vastaanottaa Paljon erilaisia Lähellä suoritinta olevat ovat nopeampia 1 2 väylä 8 9 10 Lisää tietoa? Tietokoneen rakenne -kurssi 28

Väylähierarkia Tyypillinen Pentium II systeemin emolevy omalla lastulla, tason 1 välimuistin kanssa PCI to SCSI bridge 3.2.2011 Copyright Teemu Kerola 2003 Fig. 3-50 [Tane99] 29

M.Wilkes: EDSAC I (1949) -- Luennon 3 loppu -- rekisterit (6W), tyhjiöputkilla käsky- ja datamuisti, 32 elohopeaviiveputkea, 512W à 36b kertolasku 5.4ms, 650 IPS ensimmäinen stored program tietokone 3000 tyhjiöputkea, sähkökulutus 12 kw, tila 5x4m http://www.cl.cam.ac.uk/relics/archive_photos.html 30