Ero sivun ”Näennäismuisti” versioiden välillä
[katsottu versio] | [katsottu versio] |
p yhdyssana. |
→Aiheesta muualla: linkki vanhentunut |
||
Rivi 24: | Rivi 24: | ||
{{Kirjaviite| Tekijä=Ilkka Haikala ja Hannu-Matti Järvinen| Nimike=Käyttöjärjestelmät| Luku=Luku 4| Julkaisija= Talentum | Vuosi=2003 | Tunniste=ISBN 951-762-837-4}} |
{{Kirjaviite| Tekijä=Ilkka Haikala ja Hannu-Matti Järvinen| Nimike=Käyttöjärjestelmät| Luku=Luku 4| Julkaisija= Talentum | Vuosi=2003 | Tunniste=ISBN 951-762-837-4}} |
||
==Aiheesta muualla== |
|||
*[http://www.cs.uta.fi/tarkki/luennot/muisti/ar01s03.html Virtuaalimuisti] |
|||
[[Luokka:Käyttöjärjestelmä]] |
[[Luokka:Käyttöjärjestelmä]] |
Versio 25. marraskuuta 2014 kello 06.02
Näennäismuisti eli yleisemmin virtuaalimuisti mahdollistaa sen, että osa prosessin muistista voi olla keskusmuistin asemesta massamuistilaitteessa.
Käytännössä virtuaalimuisti tarvitsee toimiakseen virtuaaliosoitteet, mutta virtuaaliosoitteet eivät tarkoita, että järjestelmä olisi samalla virtuaalimuistijärjestelmä.
Virtuaalimuistin toiminta
Virtuaaliosoitteen muuttaminen fyysiseksi osoitteeksi on selitetty kohdassa virtuaaliosoite. Mikäli prosessin koko osoiteavaruus on keskusmuistissa, virtuaalimuisti toimii kuten tavallinen muisti. Varsinkin suurten ohjelmien kohdalla on epätarkoituksenmukaista pitää koko ohjelmaa jatkuvasti keskusmuistissa. Keskusmuisti voi käydä vähiin myös silloin, jos koneessa ajetaan useita prosesseja yhtä aikaa. Riippumatta virtuaalimuistin käytön syistä viittaus sivuun, joka ei ole keskusmuistissa, edellyttää virtuaalimuistijärjestelmältä kykyä hakea puuttuva sivu keskusmuistiin.
Virtuaalimuisti tarvitsee toimiakseen laitteiston tukea. Laitteiston tulee pystyä keskeyttämään ajossa oleva käsky, jos käskyn tekemä muistiviittaus ei ole mahdollinen. Tämän jälkeen suoritus siirtyy käyttöjärjestelmän ytimelle, joka tarkistaa ensin, onko kyseessä virheellinen viittaus ohjelman sallitun osoiteavaruuden ulkopuolelle, ja mikäli ei ole, noutaa halutun sivun keskusmuistiin massamuistilaitteelta eli yleensä levyltä.
Keskusmuisti täyttyisi, jos sinne jatkuvasti vain haettaisiin uusia sivuja. Virtuaalimuistijärjestelmän tulee siis myös poistaa sivuja keskusmuistista. Tätä varten on olemassa useita eri poistoalgoritmeja. Nämä pyrkivät siihen, että poistettavaa sivua ei todennäköisesti tarvittaisi kovinkaan pian. Poistoalgoritmeja ovat muiden muassa FIFO (engl. first in, first out), joka poistaa keskusmuistissa kauiten olleen sivun, LRU (engl. least recently used), joka poistaa pisimpään käyttämättömänä olleen sivun ja DWS (engl. Denning working set), joka pystyy mukautumaan prosessin muuttuviin tarpeisiin ja ennustaa hyvin sen pisteen, jolloin pitää siirtyä sivutuksesta heittovaihtoon (engl. swapping). Käytettävä poistoalgoritmi riippuu käyttöjärjestelmästä ja laitteiston muistinhallintayksikön ominaisuuksista. Yhdellä käyttöjärjestelmällä voi eri laitteistoilla olla käytössä eri poistoalgoritmeja.
Jotta virtuaalimuistijärjestelmä toimisi sujuvasti, pyritään noin 10 prosenttia keskusmuistista pitämään vapaana massamuistilaitteelta haettavia sivuja varten.
Virtuaalimuistin rajoituksia
Virtuaalimuisti helpottaa suunnattomasti ohjelmoijien työtä, sillä aiemmin käsin tehty kerrostus oli hyvin virhealtista ja kulutti paljon voimavaroja. Virtuaalimuistia ei kuitenkaan voi aina käyttää. Esimerkiksi suurin osa käyttöjärjestelmän ohjelmakoodista ja datapuskureista on oltava aina keskusmuistissa, koska muuten järjestelmä ei toimi. Tämän takia osa muistista voidaan lukita keskusmuistiin pysyvästi.
Myös reaaliaikavaatimukset rajoittavat virtuaalimuistin käyttöä. Reaaliaikavaatimus edellyttää, että johonkin toimintoon kuluva aika on etukäteen laskettavissa. Vaikka virtuaalimuistin toiminta on loogisesti ohjelmalle näkymätöntä, se kuluttaa aikaa satunnaisesti, joten reaaliaikaprosessit on niin ikään lukittava keskusmuistiin. Koska sulautetut järjestelmät ovat yleensä reaaliaikaisia, niissä voidaan vain harvoin käyttää virtuaalimuistia.
Lähteet
Ilkka Haikala ja Hannu-Matti Järvinen: ”Luku 4”, Käyttöjärjestelmät. Talentum, 2003. ISBN 951-762-837-4.