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

Samankaltaiset tiedostot
Tietokoneen toiminta, K Tavoitteet (4)

Jakso 12 Yhteenveto. Keskeiset asiat Teemu Kerola, K2000

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)

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

Luento 12 Yhteenveto

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

Luento 12 Yhteenveto

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. Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Teemu Kerola, Copyright 2010

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

Luento 12 Yhteenveto

Luento 4 Aliohjelmien toteutus

Luento 4 Aliohjelmien toteutus

Jakso 4 Aliohjelmien toteutus

Luento 4 Aliohjelmien toteutus

Jakso 4 Aliohjelmien toteutus

Luento 4 (verkkoluento 4) Aliohjelmien toteutus

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

Luento 4 (verkkoluento 4) Aliohjelmien toteutus

Luento 1 Tietokonejärjestelmän rakenne

Aliohjelmatyypit (2) Jakso 4 Aliohjelmien toteutus

Luento 1 Tietokonejärjestelmän rakenne

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

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

Tiedon esitysmuodot. Luento 6 (verkkoluento 6) Lukujärjestelmät Kokonaisluvut, liukuluvut Merkit, merkkijonot Äänet, kuvat, muu tieto

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

Jakso 4 Aliohjelmien toteutus

Aliohjelmatyypit (2) Jakso 4 Aliohjelmien toteutus

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

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

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

Kertausluento luennoista 1-3 1

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

Luento 4 Aliohjelmien toteutus

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

Luento 1 (verkkoluento 1) Tietokonejärjestelmä

Käännös, linkitys ja lataus

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

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

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

Aliohjelmien toteutus Suoritin ja väylä

Muistihierarkia Kiintolevyt I/O:n toteutus

Aihepiiri Tietokoneen toiminta (Computer Organization I)

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

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

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Tietokoneen toiminta (Computer Organization I)

Tietokoneen toiminta (Computer Organization I)

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Tietokoneen toiminta (Computer Organization I)

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

Tietokoneen toiminta (Computer Organization I)

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

Aihepiiri Tietokoneen toiminta (Computer Organization I)

Tietokoneen toiminta (Computer Organization I)

Tietokoneen toiminta (Computer Organization I)

Luento 2 TTK-91 tietokone ja sen KOKSI simulaattori

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

Tietokoneen toiminta (Computer Organization I)

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

Tietokoneen toiminta (Computer Organization I)

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

1. Keskusyksikön rakenne

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

Jakso 10 Ohjelman suoritus järjestelmässä

Tietokoneen toiminta (Computer Organization I)

Tietokoneen toiminta (Computer Organization I)

Aihepiiri Tietokoneen toiminta (Computer Organization I) Tavoitteet (4) Mitä hyötyä tästä on? (4) Kurssien välisiä riippuvuuksia

Tietokoneen toiminta (Computer Organization I)

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

Tietokoneen toiminta (Computer Organization I)

Tietokoneen toiminta (Computer Organization I) Aihepiiri. Mitä hyötyä tästä on? (3) Tavoitteet. Kurssien välisiä riippuvuuksia

Tietokoneen toiminta (Computer Organization I)

Tietokoneen toiminta (Computer Organization I) Mitä hyötyä tästä on? (4) Kurssien välisiä riippuvuuksia. Aihepiiri.

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

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

Järjestelmän ulkoinen muisti I/O

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

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

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

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

Jakso 5 Suoritin ja väylä

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

Tiedon esitysmuodot. Luento 6 (verkkoluento 6) Lukujärjestelmät Kokonaisluvut, liukuluvut Merkit, merkkijonot Äänet, kuvat, muu tieto

Jakso 5 Suoritin ja väylä

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

Jakso 8 Ohjelman toteutus järjestelmässä

Jakso 10 Ohjelman suoritus järjestelmässä

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

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

Luento 10 Käännös, linkitys ja lataus. Käännös Linkitys Dynaaminen linkitys Lataus

Lausekielestä suoritukseen (3) Luento 10 Käännös, linkitys ja lataus. Assembler-kielinen käännösyksikkö (2) Käännösyksikkö (4) Objektimoduuli (8)

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

Lausekielestä suoritukseen (3) Luento 10 Käännös, linkitys ja lataus. Assembler-kielinen käännösyksikkö (2) Objektimoduuli (2) Symbolitaulu

Muistihierarkia Kiintolevyt I/O:n toteutus

Jakso 8 Ohjelman toteutus järjestelmässä

Transkriptio:

Keskeiset asiat Mitä hyötyä tästä on? Mitä seuraavaksi? Kurssit? Asiat? Luento 12 Yhteenveto 1 Tavoitteet Ymmärtää tietokonejärjestelmän keskeiset piirteet sillä suoritettavan ohjelman näkökulmasta Miten tietokonejärjestelmä suorittaa sille annettua ohjelmaa? Minkälaista koodia suoritin ymmärtää? Mikä on käyttöjärjestelmän rooli? 2 Luento 12, Yhteenveto 1

Mitä hyötyä tästä on? Ohjelman suoritusnopeus perustuu suorittimen (CPU) suorittamiin konekäskyihin, ei pelkästään ohjelman korkean tason esitysmuotoon Ylemmän tason asioiden ymmärtäminen on helpompaa (mahdollista), kun ymmärtää alemman tason asiat 3 Keskeisiä asioita Järjestelmä kokonaisuudessaan, nopeuserot Esimerkkikone ja sen käyttö Konekielinen ohjelmointi Suoritin, rekisterit, väylät, muisti konekäskyjen suoritussykli, keskeytykset Aktivointitietuepino, aliohjelmien toteutus Tiedon esitysmuodot (ohjelma vs. laitteisto) Prosessi ja sen toteutus (PCB) I/O laitteet laiteajurit, laitekeskeytykset, levymuisti Ohjelmien suoritus järjestelmässä käännös, linkitys, lataus, tulkinta, emulointi, simulointi Esimerkkejä keskeisistä asioista seuraavilla kalvoilla 4 Luento 12, Yhteenveto 2

Nopeuserot: Teemun juustokakku Rekisterien, välimuistin, muistin, levymuistin ja magneettinauhan nopeudet suhteutettuna juuston hakuaikaan juustokakkua tehdessä? Europa (Jupiter) käsi jääkaappi pöytä kuu 0.5 sek (rekisteri) 10 sek (muisti) 12 pv (levy) 4 v (nauha, ihminen) 5 Esimerkkikone: TTK-91 laitteisto suoritin - CPU ALU CU rekisterit muisti (kirjastorutiinit) 1 sek (välimuisti) (käyttöjärjestelmä) (välimuisti) MMU ohjelma data väylä laiteohjaimet 6 Luento 12, Yhteenveto 3

TTK-91 Rekisterit Yleisrekisterit R0-R5, SP Stack Pointer, pino-osoitin FP Frame Pointer, ympäristöosoitin Kontrolliyksikön sisäiset rekisterit PC - Program Counter, käskyosoitin IR - Instruction Register, käskyrekisteri TR - Temporary Register, apurekisteri SR - State Register, tilarekisteri 7 Konekielinen ohjelmointi for (int i=20; i < 50; ++i) T[i] = 0; muuttujat, vakiot taulukot, tietueet muistissa, rekisterissä? valinta, toistot aliohjelmat, SVC:t parametrit, paikalliset muuttujat I DC 0 LOAD R1, =20 STORE R1, I Loop LOAD R2, =0 LOAD R1, I STORE R2, T(R1) LOAD R1, I ADD R1, =1 STORE R1, I LOAD R3, I COMP R3, =50 JLES Loop 8 Luento 12, Yhteenveto 4

TTK-91 muistin osoitusmoodit (8) ks. lista sivulla 50 [Häkk98] LOAD R1, 10 ; R1 200 LOAD R1, =10 ; R1 10 LOAD R1, @10 ; R1 6000 LOAD R4, R2 ; R4 201 LOAD R4, @R2 ; R4 11 LOAD R5,=Tbl(R3) ; R5 201 LOAD R5, Tbl(R3) ; R5 11 LOAD R5, @Tbl(R3) ; R5 300 LIMIT: rekisterit muistisegmentti R0: 104 R1: 10 0: R2: 201 R3: 1 10: 200 SP=R6: 11: 300 FP=R7: 125 200: 6000 201: 11 symbolitaulu Tbl: 200 X: 101 One: 9 Käskyjen nouto- ja suoritussykli Hae käsky PC++ M=2 M>0 pura käsky, laske osoite lue muistista M=0 suorita käsky pushr kirj. muistiiin write push pushr D=0 (SR) tarkista keskeytykset noutosykli Noutosykli suoritussykli 10 Luento 12, Yhteenveto 5

Suorittimen tilat user Käyttäjätila (user mode, normal mode) voi käyttää vain tavallisia käskyjä voi viitata vain käyttäjän omaan muistiavaruuteen (MMU valvoo) Etuoikeutettu tila tai (KJ:n) ytimen tila kernel (kernel mode, privileged mode) voi käyttää kaikkia konekäskyjä, myös etuoikeutettuja (esim. clear_cache, iret) voi viitata kaikkialle muistiin, myös käyttöjärjestelmän ytimeen (kernel) voi käyttää (myös) suoria muistiosoitteita (PA) 11 Aktivointitietue (Aktivointitietuepino) Aliohjelman toteutusmuoto (ttk-91) funktion paluuarvo (tai kaikki paluuarvot) kaikkien (sisäänmeno- ja ulostulo-) parametrien arvot paluuosoite kutsukohdan aktivointitietue kaikki paikalliset muuttujat ja tietorakenteet aliohjelman ajaksi talletettujen rekistereiden alkuperäiset arvot (activation record, activation frame) 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 12 Luento 12, Yhteenveto 6

Aliohjelmaesimerkki (ei anim) int fa (int x, y) { int z = 5; } 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 = fa (200, R); CALL SP, fa POP SP, R1 STORE R1, T talleta PC, FP aseta PC, kutsu & paluu palauta FP, PC 2. operandi aina rekisteri 13 Aliohjelmaesimerkki int fa (int x, y) { int z = 5; z = x * z + y; return (z); } T = fa (200, R); retfa EQU -4 parx EQU -3 pary EQU -2 locz EQU 1 fa 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 14 Luento 12, Yhteenveto 7

Tiedon esitysmuodot kokonaisluvut liukuluvut merkit merkkijonot kuvat äänet Lukujärjestelmiä: Binääriluvut, oktaaliluvut, heksadesimaaliluvut ei-standardoitu tieto suorittimen ymmärtämä tieto 15 Negatiiviset luvut (4) arvo talletus +57 = 0011 1001 Etumerkkibitti erikseen luku Yhden komplementtiesitys Kahden komplementtiesitys Vakiolisäys Esim lisää 127 (=2 8 1) yleensä: 2 bittilkm -1 Talleta etumerkittömänä sign bit = MSB = most significant bit -57 = 1011 1001 talletusmuoto -57 = 1100 0110 sign bit +1-57 = 1100 0111 sign bit -57 = 0100 0110-57 + 127 =70 +57 = 1011 1000 +57+127=184 16 Luento 12, Yhteenveto 8

Tiedon esitysmuodot: liukuluku + 15 0.1875 = 0.0011 sign exponent mantissa or significand 23 bittiä mantissalle, siten että... 1) Binääripiste (.) on heti ensimmäisen bitin jälkeen 2) Mantissa on normalisoitu: vasemmanpuolimmainen bitti on1 3)Vasemmanpuolimmaista (eniten merkitsevä) bittiä (1) ei talleteta (implied bit) 1/8 = 0.1250 1/16= 0.0625 0.1875 mantissa eksponentti 0.0011 15 1.1000 12 1000 12 24 bitin mantissa! 17 Big vs. Little Endian (3) Miten monitavuiset arvot talletetaan? 0x1200: Sanan osoite 0x1200 0x1201 0x1202 0x1203 talleta 0x11223344?? tavuosoitteet Big-Endian: eniten merkitsevä tavu pienimpään osoitteeseen Little-Endian: vähiten merkitsevä tavu pienimpään osoitteeseen 0x1200 0x11 0x22 0x33 0x44 0x1201 0x1202 0x1203 0x44 0x33 0x22 0x11 18 Luento 12, Yhteenveto 9

Virheen korjaava Hamming koodi Data: 100 1100 110 1100 Bitti nro: 765 4321 765 4321 Pariteettibitti 1 tarkistaa bittejä 1, 3, 5, 7 Pariteettibitti 2 tarkistaa bittejä 2, 3, 6, 7 Pariteettibitti 4 tarkistaa bittejä 4, 5, 6, 7 Tapahtuu virhe: bitti 6 muuttuu (flips) Pariteettibitti 2 tarkistaa bittejä 2, 3, 6, 7: VIRHE Pariteettibitti 4 tarkistaa bittejä 4, 5, 6, 7: VIRHE 2+4 = 6 korjaa bitti nro 6 (parillinen pariteetti) 1 = 001 2 = 010 3 = 011 4 = 100 5 = 101 6 = 110 7 = 111 19 Prosessin tilat ja elinkaari ready-to-run valmis suoritukseen running suorituksessa luonti odottaa poistettu tai tapettu waiting 20 Luento 12, Yhteenveto 10

Prosessit jonoissa ja PCB R-to-R 1056 1766 Running 0188 Disk1 0036 7654 9878 waiting Timer 0555 Msg from 1345 2222 Prosessin 9878 kuvaaja (PCB) Vuoronanto: valitse seuraava prosessi Ready-to-Run -jonosta ja siirrä se suoritukseen CPU:lle (kopioi tämän prosessin suorittimen tila suorittimelle) 21 Laiteohjain ja laiteajuri Muisti väylä suoritin käyttäjäprosessi laiteajuri (KJ prosessi) laite data c/s laiteohjain laiteohjainprosessi (device controller) laite Suora I/O Epäsuora I/O DMA I/O 22 Luento 12, Yhteenveto 11

Levyjen käyttö Tiedosto koostuu useista lohkoista lohko per sektori Levyn hakemistossa on tieto kunkin tiedoston käyttämistä lohkoista luetaan lohkot annetussa järjestyksessä hakemisto alkio FileA (unix) indeksi lohko lohko lohko lohko lohko 23 Lausekielestä suoritukseen Käännös lausekielestä Linkitys muiden ja kirjastomoduulien kanssa Lataus muistiin prosessia varten Käännösyksikkö myprog.c Lausekielinen ohjelma tai moduuli osoitteet: symbolit Objektimoduuli myprog.obj Käännetty ohjelma (konekielellä) osoitteet: lineaariset (per moduuli) Ajomoduuli myprog.exe osoitteet: lineaariset, osa puutteellisia (?) Prosessi Suorituskelpoinen ohjelma osoitteet: lineaariset (virt. avar.?) prog.c prog.o math.l 24 prog Luento 12, Yhteenveto 12

Tulkinta ja emulointi Java virtuaalikone Java tulkki Pentium II suoritin data load iload i iload j iadd istore k Java suoritin ( esimerkiksi) natiiviympäristö k = i+j; Java ohjelma Java käännös iload i Java iload j byte-koodi iadd istore k data (JIT) käännös dl latausmoduuli Pentium II suoritin 25 26 Luento 12, Yhteenveto 13

Asioiden välisiä suhteita Tietokoneen toiminta Ohjelmointikielet Tietokonearkkitehtuuri Samanaikaisuuden hallinta Laskennan teoria Kääntäjät Oikeellisuuden todentaminen Tietoliikenne Käyttöjärjestelmät 27 Kurssien välisiä suhteita Tietokoneen toiminta (2ov) Käyttöjärjestelmät I (2ov) Rinnakkaisohjelmointi (2ov) Tietokoneen rakenne (2ov) Tietoliikenne I (2ov) 28 Luento 12, Yhteenveto 14

Tietokoneen rakenne, 2 ov Yksi taso alaspäin TITOsta Sopiva 2. vuoden opiskelijalle Useissa yliopistoissa yhdistetty TITOon Miten kellopulssi saa suorittimen suorittamaan konekäskyjä? Miten suorittimen aritmetiikka on toteutettu? Usea käsky on todellisuudessa suorituksessa samanaikaisesti Miten tämä toteutetaan, mitä ongelmia siitä seuraa ja miten noita ongelmia ratkotaan? Jatkoa syventävällä tasolla Tietokonearkkitehtuurit, 4 ov 29 TiKRa. [Stal99] 30 Luento 12, Yhteenveto 15

Käyttöjärjestelmät I, 2 ov Sopiva 2. vuoden opiskelijalle Käyttöjärjestelmän rooli yhden prosessin valvojana Täsmentää ja jatkaa TITOn käyttöjärjestelmien piirteiden esittelyä Samanaikaiset prosessit resurssien käyttäjinä Systeemin resurssien jakelu Prosessien vuoronanto (skedulointi) Jatkoa perustasolla ja syventävällä tasolla Käyttöjärjestelmät II, 2 ov Käyttöjärjestelmämetodiikka, 3 ov 31 KJ... 32 Luento 12, Yhteenveto 16

Tietoliikenne I, 2 ov Sopiva 2. vuoden opiskelijalle Tietokoneverkkojen peruspalvelut käyttäjälle ja sovelluksille Verkkojen tiedonsiirron perusvälineistö Verkkoarkkitehtuurin kerrosrakenne ja kunkin tason palvelut Jatkoa perustasolla ja syventävällä tasolla Tietoliikenne II, 2 ov Tietoliikennejärjestelmät, 3 ov 33 Tietoliikenne TCP/IP -kerrosmalli Sovellus Sovellus rajapinta Kuljetuskerros Verkkokerros Siirtoyhteyskerros sovellus protokollat kuljetus protokollat verkko protokollat siirto protokollat Sovellus Sovellus rajapinta TCP, UDP IP Ethernet, token ring, PPP 34 Luento 12, Yhteenveto 17

Rinnakkaisohjelmointi, 2 ov Sopiva: 2. vuoden opiskelijoille Samanaikaisuuden aiheuttamat ongelmat järjestelmä kaatuu miksi niin kävi? Samanaikaisuuden aiheuttamat vaatimukset systeemille Prosessien synkronointi eri tapauksissa odottamalla vai prosessia vaihtamalla? miksi? Prosessien kommunikointi eri tavoin yhteinen muistialue? viestit? miksi? verkon ylitse? Jatkoa syventävällä tasolla Hajautetut järjestelmät, 3 ov 35 RIO: synkronointiongelman ratkaisu Test-and-Set -käskyllä TAS Ri, L (ttk-91:n laajennus) Kriittinen vaihe Ri := mem[l] if Ri==1 then {Ri := 0, mem[l] := Ri, jump *+2} LOOP: TAS R1, L # L: 1 (vapaa) 0 (varattu) JUMP LOOP # odota kunnes lukko auki... # lukko on varattu (kiinni) minulle kriittinen vaihe: yksi prosessi kerrallaan Toimiiko, josstore tulee R1,L keskeytys pahassa kohtaa? Mikä on paha kohta??... LOAD R1,=1 # avaa lukko L tämän käskyn osoite 36 Luento 12, Yhteenveto 18

Ohjelmointikielten periaatteet, 4 ov Ei luennoitu muutamaan vuoteen Lähtötiedot: OLPM, TiTo, ohjelmointilabrat Sopiva: 3. vuoden opiskelijat Ohjelmointikielten määrittelyn välineistö Erilaiset ohjelmointiparadigmat esimerkkikielten avulla proseduraaliset kielet oliokielet funktionaaliset kielet logiikkaohjelmointikielet Smalltalk Prolog Muita asiaan liittyviä kursseja: Symbolinen ohjelmointi, tekoälykielet C, Pascal Scheme, ML 37 Ohjelmointikielten kääntäjät, 5 ov Luennoidaan satunnaisesta muutaman vuoden välein Lähtötiedot: OLPM, ohjelmointilabrat Sopiva: 3. vuoden opiskelijat Ohjelmointikielten kääntäjien tyypit rekursiivisesti etenevä jäsentelijä Kääntäjän osat lex selaaja jäsentelijä semantiikan analyysi, koodin generointi yacc 38 Luento 12, Yhteenveto 19

Spesifioinnin ja verifioinnin perusteet, 2 ov Lähtötiedot: hajautuksen ja samanaikaisuuden problematiikka Sopiva: 3. vuoden opiskelijalle Mallinnetaan prosesseja siirtymäsysteemeillä askel: konekäsky? metodi? tapahtuma? ohjelma? Automaattisen verifioinnin periaatteet Yksinkertaisten protokollien verifiointi Jatkoa syventävällä tasolla Ohjelmien semantiikka, 3 ov Automaattinen verifiointi, 3 ov 39 Ohjelmoinnin ja laskennan perusmallit (OLPM), 2 ov Lähtötiedot: matematiikkaa appro tai diskr. mat.,... + tira? Sopiva: 1. vuoden (2. vuoden?) opiskelijalle, joka on opiskellut jo matematiikkaa Laskennalliset ongelmat, niiden luokittelu Äärelliset automaatit ja säännölliset kielet Kieliopit Turingin kone Jatkoa syventävällä tasolla Laskennan teoria, 3 ov 40 Luento 12, Yhteenveto 20

Laskennan teorian perusta (1) suoritin - CPU hae käsky suorita käsky muisti 40 miljoonaa lukua á 10 numeroa väylä suoritin - CPU hae käsky suorita käsky muisti Ohjelma P Data väylä 41 Laskennan teoriaa (4) hae käsky suorita käsky Ohjelma P Data väylä Muistin sisältö ennen P:n suoritusta: Muistin sisältö P:n suorituksen jälkeen: X = hyvin iso kokonaisluku (200M numeroa?) Y = joku toinen hyvin iso luku P on kokonaislukuarvoinen funktio P: Ohjelman P esitysmuoto muistissa: Iso kokonaisluku, P 42 Luento 12, Yhteenveto 21

Laskennan teoriaa... (4) Mielivaltaisten ohjelmien ominaisuuksia voi päätellä kokonaislukujen ja niiden välisten funktioiden ominaisuuksista laskennan teoria Todistettuja lauseita ohjelmien ominaisuuksista pätevät kaikille tietokoneille nyt ja tulevaisuudessa 43 Laskennan teoriasta ja algoritmianalyysistä todistettuja lauseita (3) Valitaanpa mikä tahansa aikaraja tai muistin koko, niin aina on olemassa sellainen ongelma, että (1) siihen on olemassa ratkaisu ja (2) kaikki ongelman ratkaisevat ohjelmat vievät enemmän aikaa tai muistitilaa kuin ennalta annettu raja On olemassa sellaisia ongelmia, että niitä ei voi ratkaista millään tietokoneella On olemassa suuri joukko tunnettuja vaikeita ongelmia, joista ei vielä tiedetä, kuinka vaikeita ne oikeastaan ovat? P = NP 44 Luento 12, Yhteenveto 22

-- Luennon 12 ja koko kurssin loppu -- http://www.retroweb.com/apollo_retrospective.html http://lue.kurssikokeeseen.edu/ajoissa.html 45 Luento 12, Yhteenveto 23