1 / 57

Operációs rendszer szintje Operating System Machine (OSM)

Operációs rendszer szintje Operating System Machine (OSM)

Download Presentation

Operációs rendszer szintje Operating System Machine (OSM)

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. Operációs rendszer szintje Operating System Machine (OSM) Ezen a szinten programozóknak rendelkezésre állnak a felhasználói módban használható ISA szintű utasítások és az operációs rendszer által hozzáadott utasítások: rendszerhívások (system calls). Ezeket az operációs rendszer eljárásai valósítják meg (értelmezés). 12. előadás

  2. Virtuális memória Régen nagyon kicsi volt a memória. Sokszor nem fért el az egész program a memóriában. Overlay (átfedés): A program több része fut ugyanazon a memória területen, mindig az aktuálisan futó rész van a memóriában, a többi rész mágneslemezen van. A programozó dolga a feladat átfedő részekre bontása, és a részek mozgatása a memória és a lemez között. Ma már sokkal nagyobb ugyan a memória, de még sokkal nagyobb lehet a címtartomány (address space). 12. előadás

  3. Virtuális címtartomány: azok a címek, amelyekre a program hivatkozni tud. Fizikai címtartomány: azok a címek, amelyek tényleges memória cellát címeznek. A virtuális és fizikai címtartomány ugyanolyan méretű lapokra van osztva (6.3. ábra). A fizikai „lapokat” lapkeretnek (page frame) nevezzük. Lap méret: 512 B – 64 KB (– 4 MB), mindig 2 hatványa. 12. előadás

  4. A virtuális címtartomány sokkal nagyobb, mint a fizikai! Mit kell tenni, ha olyan címre történik hivatkozás, amely nincs a memóriában? 12. előadás

  5. Egy lapkeret (pl. a 0-4095) tartalmának lemezre mentése. • A kérdéses lap megkeresése a lemezen. • A kérdéses lap betöltése a lapkeretbe. • A memória térkép megváltoztatása: pl. a 4096 és 8191 közötti címek leképezése a betöltött lapkeret címtartományába. • A végrehajtás folytatása. leképezés 12. előadás

  6. A virtuális címek fizikai címekre történő leképezését az MMU (Memory Management Unit – memória kezelő egység végzi. Memória térkép (memory map) vagy laptábla (pagemap) kapcsolja össze a virtuális címeket a fizikai címekkel. Pl., 4 KB-os lapméret 32 bites virtuális cím esetén 1 millió virtuális lap van, ezért 1 millió bejegyzésű laptáblára van szükség. 32 KB fizikai memória esetén csak 8 lapkeret van, ezért a leképezés megoldható 8 cellás asszociatív memóriával is (a gyakorlatban több ezer lapkeret van, és az asszociatív memória igen drága). 12. előadás

  7. kulcs kulcsmező szelektor össze-hasonlító tartalom kulcsmező szelektor össze-hasonlító tartalom Asszociatív memória 12. előadás

  8. 15 bites fizikai cím Laptábla Jelenlét/hiány (present/absent) 6.4. ábra 12. előadás

  9. virtuális lap Laptábla 6.5. ábra lap keret lap keret fizikai memória 12. előadás

  10. Laphiba (page fault): a lap nincs a memóriában. Kérésre lapozás (demand paging): lapozás csak laphiba esetén. A program egyetlen bájtja sem kell bent legyen a memóriában, csak a másodlagos tárolón. Időosztásos rendszereknél nem kielégítő! Munka halmaz (working set): a legutóbbi k memória hivatkozásban szereplő lapok halmaza (az operációs rendszer feladata megállapítani). Időosztásos rendszerekben ezek a lapok előre visszatölthetők. Ha a munkahalmaz nagyobb, mint a lapkeretek száma, akkor gyakori lesz a laphiba. A nagyon gyakori laphibát vergődésnek (thrashing) nevezzük. 12. előadás

  11. Lapkezelési eljárások: melyik lap helyett töltsük be a kért lapot? LRU (Least Recently Used, legrégebben használt): általában jó, de nem jó pl. 9 lapon átnyúló ciklus esetén, ha csak 8 memória lap van (6.6. ábra). 12. előadás

  12. FIFO (First-in First-Out, először be, először ki): egyszerűbb (de most ez se jobb, mint LRU). Csak a módosult (dirty, szennyezett) lapokat kell visszaírni, a tisztát (clean) nem (szennyezés bit). Most is előnyös, ha az utasítások és az adatok elkülönülten helyezkednek el a memóriában: az utasításokat nem kell visszaírni. 12. előadás

  13. Lapméret és elaprózódás Ha egy program k lapon fér el, akkor általában a k-dik lap nincs tele. Ha a lap mérete n, akkor programonként átlagosan n/2 bájt kihasználatlan: belső elaprózódás (internal fragmentation). A belső elaprózódás ellen a lap méretének csökkentésével lehet védekezni, de ez a laptábla méretének növekedéséhez vezet. A kis lap előnytelen a lemez sávszélességének kihasználása szempontjából, viszont kisebb a vergődés kialakulásának valószínűsége. 12. előadás

  14. Virtuális címtartomány Szabad Jelenleg használt Verem terület Elemzési fa Szegmentálás Egy fordítóprogramnak a következő célokra kellhet memória (6.7. ábra): • szimbólum tábla, • forrás kód, • konstansok, • elemzési fa, • verem. Rögzített memória felosztás esetén ezek egyike kicsinek bizonyulhat, miközben a többi nem használja ki a rendelkezésére álló tartományt. Konstans tábla Forrás szöveg Szimbólum tábla 12. előadás

  15. Szegmentált memóriában minden tábla a többitől függetlenül nőhet vagy zsugorodhat. Szim-bólum tábla Szegmentálás (6.8. ábra) Hívási verem Forrás szöveg Elemzési fa Konstans tábla 12. előadás

  16. Szegmens (6.8. ábra) A programozó számára látható logikai egység. Minden szegmens címtartománya 0-tól valamilyen maximumig terjed. A szegmens tényleges mérete ennél kisebb lehet. A program számára a címtartomány két dimenziós: (szegmens, offset). Általában egy szegmensben csak egyféle dolgok vannak: vagy kód vagy konstans vagy …Különböző tárvédelmi lehetőségek: • kód: csak végrehajtható, nem írható, nem olvasható, • konstans: csak olvasható • … 12. előadás

  17. A szegmentálás és a virtuális memória összehasonlítása(6.8. ábra) 12. előadás

  18. A szegmentálás megvalósítása Lapozással: Minden szegmensnek saját laptáblája van. A szegmens néhány lapja a memóriában van. Cseréléssel: Teljes szegmensek mozognak a memória és a lemez között. Ha olyan szegmensre hivatkozunk, amely nincs a memóriában, akkor betöltődik. Külső elaprózódáshoz (external fragmentation) vezethet (6.10. ábra). Lyukacsosodásnak (checkerboarding) is nevezik. 12. előadás

  19. 4. 7 K 4. 7 K 3 K 3 K 10 K 5. 4 K 5. 4 K 3. 8 K 3. 8 K 3. 8 K 4 K 5. 4 K 6. 4 K 6. 4 K 2. 5 K 2. 5 K 2. 5 K 2. 5 K 2. 5 K 1. 8 K 3 K 3 K 3 K 7. 5 K 7. 5 K 7. 5 K 7. 5 K 0. 4 K 0. 4 K 0. 4 K 0. 4 K 0. 4 K 6 K Összepréselés: idő igényes, de időnként kell. Legjobb illesztés (best fit) és első illesztés (first fit) algoritmus. Az utóbbi gyorsabb és jobb is az általános hatékonyság szempontjából. 12. előadás

  20. Szelektor: Pentium II (6.12-14. ábra) A szegmens regiszter tartalmazza a szelektort. 0: GDT 1: LDT Védelmi szint: 0-3 A szelektor (6.12. ábra) indexe választja ki a leírót (descriptor) a lokális (LDT, Local Descriptor Table) vagy globálisleíró táblából (GDT, Global Descriptor Table). (6.13. ábra). A 0. leíró használata csapdát eredményez (hiba). 12. előadás

  21. Szegmens típusa, védelme Védelmi szint (0-3) 0: a szegmens nincs a memóriában 1: a szegmens a memóriában van 0: LIMIT értéke bájtokban 1: LIMIT értéke lapokban(lap ≥ 4 KB) 0: 16 bites szegmens r. 1: 32 bites szegmens r. Ha P=0, csapda: be kell tölteni a szegmenst. 12. előadás

  22. Szelektor Offset Leíró Bázis cím + Limit Más mezők 32 bites lineáris cím 6.14. ábra Ha offset (a szegmens elejéhez viszonyított relatív cím) a szegmens határán túl van, csapda (hiba). Lapozást tiltó flag (a globális vezérlőregiszter bitje): Ha engedélyezett: lineáris cím = virtuális cím Ha tiltott: lineáris cím = fizikai cím 12. előadás

  23. Lapkönyvtár (page directory 6.15. ábra) A 32 bites lineáris címek és a 4 KB-os lapok miatt egy szegmenshez egymillió lap is tartozhat. Túl sok! Minden futó programhoz egy lapkönyvtár tartozik. Minden bejegyzés egy laptáblára mutat, vagy sehova. 12. előadás

  24. Csak a ténylegesen használt virtuális lapokhoz kell laptábla. A lapkönyvtárnak azokhoz a mutatóihoz, amelyek nem mutatnak sehova, nem kell helyet foglalni a laptábla számára (rövid szegmenshez csak két ezer, és nem egy milliós bejegyzésű tábla kell). A táblákban minden bejegyzéshez 32 bit áll rendelkezésre. A mutatókhoz nem használt biteket a hardver az operációs rendszer számára hasznos jelzésekkel tölti ki (védelem, szennyezettség, hozzáférés, …). Speciális hardver támogatja a legutóbb használt lapok gyorsabb elérését. 12. előadás

  25. A szintek egy lehetséges felhasználása: Felhasználói programok Osztott könyvtár Rendszer hívások Kernel 0123 szint A Pentium II védelmi rendszere (6.16. ábra) A futó program pillanatnyi szintjét a PSW tartalmazza. A program a saját szintjén lévő szegmenseket szabadon használhatja. Magasabb szinten lévő adatokhoz hozzáfér, de az alacsonyabb szinten lévők kezelése csapdát okoz. Más szinten lévő eljárás hívásánál CALL helyett szelektort kell alkalmazni, ez egy hívás kaput (callgate) jelöl ki (más védelmi szintre csak szabványos – tehát ellenőrzött – belépési ponton lehet áttérni). 12. előadás

  26. Virtuális címtartománymegengedett zónák Az UltraSPARC II virtuális memóriája Virtuális cím 64 bites, egyelőre 44 bitre korlátozva. 243-1 264-243 264-1 0 44 bitre korlátozva ez a címtartomány folytonos. Fizikai címtartomány maximum 41 bites. A kód és adat lapokat külön kezeli. 12. előadás

  27. Lapméret: 8, 64, 512 KB és 4 MB (6.17. ábra). 44 bitre korlátozva maximum 41 bit 12. előadás

  28. A memória kezelő egység (MMU) három szinten dolgozik: • A legutóbb használt lapokat gyorsan megtalálja (hardver). A kód és az adat lapokat teljesen külön kezeli. • A nem nagyon régen használtakat már lassabban (hardver segítséggel). • A nagyon régen használtakat csak hosszas keresés után (szoftveres úton). 12. előadás

  29. Fizikai lapkeret Virtuális lap Flag-ek Környezet Érvényes TLB (Translation Lookaside Buffer) a legutóbb használt 64 lap címét tartalmazza (6.18. ábra). Környezet (context): processzus szám. Asszociatív memória: Kulcs a keresett virtuális lap és a környezet. TLB hiány (TLB miss) esetén: csapda. 12. előadás

  30. TLB hiány esetén TSB folytatja a keresést (szoftver). TSB (Translation Storage Buffer): olyan, mint egy direkt leképezésű gyorsító tár (operációs rendszer építi fel, és kezeli). Virtuális lap tag Virtuális lap címe Fizikai lapkeret Flag-ek Környezet Érvényes tag line TSB találat esetén egy TLB sor helyébe beíródik a kért lapnak megfelelő bejegyzés. 12. előadás

  31. TSB hiány esetén a fordító tábla (translation table) alapján keres. Ennek a táblának a szerkezetét az operációs rendszer határozza meg. Egy lehetséges megoldás a tördeléses eljárás. Ebben az esetben a memóriába töltött virtuális lapok és a nekik megfelelő fizikai lapkeretek sorszáma listákba van helyezve. Ha a virtuális lap sorszáma p-vel osztva q-t ad maradékul, akkor csak a q-adik listát kell végignézni. Ha ez se találja a keresett lapot, akkor nincs a memóriában (lap hiba). 12. előadás

  32. Virtuális memória és gyorsító tár Két szintű hierarchia: Virtuális memória használatakor az egész programot lemezen tartjuk, fix méretű lapokra osztjuk. Lap hiány esetén a lapot a memóriába töltjük (operációs rendszer). Gyorsító tár esetén a memóriát gyorsító sorokra osztjuk. Gyorsító tár hiány esetén a sort a gyorsító tárba töltjük (hardver). 12. előadás

  33. Szerkesztő A következő feladatokat kell megoldania: • az azonos nevű és osztályú szegmens szeletek egymáshoz illesztése a szegmens szeletek definíciójában megadott módon, • a GROUP pszeudo utasítással egy csoportba sorolt szegmensek egymás után helyezése, • a relokáció elvégzése, • a külső hivatkozások (EXTRN) feloldása. Az object file nemcsak a lefordított utasításokat tartalmazza, hanem további – a szerkesztőnek szóló – információt is. 12. előadás

  34. 1. Forrás modul 1. Tárgy modul 1. Fordító Futtatható bináris program 2. Forrás modul 2. Tárgy modul 2. Fordító Szerkesztő 3. Forrás modul 3. Tárgy modul 3. Fordító Szerkesztő Lehetővé teszi a program akár különböző nyelveken készített részleteinek összeillesztését (7.13. ábra). 12. előadás

  35. Két menetben dolgozik: • Az első menetben táblázatokat készít (térkép – map és globális szimbólum tábla). • A második menetben a táblázatokban elhelyezett információk alapján elvégzi a szerkesztést. 12. előadás

  36. A térkép (map) szegmens szeletenként a következő információt tartalmazza: • modul név, • szegmens név, • osztály, • illesztés típusa, • kombinációs típus, • hossz, • kezdőcím, • relokációs konstans. Az első menet végén a térképet átrendezi, majd kitölti kezdőcímeket és a relokációs konstansokat. 12. előadás

  37. A globális szimbólum tábla a PUBLIC változókból: APUBLICutasítás nem tartalmazza a típust és a szegmens nevét, de az assembler ismeri, és el tudja helyezni a tárgy (object) modulban. A cím a táblázat összeállításakor még relokálatlan címet jelent. Az első menet végén ebben a táblázatban is elvégezhető a relokáció. 12. előadás

  38. Az assembler az EXTRN utasítás alapján a következő információt adja át: Definiálatlan külső hivatkozások. Moduláris programozás. Object könyvtárak. 12. előadás

  39. Dinamikus szerkesztés Nagyméretű programokban bizonyos eljárások csak nagyon ritkán szükségesek. Csatoló táblázat (Linkage Segment): minden esetleg szükséges eljáráshoz egy csatoló blokkot (struktúrát) tartalmaz. CSAT_STR STRUCT CIM DD FAR PTR CSATOLO NEV DB ’ ’; 8 szóköz CSAT_STR ENDS 12. előadás

  40. Pl. a dinamikusan szerkesztendő ALFA eljáráshoz az: ALFA CSAT_STR <, ’ALFA’> csatoló blokk tartozhat. Az eljárás csatolása, hívása: MOV BX, OFFSET ALFA CALL [BX].CIM Első híváskor a CSATOLO kapja meg a vezérlést. A csatolandó eljárás neve a [BX].NEV címen található. A név alapján betölti és a programhoz szerkeszti a megfelelő eljárást. 12. előadás

  41. A szerkesztés végeztével CIM -et a most a programhoz szerkesztett eljárás kezdőcímére változtatja, és erre a címre adja a vezérlést: JMP [BX].CIM JMP , és nem CALL, hogy a veremben a CSATOLO -t hívó programhoz való visszatérés címe maradjon. További hívások esetén a CSATOLO közbeiktatása nélkül azonnal végrehajtásra kerül az imént csatolt eljárás. 12. előadás

  42. CSATOLO használhatja és módosíthatja a program szerkesztésekor készült térképet (map) és a globális szimbólumok táblázatát. Szokásos megszorítás: a csatolandó eljárás nem tartalmazhat EXTRN utasítást, és egyetlen, a memóriába bárhová betölthető modulból áll. Ekkor a szerkesztés magára a betöltésre, és ennek a tényét rögzítő adminisztrációra egyszerűsödik. A dinamikusan szerkesztett eljárásokat könyvtárakba szokás foglalni (pl.: .dll), az eljárások általában többszöri belépést tesznek lehetővé (re-entrant). 12. előadás

  43. Továbbfejlesztés: A csatoló paraméterként kapja meg a felhívandó eljárás nevét. A csatoló program hoz létre egy csatoló táblázatot. A csatoló a táblázatban ellenőrzi, hogy csatolva van-e a kívánt eljárás. Ha nincs, akkor elvégzi a csatolást, ha pedig csatolva van, akkor közvetlenül meghívja az eljárást. 12. előadás

  44. Menü vezérelt rendszer esetében, ha a kiválasztott menü elemhez tartozó szövegből generálni lehet az – esetleg csatolandó, majd – végrehajtandó eljárás nevét és az eljárást tartalmazó file nevét, akkor a program bővítését, javítását a megfelelő file-ok hozzáadásával vagy cseréjével és a menü szöveg file-jának cseréjével akár üzemelés közben is elvégezhetjük. 12. előadás

  45. A csatolt program törlése: a törlendő eljárás csatoló blokkjában a CIM visszaállítása – illetve a csatoló tábla törlése – után az eljárás törölhető. Szokásos, hogy egy dinamikusan szerkesztendő eljáráshoz tartozik egy számláló, melynek értéke a csatolás előtt 0. A hívó program először „bejelenti” az igényét az eljárásra. Ha a számláló 0, akkor megtörténik a csatolás, és mindenképpen: számláló ++. Ha a továbbiakban már nem igényli az eljárást, akkor „elengedi”: számláló --. Ha a számláló =0, akkor senki sem igényli az eljárást, tehát törölhető. 12. előadás

  46. Cím hozzárendelés (binding) Időosztásos (time sharing) rendszer. Egy program elindításakor többek között a következő feladatokat kell végrehajtani: betöltés – indítás – felfüggesztés – kimentés a program folytatásakor: visszamentés – futtatás – felfüggesztés – kimentés Általában nem biztosítható, hogy a visszamentett program a memóriának ugyanarra a területére kerüljön vissza, ahol korábban futott! 12. előadás

  47. Ha pl. a programunk egy JMP L ugró utasítást tartalmaz, akkor L-hez valamikor hozzá kell rendelnünk egy konkrét fizikai címet – bindig = (cím) hozzárendelés. A cím hozzárendelés különböző időpontokban történhet: Program írásakor (gépi kódú programozás): Manapság már ritka. Fellelhető a szegmens definícióban alkalmazható AT kifejezés kombinációs típusban. 12. előadás

  48. Fordításkor: pl. szintén az AT kifejezés kombinációs típussal kapcsolatban, ha a szegmensben szimbolikus címzést használnak. Általánosan használt volt, amikor még nem különült el a fordítás és szerkesztés folyamata. Szerkesztéskor: Ma ez a cím hozzárendelés egyik legelterjedtebb módja. Általában ez valósul meg az assembly programokban is. 12. előadás

  49. Betöltéskor: Ekkor a betöltő átveszi a szerkesztő feladatainak egy részét, pl. a FAR típusú cím konstansok értékének kiszámolását, hiszen ezek értéke a betöltés helyétől függ. A program betöltése valamivel hosszabb időt vesz igénybe, előnye viszont, hogy a betöltési cím tetszőleges lehet. 12. előadás

  50. A címzéshez használt bázis regiszter kitöltésekor: Ez a módszer már biztosítja az időosztásos rendszerben futtatható alakú programok elkészítését, de a FAR címek nagy problémát jelentenek, mert a program áthelyezésekor módosítandók a FAR címek. Megfelelően kialakított hardver: pl. a Motorola 680x0 processzor család rendelkezik egy program bázisregiszterrel. Minden utasítás tartalmaz egy bitet, hogy a benne szereplő hivatkozás módosítandó-e a program bázis regiszterrel. 12. előadás

More Related