1 / 34

Správa pamäte

Správa pamäte. Dva základné pohľady na pamäť. Fyzický adresový priestor (FAP) - je operačná pamäť fyzicky prítomná v počítači. Predstavujeme si ho ako lineárne pole adresovateľných jednotiek - bytov očíslovaných adresami od 0 po MAX

ursa
Download Presentation

Správa pamäte

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Správa pamäte

  2. Dva základné pohľady na pamäť • Fyzický adresový priestor (FAP) - je operačná pamäť fyzicky prítomná v počítači. Predstavujeme si ho ako lineárne pole adresovateľných jednotiek - bytov očíslovaných adresami od 0 po MAX • Logický adresový priestor (LAP) - je pamäť ako abstrakcia, na ktorú sa jednotlivé programy (a tým aj procesy) odvolávajú pri adresácii.

  3. MMU (memory management unit) • Jednotka pre ovládanie pamäte • Jej úlohou je namapovať logické adresy generované procesom na fyzické adresy zrozumiteľné hardvéru, keď sa CPU obracia prostredníctvom MMU k pamäti, a to pri: • načítavaní inštrukcie (fetch), • čítaní dát (load), • zapisovaní dát (store), • MMU nerobí rozdiely medzi dátami a inštrukciami

  4. Generovanie adries • Adresy z hľadiska programu (procesu) sú v rôznych etapách spustenia programu reprezentované rôzne • V zdrojovom programe používame adresy symbolické ─ premenné alebo identifikátory • Pri preklade programu sa tieto adresy zmenia prekladačom na tzv. relokovateľné adresy ("14 bytov od začiatku modulu X", "17 bytov pod vrcholom zásobníka") • Počas behu programu máme logické adresy procesu (LAP) ─ jediná adresácia, ktorá je "zrozumiteľná" MMU, ktorý ju namapuje na FAP.

  5. Pridelenie adries (address binding) • dátam a inštrukciám programu sa môžu prideliť adresy v troch fázach: • Počas prekladu - vzniká relatívný (relokovateľný) kód. Ojedinele sa používa aj absolútny kód, ktorý sa dá zaviesť len na pevne určenú adresu v op. pamäti. • Počas zavedenia programu do pamäti - adresy v kóde zadané relatívne sa pri zavedení programu modifikujú podľa umiestnenia programu v pamäti. • Počas behu programu - ak OS povoľuje premiestnenie adresového priestoru počas behu programu, adresy sa musia prepočítavať po každom premiestnení.

  6. Procedúry pre zefektívnenie práce s pamäťou

  7. Dynamické zavedenie (loading) • Procedúra sa nenačíta do pamäte, pokiaľ to nie je nutné. Pri prvom volaní sa zavedie z relokovateľného formátu uloženého na disku. • Výhoda: zriedkavo volané procedúry sa vôbec nezavedú (typicky napr. ošetrenie exotických chýb). • Nevýhoda: časové zdržanie pri prvom volaní každej procedúry.

  8. Dynamické zostavovanie (linking) • Zostavovací program (linker) kombinuje jednotlivé moduly programu a predpripravené knižnice a vytvára vykonateľný súbor. • Pri dynamickom zostavovaní sa tzv. dynamicky linkované knižnice nepridajú do vykonateľného súboru, pridá sa len akýsi "odkaz" hovoriaci "toto je volanie procedúry f() z knižnice X". Pri prvom volaní procedúry f sa vyhľadá knižnica X v systéme súborov a zavedie sa. • Výhody: menšie vykonateľné súbory, možnosť vylepšiť knižnicu (napr. opraviť drobné chyby) bez nutnosti zmeniť vykonateľné programy. • Nevýhoda: nutnosť verzionovať knižnice (veľké, nekompatibilné zmeny knižníc znemožňujú spoluprácu s programami kompilovanými so starou verziou knižnice). • Reprezentantom tohoto prístupu sú DLL v MS Windows a shared libraries v systémoch UNIX.

  9. Prekrývanie (overlay) • Často štruktúra programu je taká, že určité časti kódu sa používajú len v určitých etapách behu programu. • Program je možné rozčleneniť na prekrývané moduly: určité spoločné časti sú zavedené vždy, iné sa zavádzajú a odstraňujú z pamäti podľa potreby. • Táto metóda nepotrebuje podporu od OS, len od prekladača (vie to napr. aj Borland Pascal).

  10. Odkladanie na disk (swapping) • Proces, ktorý je v stave bežiaci, musí byť v pamäti. Na druhej strane ostatné procesy (čakajúce, pripravené) sa môžu dočasne odsunúť na disk a znovu sa zaviesť až vtedy, keď sú naplánované. • Výhody: táto metóda umožňuje "opticky" zväčšiť súčet veľkostí LAP procesov nad veľkosť FAP. • Nevýhoda: obrovský nárast trvania prepnutia kontextu (disky sú pomalé). Táto "čistá" forma odkladania sa dnes už skoro nepoužíva ─ odkladajú sa nie celé adresové priestory procesov, ale menšie bloky pamäti.

  11. Prideľovanie pamäte Súvislá alokácia

  12. Súvislá alokácia • LAP procesu je uložený v súvislej oblasti FAP. • Jedna oblasť je vyhradená pre OS, ďalšie oblasti sú určené procesom. Podľa počtu a veľkosti týchto oblastí rozoznávame niekoľko možností: • jedna oblasť (okrem oblasti pre OS) ─ jeden proces, • viac oblastí rovnakej veľkosti ─ každý proces vo svojej oblasti • viac oblastí premenlivej veľkosti ─ každý proces vo svojej oblasti, veľkosť oblasti je určená nárokmi procesu.

  13. Mapovanie LAP na FAP a ochrana pamäti • Uskutočnuje sa pomocou dvoch registrov: bázového (alebo relokačného) a limitného. • Pri prepínaní kontextu sa tieto registre naplnia špecifickými hodnotami pre proces, na ktorý sa prepína. • LAP procesu i sa chápe ako pole bytov číslované od 0 po hodnotu maximálnej adresy procesu 0..max(i). • Pri zavedení procesu sa rozhodne o fyzickej adrese priradenej logickej adrese 0 (začiatku LAP) ─ to bude hodnota bázového registra pre daný proces. • Hodnota limitného registra daného procesu bude max(i).

  14. Spracovanie v MMU • Keď CPU požiada o prácu s údajmi na logickej adresea, MMU najprv overí, či a<=max(i) (tým sa zabezpečí ochrana: neadresujeme "nad" vyhradenou fyzickou adresou; adresovať "pod" sa nedá: adresy sú bez znamienka). • V prípade neúspechu sa vyvolá programová chyba a proces sa ukončí. Ak sa test podaril,a sa pripočíta k hodnoteR bázového registra a dostaneme fyzickú adresu. • Znamená to napr., že pri hodnote R=10000 sa logická adresa a=314 namapuje na FA 10314 ─ ak 314<=max(i), t.j. daný proces používa aspoň 315 bytov pamäti.

  15. Nevýhody • Pre jednu oblasť je to znemožnenie multitaskingu. • V prípade rovnako veľkých oblastí je to interná fragmentácia a obmedzenie veľkosti procesov (ak oblasti majú 100KB, tak na proces veľkosti 10KB vyplýtvame 90KB op. pamäti, ak máme 10 voľných oblastí po 100KB, nespustíme proces, ktorý chce 101KB). • Pri premenlivých veľkostiach oblastí je to externá fragmentácia: môže sa stať, že po spustení a ukončení niekoľkých procesov bude FAP vyzerať ako ementál a veľkosť najväčšieho súvislého voľného bloku ("diery") bude výrazne menšia, než súčet veľkostí všetkých voľných oblastí ─ zase sa nemusí podariť spustiť proces s veľkými pamäťovými nárokmi.

  16. Prideľovanie pamäte Stránkovanie

  17. Stránkovanie • Riešením problémov fragmentácie pri súvislej alokácii je stránkovanie. • Tu dovolíme, aby FAP priradený procesu nebol súvislý. • FAP je rozdelený na bloky pevnej dĺžky ─ rámce (typicky 1/2, 1, 2, 4 KB). • LAP procesu je taktiež rozdelený na bloky rovnakej veľkosti: stránky.

  18. Tabuľka stránok (TS) procesu • Určuje priradenie rámcov stránkam. Pri prepnutí kontextu sa prepne aj tabuľka stránok (typicky adresa tabuľky stránok bežiaceho procesu je v špeciálnom registri a stačí zmeniť túto hodnotu). • Každý proces má vlastnú tabuľku stránok • Ak proces požiada o ďalšiu pamäť, OS mu pridelí ďalší voľný rámec (ak existuje), a vytvorí sa spojenie v tabuľke stránok. Takto pridelené rámce nemusia ležať súvisle za sebou.

  19. Pri spracovaní v MMU • logická adresa sa rozdelí na číslo stránky p a offset na stránke d (typicky niekoľko prvých bitov adresy dáva p a zvyšok d ─ preto je veľkosť stránky mocnina 2). • p sa použije ako index do TS a získa sa tým hodnota f: číslo rámca. • Fyzická adresa je: f*r + d, kde r je veľkosť rámca.

  20. Ochrana • Do TS sa pridajú ďalšie bity, ktoré definujú prístupové práva procesu k danej stránke (napr read, write, readonly a pod). • Okrem toho jeden bit označuje stránku ako platnú/neplatnú ─ či stránka patrí do LAP procesu alebo nie (veľkosť TS je totiž rovnaká pre všetky procesy bez ohľadu na ich pamäťové nároky).

  21. Zdieľanie • Stránkovanie dokonca umožňuje zdieľať stránky medzi procesmi: stačí, ak dva procesy majú rovnaké číslo rámca niekde vo svojej TS. • Pomocou bitov pre ochranu sa dá nastaviť aj to, že jeden z procesov na danú stránku len zapisuje, druhý len číta. • Typickejšia situácia je pri zdieľaní vykonateľného kódu (inštrukcií, nie dát!): tieto stránky sú označené readonly a môžu byť zdieľané viacerými procesmi ktoré majú ten istý program.

  22. Nevýhody • interná fragmentácia na poslednej stránke procesu (priemerne pol stránky na proces) • zvýšenie času na context switch, veľkosť TS atď.

  23. Prideľovanie pamäte Segmentácia

  24. Segmentácia • Stránkovanie striktne oddeľuje LAP a FAP, mapovanie je "neprirodzené". Je to vyvolané tým, že sa na LAP dívame ako na lineárne pole bytov. • Prirodzenejší pohľad na LAP je programátorský: vidíme rôzne procedúry alebo skupiny súvisiacich procedúr (napr. knižnice), rôzne oblasti dát (polia, zásobníky). • Pri segmentácii si LAP predstavíme ako neusporiadanú kolekciu segmentov: pomenovaných oblastí premenlivej dĺžky, ktoré obsahujú kód alebo dáta, ktoré spolu nejako súvisia, sú sémanticky (významovo) zviazané. Z dôvodov efektívnosti sa pri behu nepoužíva meno, ale číslo segmentu.

  25. Pri mapovaní LAP na FAP • každý segment sa zobrazí do súvislej oblasti FAP podobne, ako sa celý LAP procesu zobrazoval pri súvislej alokácii. Budeme teda potrebovať bázovú a limitnú hodnotu, ale pre každý segment. • Tieto hodnoty sa ukladajú v tabuľke segmentov procesu, v ktorej sa vyhľadáva pomocou čísla segmentu. • Segmenty sa vo FAP neprekrývajú. • Segmenty obyčajne vytvára prekladač, v niektorých prípadoch je jeho chovanie ovplyvniteľné.

  26. Pri spracovaní v MMU • sa logická adresa rozdelí na číslo segmentus a offset v segmente d (typicky niekoľko prvých bitov adresy dáva s a zvyšok d). • s sa použije ako index do TS a získa sa tým hodnota l: veľkosť (limit) segmentu a hodnota b: bázová adresa segmentu. • MMU najprv porovná d a l: ak d>l, znamená to chybu adresácie a proces sa obyčajne ukončí. V opačnom prípade získame fyzickú adresu ako b+d.

  27. Ochrana a zdieľanie • Teraz nám príde vhod, že segmenty sú sémantické entity: obsahujú spolu súvisiace veci (kód, dáta). • Preto môžu byť segmenty označené prístupovými právami a zdieľané procesmi tak, ako rámce, ale všetko je prirodzenejšie.

  28. Nevýhody • Nenastáva interná fragmentácia, ale môže nastať externá, rovnako, ako pri súvislej alokácii LAP procesov s premenlivou dĺžkou oblastí. • Situácia je ale lepšia, lebo segmenty sú menšie, než LAP celého procesu.

  29. Prideľovanie pamäte Segmentové stránkovanie

  30. Výhody a nevýhody segmentácie a stránkovania sa dajú užitočne skombinovať pomocou segmentovaného stránkovania. Tieto schémy môžu byť veľmi komplikované, načrtneme len základnú myšlienku. • Základom je segmentácia, t.j. prvotná fáza prevodu LA na FA je segmentácia. • Ako výsledok nedostaneme hneď FA, ale tzv. lineárnu adresu. • Táto adresa sa potom stránkuje, t.j. priestor lineárnych adries je rozdelený na stránky a týmto stránkam sa v druhej fáze prevodu priraďujú rámce popísaným algoritmom stránkovania: takto dostaneme FA.

  31. Prideľovanie pamäte Virtuálna pamäť

  32. Táto technika umožňuje beh procesov, ktorých LAP nie je celý vo FAP, t.j. celý proces nie je zavedený v op. pamäti. Jedna z možných implementácií je stránkovanie na žiadosť, ktoré tu stručne a veľmi zjednodušene popíšeme.

  33. Stránkovanie na žiadosť • Základom je stránkovanie. • Každý rámec má priradené miesto aj v sekundárnej pamäti (disku) ─ tzv. odkladacej oblasti (toto je zjednodušenie!). • Nie každá stránka procesu musí byť v op. pamäti, niektoré môžu byť na disku. • Čo sa ale stane, ak sa proces snaží pristúpiť k stránke, ktorá je odložená? • Nastane tzv. výpadok stránky (page fault) ─ proces prejde do stavu čakajúci a OS prenesie stránku do op. pamäti. V podstate proces môže začať svoj beh tak, že len jeho "úvodná stránka" (začiatok programu) je v op. pamäti, ostatné sú odložené. • Po prenesení chýbajúcej stránky do op. pamäti proces prejde do stavu pripravený a eventuálne sa dostane k procesoru.

  34. Pri tejto schéme súčet veľkostí LAP procesov v systéme môže prekročiť veľkosť FAP: čo rozhoduje, je súčet veľkostí stránok, ktoré sú v op. pamäti (nie sú odložené). • Samozrejme, môže nastať situácia, že po výpadku stránky chceme stránku odloženú zaviesť z disku do op. pamäti, ale nie je voľný žiaden rámec vo FAP. • V takomto prípade sa jeden z obsadených rámcov musí odložiť na disk. Algoritmy výberu tejto obete prekračujú rámec prednášky.

More Related