שבוע #05 פרקMemory Management : ניהול הזיכרון קורס מערכות הפעלה ב' מכללת הדסה /מכללה חרדית צבי מלמד [email protected] הרצאות הקורס מבוססות במידה רבה ביותר על ההרצאות של ד"ר יורם ביברמן © כל הזכויות שמורות לד"ר יורם ביברמן ולצבי מלמד ©צבי מלמד 1 ניהול זיכרון • המטרות שדיברנו עליהם בעבר ,ובפרט בפרק הקודם: – שיפור ניצולת המעבד – שיפור התגובתיות למשתמש • הפתרון )באופן הכי כללי( – ריבוי תוכניות שרצות במקביל • מה שזה מצריך: – שהתוכניות האילו תמצאנה בזיכרון בו-זמנית • דרושות – שיטות לניהול הזיכרון memory management scheme • אולי יותר מכל מרכיב אחר – שיטות לניהול הזיכרון תלויות בתמיכה בחומרה. – במלים אחרות :יחסי הגומלין בין מבנה החומרה למערכת ההפעלה מאוד משמעותיים בהקשר של ניהול הזיכרון ©צבי מלמד 2 עולם היהדות • מהדר )בהלכה ,בכשרות(... • כורך )מצה ומרור(... • טוען )בבית הדין הרבני(... ©צבי מלמד 3 ניהול הזיכרון -רקע • התוכניות – נמצאות על הדיסק )או התקן לא-נדיף אחר( • בכדי להריץ – התוכנית צריכה להיטען לזיכרון • הזכרנו אזורים שונים בזיכרון: – טקסט/קוד – פקודות התוכנית – נתונים ) (dataו – bss-נתונים גלובליים וסטטיים ,מאותחלים ובלתי מאותחלים – מחסנית ,ערימה – הזיכרון "הדינמי" ©צבי מלמד 4 התהליך • לכל תהליך מרחב כתובות ) (address spaceשלו – אליהן ,ורק אליהן ,הוא רשאי לפנות תזכורת – מהמצגת על תהליכים ©צבי מלמד 5 מרחב הכתובות ) (address spaceשל התהליך .1 .2 .3 .4 .5 .6 - text segmentפקודות התכנית )בשפת מכונה( = ]בד"כ מוגן מפני כתיבה[ - Stackמחסנית )פרמטרי התוכנית ,קריאות לפונקציות ומשתנים לוקליים( heapערמה )להקצאה דינאמית( – data sectionמשתנים סטטיים וגלובליים (block started by symbol) bssמשתנים גלובליים וסטטיים שאינם מאותחלים )וע"כ אינם נשמרים בקובץ המכיל את התכנית( מידע נוסף על התהליך )רשימת קבצים שפתח ,עדיפות ,זמן ריצה, מצב האוגרים ב context switch-האחרון] - ( .. ,מתוחזק על ידי מערכת ההפעלה[ תזכורת – מהמצגת על ©צבי מלמד תהליכים 6 ניהול הזיכרון -רקע • ביצוע תוכנית – רצף של ביצוע פקודות • ביצוע פקודה כולל מספר שלבים ,שבעיקרם קריאת נתונים מהזיכרון )ותלוי בפקודה ,אולי גם כתיבה לזיכרון( – ) – Program Counter = PC (aka instruction pointerמשמש לאיתור מיקום הפקודה הבאה לביצוע )כתובתה בזיכרון( – – Instruction Register = IRמכיל את הפקודה ה"נוכחית" – פענוח הפקודה – קריאת הארגומנטים מהזיכרון )במידת הצורך( – אחסון תוצאת הפקודה בזיכרון • כל הקריאות והכתיבות לזיכרון מתבצעות על גבי הBUS- – ) BUS, USBהזה ,האם יש קשר ביניהם חוץ מפרמוטצית האותיות(?... ©צבי מלמד 7 ניהול הזיכרון -רקע • לא נתעניין בנתונים שנמצאים בכתובות השונות ...אלא בעיקר רק בכתובות עצמן ,זאת אומרת ,באיזה כתובת נמצא הנתון • מרחב הכתובות address spaceשל – Pאוסף כל הכתובות שאליהן עשוי המעבד לפנות כאשר הוא מריץ תהליך מסוים P • כתובת סמלית – symbolic addressהסמל בתוכניתנו שמייצג כתובת – ההכרזה ;int num ;num = 17 – הגדירה כתובת סמלית – .num – אם נבחן את התוכנית – את פקודות התוכנית ,לא נראה בפקודה numאלא התיחסות לכתובת כלשהי ,שהיא הכתובת בזיכרון שהוקצתה למשתנה num – באופן דומה ,אם השתמשנו ב goto my_label-או אפילו ...זימון לפונקציה ©צבי מלמד 8 שאלה של ניסוח • מרחב הכתובות address spaceשל – P האם היינו הך? – אוסף כל הכתובות שאליהן עשוי המעבד לפנות כאשר הוא מריץ תהליך מסוים P – אוסף כל הכתובות שאליהן עשוי לפנות התהליך בזמן הריצה? ©צבי מלמד 9 ניהול הזיכרון -רקע • הגדרנו משתנים בתכניתנו ;double my_double ;long int to_long • הקומפיילר מחליט וקובע: – כמה בתים להקצות למשתנה – כלומר ,לכתובת הסמלית – קביעות אודות הכתובת הפיזית שתכיל את המשתנה בזמן הריצה – מה תהיה כתובת התווית או הפונקציה • אבל – הקומפיילר איננו הקובע היחיד ,וגם לא הפוסק האחרון • אז מה בעצם קובע הקומפיילר ,ומה קובעים "השחקנים" האחרים אודות הכתובת של משתנה או תווית? ©צבי מלמד 10 קביעת הכתובת Absolute Code שיטה א' :קוד מוחלט – absolute code – אם המהדר יודע באילו בכתובות בזיכרון תהיה התוכנית בזמן שתורץ ,הוא יכול לקבוע גם את הכתובת הפיזית המוחלטת והסופית של המשתנה. – יתרון : • טעינת מהירה של התוכנית – לא צריך לחשב כתובות • ריצה מהירה )אותה סיבה( – חיסרון :הקומפיילר צריך לדעת משהו דיי דראסטי ...באיזה כתובת תשכון התוכנית – קבצי .comשל DOSעבדו כך ©צבי מלמד 11 קביעת הכתובת Relocatable Code - שיטה ב' :קוד בר-הזזה – relocatable code – המהדר לא יודע לאיזה כתובת התוכנית תיטען בזיכרון – אבל – הוא יודע :אחרי שהתוכנית תיטען לכתובת מסוימת בזיכרון, ,היא לא תזוז משם עד סיום ריצתה )אפילו אם עוד תוכניות רצות במקביל( כיצד זה עובד? – המהדר קובע כתובת יחסית ביחס לכתובת בסיס כלשהי – כאשר ה) Loader-טוען( טוען את התוכנית לזיכרון: • הוא יודע "לאן הוא טוען" • יבצע המרה של הכתובות היחסיות לכתובות המוחלטות • )"הניתנות להזזה" - relocatable addressesמה משתמע?( ©צבי מלמד 12 כתובת יחסית ,בסיס ומוחלטת כתובת יחסית כתובת יחסית כתובת יחסית כתובת יחסית כתובת בסיס + כתובת יחסית כתובת יחסית כתובת יחסית כתובת מוחלטת ©צבי מלמד 13 קביעת הכתובת Relocatable Code - 2404 + 12000 14404 • משתנה שכתובתו היחסית 2404נטען לכתובת מוחלטת .14404 • זאת כתובתו הסופית של המשתנה. • איזו/כמה עבודה הצטרך הטוען לבצע? • מאזן רווח והפסד: +יותר עבודה בזמן הטעינה – גמישות במיקום הפיזי של התוכנית בזיכרון ©צבי מלמד 14 קביעת הכתובת -שיטה שלישית • נקודת המוצא :גם לאחר שטענו את התוכנית לזיכרון ,הכתובות עלולות להתחלף – נהוגה במערכות ריבוי-תוכניות בסיסיות – התוכנית עשויה להיות משוחלפת לדיסק swap outאו roll out • למה? – הגיעה תוכנית חדשה בעדיפות גבוהה יותר ...אין מקום לשתיהן בזיכרון • אז מה קורה... – כאשר התוכנית מוחזרת לזיכרון המחשב – היא מוחזרת לכתובת כלשהי )ובד"כ לא הכתובת שהייתה בה קודם( – לכן – גם הטוען – אינו קובע שום דבר סופי ואולטימטיבי ©צבי מלמד 15 קביעת הכתובת -שיטה שלישית • במצב כזה –הכתובות היחסיות אינן מומרות בכתובות מוחלטות בשלב הטעינה הראשונה או בשלב הטעינה החוזרת • בכל פעם שהמעבד פונה לכתובת כלשהי – הוא יציין את הכתובת היחסית .באותו רגע ,ובתוקף לאותה פעולה/פניה בלבד תתבצע ההמרה לכתובת פיזית )מוחלטת( • האם זה יאט את ריצת התוכנית? ©צבי מלמד 16 קביעת הכתובת -שיטה שלישית • עלול היה להאט את התוכנית ,לולא הייתה לזה תמיכה בחומרה • Memory Management Unit – MMUמבצעת באופן "אוטומטי" את ההמרה הזאת • משתמשת ברגיסטרBase-Register : • תוכנו של הרגיסטר הזה – שונה מתהליך לתהליך, – ולכן מתקבלות כתובות פיזיות שונות עבור אותן כתובות יחסיות – נשמר :מרחבי זיכרון נפרדים לכל תהליך • מי יהיה אחראי לעדכן את הרגיסטר הזה? • איך נבטיח שמישהו "אחר" לא ישנה את ערכו – בשוגג או בזדון? ©צבי מלמד 17 קביעת הכתובת -שיטה שלישית • מאזן רווח והפסד +אפילו עוד יותר גמישות במרחב הפיזי של התוכנית • קודם זה איפשר :מספר תוכניות ירוצו במקביל • עכשיו בנוסף :התוכנית יכולה להיות להיות מוצאת מהזיכרון לפרקי זמן מסוימים ,ולהמשיך את ריצתה אחר כך ,מאותו מקום – חישוב נוסף בכל פניה לזיכרון – האטה )פוטנציאלית??( תוספת חומרה ,שמבצעת את ההמרה – חיבור לאוגר בכל פנייה ©צבי מלמד 18 טעינת תוכנית – זמנים אופיינים • זמן חיפוש בדיסק – )15 msec (milliseconds • זמן חביון 8 msec – context switch latency time • קצב העברת נתונים100MB/Sec : • נניח שגודל תוכנית הוא 1MBזמן ההעברה שלו10 msec : • סה"כ :בערך ~ 33msec • חריץ הזמן צריך להתייחס לגדלים האילו ©צבי מלמד 19 שיחלוף – swapping -בעיה פוטנציאלית • P1ממתין לקלט )שיקרא לתוך החוצצים שלו( • ה disk-controller -קורא עבורו נתונים מהדיסק • בטרם הסתיימה הפעולה P1 ,שוחלף ואת מקומו בזיכרון תפס P2 • בקר-הדיסק יודע שעליו להעביר את המידע לכתובות אילו ....אבל המידע הזה הוא .passé אבחנות ופתרון אפשרי: • צרה צרורה... • הקלט יתבצע לחוצץ של מערכת ההפעלה ורק כאשר P1יורץ שוב ) (swapped inנעביר את הנתונים למקום הדרוש בזיכרון ©צבי מלמד 20 קביעת הכתובת ) – (address bindingשיטה רביעית • נקודת המוצא: – התוכנית איננה בהכרח רציפה בזיכרון או נטענת במלואה לזיכרון! – מקובלת במערכות של זיכרון מדומה virtual memory – הקלה בדרישה הקודמת :התוכנית יכלה אמנם לרוץ פעם כשהיא שוכנת באזור א' ופעם אחרת באזור ב' – אבל הייתה חייבת להיות בזיכרון במלואה וברציפות. • הרעיון המרכזי: – אם התוכנית היא ספר אנחנו קוראים דף בכל נקודת זמן – בכל פעם נטען לזיכרון רק חלק מהתוכנית – דף אחד – כל עוד התוכנית פונה לכתובת חוקית בדף שנמצא בזיכרון – אשרינו וטוב לנו – אם התוכנית פונה לכתובת חוקית אבל בדף שאיננו בזיכרון ,נצעק גוואלט... ©צבי מלמד 21 קביעת הכתובת ) – (address bindingשיטה רביעית • הרעיון המרכזי )המשך(: – לא נצעק גוואלט ...ולא באמת ניבהל. – תופעל רוטינה/טיפול בשם ) page-faultחריגת-דף או שגיאת- דף( .הדף שמכיל את הכתובת הדרושה ,יטען לזיכרון – לאן בזיכרון? למקום פנוי... – ולכן – התוכנית איננה רציפה בזיכרון אלא מפוזרת על פני מקטעים שונים – אם קודם היה דרוש לנו אוגר בסיס אחד לכל תהליך ,עכשיו דרוש לנו )מין של (...אוגר בסיס ,לכל דף של התוכנית. • טעינת התוכנית היא דינמית ומתבצעת על ידי relocatable linking loader ©צבי מלמד 22 קביעת הכתובת – שיטה רביעית :זיכרון מדומה • השיטה נקראת זיכרון מדומה ,ווירטואלי ,למראית עין... – זיכרון הדיסק למראית עין מתפקד כמו הזיכרון הראשי. כלומר ,הדיסק הוא הרחבה extensionשל הזיכרון הראשי – הזיכרון של התוכנית הוא רק למראית עין שלם ורציף אבל התוכנית למעשה מפוזרת באזורים שונים בזיכרון • טעינת התוכנית היא דינמית ומתבצעת על ידי relocatable linking loader • התכונות הווירטואליות הנ"ל מסייעות לנו גם בכריכה דינמית של ספריות משותפות ©צבי מלמד 23 shared library linking • התכונות הווירטואליות הנ"ל מסייעות לנו גם בכריכה דינמית של ספריות משותפות • ניתן לכרוך פונקציה בשני אופנים: א .כריכה סטאטית – קוד הפונקציה מוסף לקובץ הבינארי של התוכנית. – הקובץ גדל בהתאמה. – אין אבחנה מהו מקור הפונקציה – קוד המקור שלנו או מספריה ב .כריכה דינאמית – במקום להוסיף את קוד הפונקציה מוסף – stubבדל ,שארית, של הפונקציה האמתית. – הבדל )כמו בדל סיגריה( – stubהזה מאפשר למערכת ההפעלה לאתר את ה הפונקציה הדרושה )שנמצאת ב DLL -או (Shared-Library – הקובץ גדל במידה זניחה בלבד – בזמן הריצה מוחזק בזיכרון עותק אחד של הפונקציה הזאת שמשמש תהליכים מרובים – זמן טעינת התוכנית מתקצר מאוד ©צבי מלמד 24 הקצאת זיכרון רציפה contiguous memory allocation • מערכות ריבוי תוכניות בסיסיות שטוענות תכניות בשלמותן לזיכרון • זיכרון ראשי מכיל – מערכת הפעלה ,תוכניות שירות שנלוות לה. – תוכניות המשתמשים :במרחב הזיכרון שאיננו שייך למערכת ההפעלה • החלפת הקשר )בין היתר( טוענת את הbase/relocation register- • כל כתובת לוגית שמייצר המעבד מוספת לערכו על מנת לקבל את הכתובת הפיזית בזיכרון • בדיקת חריגה :השוואה לאוגר-הגבול limit-register ©צבי מלמד 25 עד כאן יום א' 15.4.2012 הקצאת זיכרון רציפה המערכת הזאת: • מספקת הגנה בפני תוכנית משתמשים שמנסות לגשת לאזור שאסור להן • מאפשר לשנע/לנייד תוכניות לכתובת התחלה כלשהי על פי הצורך • מאפשרת לזיכרון של מערכת ההפעלה )שנמצא אקטיבית בזיכרון( להשתנות באופן דינמי )לגדול /לקטון( ©צבי מלמד 26 הקצאת הזיכרון • כיצד יוקצה הזיכרון לתוכניות המשתמשים? )אופן ההקצאה( • פתרון א': – נחלק את הזיכרון ל n-חלקים. – החלקים – לא בהכרח בעלי גודל שווה – כל תהליך יקבל את החלק )הקטן ביותר( שבו הוא יכול להסתפק – תוצאה: • קל למימוש • לכל היותר nתהליכים במקביל ) nנקבע מראש( • מגבלה על גודל תהליך – כגודל החלק הגדול שקבענו • לא משתמשים בזה ©צבי מלמד 27 הקצאת הזיכרון • כיצד יוקצה הזיכרון לתוכניות המשתמשים? )אופן ההקצאה( • פתרון ב': – מערכת ההפעלה מנהלת טבלה של שטחי הזיכרון הפנויים /התפוסים – חור ) – (holeשטח זיכרון פנוי .מאפיינים :כתובת התחלה וגודל – כשצריך לטעון ) (loadתהליך או לשחלף ) – (swap inנחפש עבורו חור "מתאים" ) (fitורק אם מצאנו חור כזה הפעולה תתבצע. ©צבי מלמד 28 הקצאת זיכרון רציפה • כאשר תהליך מסוים מגיע )בקשה להטען( מערכת ההפעלה מחפשת עבורו חור "מתאים" )מספיק גדול( • התהליך נטען בשלמותו לזיכרון רק אם נמצא חור מתאים כזה ,ואז הוא מתחיל לרוץ • תהליך ששוחלף לדיסק – באופן דומה – יכול לחזור לרוץ רק אם נמצא עבורו חור גדול דיו ©צבי מלמד 29 הקצאת זיכרון רציפה – דוגמא • נניח זיכרון בגודל 5יח' • א .הגיע P1בגודל ,2והוכנס ל0, 1: • ב .הגיע P2בגודל ,2והוכנס ל2, 3 : • ג .הגיע P3בגודל 3עליו להמתין • ד P1 .סיים ,ושיחרר את יח' .0, 1עדיין לא ניתן להריץ את P3 – למרות -יש דיי מקום עבורו ,אבל ,המקום הזה איננו רציף • ה .נניח שעכשיו מגיע P4בגודל 2יח' – האם נאפשר לו לרוץ? ©צבי מלמד 30 הקצאת זיכרון רציפה – דוגמא • ה .נניח שעכשיו מגיע P4בגודל 2יח' – האם נאפשר לו לרוץ? • תשובה: – לפי שיקול דעת – מדיניות ...אלגוריתם ) – (iנקבע שלא ניתן להריץ תהליך חדש עד ש P3 -יורץ ) – (iiנאפשר ל P4 -לרוץ – ה :tradeoff -ניצולת המערכת מול הרעבה )של (p3 ©צבי מלמד 31 הקצאת זיכרון רציפה – שיפורים • כאשר תהליך משחרר זיכרון – לבדוק האם הזיכרון סמוך לחור – ואם כן לאחד אותם • מעת לעת לבצע איחוי defragmentationשל הזיכרון כדי לאחד חורים – האיחוי – מחייב הזזת תהליכים בזיכרון ©צבי מלמד 32 הקצאת זיכרון רציפה • השאלה :מהו החור המתאים – באופן ספציפי :נתונה קבוצת חורים ,ובקשה לזיכרון רציף בגודל nתאים .איזה חור יוקצה לבקשה? • תשובות אפשריות: – First Fit – Best Fit – Worst Fit ©צבי מלמד 33 הקצאת הזיכרון • : First-Fitמחפשים ברשימת החורים ,עד שמוצאים את הראשון המתאים )כלומר שהוא מספיק גדול(. – החלק שאיננו מוקצה הופך להיות "חור" )קטן יותר כמובן( • : Best-Fitמחפשים את החור הכי קטן שיכול להתאים לדרישה. – השארית – בד"כ תהיה חור במידה קטנה מדי לשימוש – לתחזק את הרשימה ממוינת )זירוז החיפוש( • :Worst-Fitמחפשים את החור הגדול ביותר במערכת. – מגדיל את הסבירות שהשארית תהייה שמישה .מקטין את הבזבוז • מה עדיף? ©צבי מלמד 34 הקצאת זיכרון רציפה – מה עדיף? • איך נדע? – מעקב אחרי שימוש וסימולציות • First-Fitאו best-fitטובים יותר מבחינת זמן וניצולת הזיכרון מאשר Worst-Fit • ניצולת זיכרון – שניהם דומים • זמן חיפוש – first-fitעדיף ©צבי מלמד 35 Internal & External Fragmentation קיטוע חיצוני ופנימי • כל שלושת השיטות סובלות מקיטוע חיצוני (external ):fragmentation – עם הזמן נוצרים יותר ויותר שטחי זיכרון קטנים ולא שימושיים – מחוץ לשטחים המוקצים לתוכנית – לכן נקרא קיטוע חיצוני • כלל ה50% - – שטחם של החורים הלא שמישים מגיע לכדי מחציתם של שטחי הזכרון השמישים )= שליש מנפח הזיכרון( – deframentationפותר את בעית הקיטוע החיצוני – במחיר השקעת עבודה לא מבוטלת ©צבי מלמד 36 Internal Fragmentation קיטוע פנימי • הקצאת הזכרון איננה ביחידות של "בתים בודדים" )או בדיוק בכמות הנדרשת( – אלא בגושים בגודל Xבתים. • לכל תהליך מוקצה יותר ממה שדרוש לו בפועל • לא רק ההקצאה הראשונית – אלא בקשות חוזרות להקצאת זיכרון דינמית. • בממצע – בזבוז של חצי-בלוק לכל בקשה/הקצאה • החלק הלא מנוצל "מבוזבז" • בזבוז פנימי לתהליך – ולכן נקרא internal fragmentation ©צבי מלמד 37 חלוקה לדפים Paging • במערכות של :virtual memory – התוכנית הראשית איננה נטענת לזיכרון בשלמותה – איננה שוכנת בכתובות רציפות בזיכרון • כיצד זה מתבצע? ©צבי מלמד 38 חלוקה לדפים – Paging • קיים הזיכרון הפיזי והזיכרון הלוגי • השאלה :כיצד לטעון את הזיכרון הלוגי בזיכרון הפיזי. – כבר הסכמנו שהתוכנית )הזיכרון הלוגי( יכולה להטען במרוצת חייה/ריצתה לאזורים שונים בזיכרון הפיזי ,וגם ,לא חייבת לשכון באופן רצוף. • נחלק אם כן ,גם את הזיכרון הפיזי וגם את הזיכרון הלוגי לחלקים שווי גודל – החלקים בזיכרון הפיזי – נקרא להם ) framesמסגרות( – החלקים בזיכרון הלוגי – נקרא להם ) pagesדפים( – דף לוגי pageכלשהו יטען למסגרת frameפיזית כלשהי -שפנויה ברגע הטעינה – טבלת הדפים תחזיק את המידע – עבור כל דף לוגי מספר ,#iבאיזה מסגרת פיזית הוא משוכן כרגע )או :האם הדף נמצא בזיכרון( ©צבי מלמד 39 חלוקה לדפים – Paging ©צבי מלמד 40 חלוקה לדפים – Paging • גודל אופייני לדף 2) 2^12 :בחזקת (4096 = 12בתים – קיימת שונות רבה • נתייחס לכתובת הדף כמורכבת משני חלקים: – מספר הדף page-number – הסטה בתוך הדף page-offset אינדקס לטבלת הדפים הסטה בתוך הדף ©צבי מלמד 41 חלוקה לדפים – Paging • טבלת הדפים דומה לאוגר בסיס +הזזה • במקום אוגר בסיס אחד – טבלה של בסיסים ©צבי מלמד 42 – Pagingדוגמא • כתובת פיזית בת 5סיביות • כלומר ,מרחב הזיכרון – 32בתים • גודל מסגרת 4 = frameבתים )(22 • מספר מסגרות8 : • כתובת בתוך המסגרת 2 :סיביות • כתובת המסגרת 3 :סיביות • הכתובת הלוגית011 01 : )עשרוני ,13 :תוכן :האות (n • מיפוי לדף לוגי מספר ,3ששוכן במסגרת מספר 2 ©צבי מלמד 43 מודל מופשט של זיכרון ווירטואלי process X process Y page 1 page 2 page 3 טבלת הדפים של X תהליך page 4 frame 1 frame 2 frame 3 page 5 frame 4 page 6 frame 5 page 7 frame 6 page 8 frame 7 frame 8 frame 9 frame 10 44 page 1 זיכרון פיזי ©צבי מלמד טבלת הדפים של Y תהליך page 2 page 3 page 4 page 5 page 6 page 7 page 8 זיכרון דפים – דוגמא עם כתובות בייצוג עשרוני • • • • • • נניח שמרחב הזיכרון של התהליך = כלומר ,הזיכרון הלוגי הוא בגודל 10,000 ייצוג כתובת בזיכרון הלוגי 4 :ספרות עשרוניות נניח גודל דף )= גודל מסגרת( = .100כלומר ,כתובת בתוך הדף 2ספרות עשרוניות )החל מ 00-ועד (99 כמות הדפים ,100 :ולכן דרושות 2ספרות לייצג את מספר הדף )החל מ- 00ועד (99 נניח זיכרון פיזי בגודל .100,000כלומר כתובת זיכרון פיזי היא 5ספרות עשרוניות .הזיכרון הפיזי מכיל 1000מסגרות ,ולכן כתובת מסגרת היא 3 ספרות עשרוניות )החל מ 000-ועד (999 ולכן ,טבלת הדפים שמתרגמת מכתובת דף לכתובת מסגרת תכיל 100 כניסות )תאים( בהתאם ל 100-דפים ,וכל תא יכיל 3ספרות בכדי להצביע על המסגרת המתאימה ©צבי מלמד 45 זיכרון דפים – דוגמא עם כתובות בייצוג עשרוני זיכרון לוגי בגודל 10,000 כתובת 4 :ספרות עשרוניות גודל דף – 100 זיכרון לוגי בגודל 100,000 כתובת 5 :ספרות עשרוניות גודל מסגרת 100 -frame כתובת 00000 ’‘M טבלת דפים בגודל 100 )כלומר 100 :כניסות/כתובות( כל כתובת 2 :ספרות עשרוניות ’‘M כתובת 5012 כתובת 34512 345 כתובת 99999 כתובת 50 ©צבי מלמד 46 חלוקה לדפים – Paging משמעויות/תכונות נוספות של שימוש בדפים: א -קל להזיז דפים בזיכרון ב -אין קיטוע חיצוני ג -הקיטוע הפנימי הוא מינימלי – בערך חצי דף לתהליך ד -כאשר טוענים תהליך ששוחלף ,יש לטעון גם את טבלת הדפים שלו )אם גם היא שוחלפה( ה -קיים אוגר ייעודי – Page-Table Base Register – PTBR שמצביע על כתובתה של טבלת הדפים בזיכרון .צריך לעדכן את כתובתה של טבלת הדפים )אם היא שוחלפה לכתובת חדשה( כתוצאה מ -ד' +ה' זמן החלפת הקשר עולה ©צבי מלמד 47 קביעת גודל הדף • האם נרצה דפים גדולים או קטנים? • מהם השיקולים בעד /נגד ? ©צבי מלמד 48 קביעת גודל הדף א -דפים קטנים קיטוע פנימי קטן טבלת דפים גדולה מעלה את ה overhead-של ) page-swapקריאה/כתיבה( לדיסק בגלל שמרכיב הזמן כולל גורם קבוע של הזזת ראשים ו- – context-switch latencyומעבירים יחסית מעט נתונים( ב -משמעויות נוספות שעוד נכיר בהמשך... • גודל מקובל של דפים 12-13) 4KB-8KB :סיביות( • סולאריס :תומכת בדפים בשני גדלים8KB, 4MB : • לינוקס :גודל דף) 4KB :הפקודה( getconf PAGE_SIZE : • :Windowsגודל דף 4KB ©צבי מלמד 49 ( )שקף גיבויFree frames before/after allocation 50 ©צבי מלמד TLB - Translation Look-aside Buffer • פניה לזיכרון בתוכנית: – המעבד יוצר כתובת לוגית – בעזרת טבלת הדפים )שנמצאת בעצמה בזיכרון( מתרגמים את הכתובת הלוגית לכתובת פיזית – הפניה לזיכרון בתוכנית( – שתי פניות לזיכרון בשביל פניה אחת בתוכנית – כפול זמן • בעייתי! מה גם שמלכתחילה הפניה לזיכרון היא צוואר בקבוק )ביחס לזמני הריצה של המעבד( • פתרוןTLB : ©צבי מלמד 51 גישות לפתרון בעיות גישה לזיכרון • הבעיות הכרוכות בטבלת הדפים: א -גישה כפולה לזיכרון )מהירות( ב -גודל טבלת הדפים )= מספר הדפים Xגודל כתובת( • בעיות של גישה לזיכרון נפתרות בדרך כלל על ידי שילוב של שתי גישות: .I ) CACHINGזיכרון מטמון( ) Indirection .IIמיעון עקיף( ©צבי מלמד 52 TLB - Translation Look-aside Buffer • • • • שתי פניות לזיכרון בשביל פניה אחת בתוכנית – כפול זמן פתרוןTLB : – זיכרון מטמון ,מהיר ,יקר ,קטן שנמצא על המעבד עצמו – אין צורך לגישה דרך הBUS- – מכיל חלק מטבלת הדפים בכדי למצוא כניסה בטבלת הדפים – ראשית נחפש את הכניסה בTLB- – אם הצלחנו – מה טוב = Hit ) TLB Hit – ...פגיעה( – אם לא הצלחנוTLB-Miss : • נפנה לטבלת הדפים בזיכרון • נטען את הכניסה הדרושה לTLB- – Hit-Ratioאחוז ההצלחה בחיפוש ערך בcache/TLB- ©צבי מלמד 53 TLB - Translation Look-aside Buffer CPU p 20 o 10 9 f – המסלול המהיר TLB-Hit 1 Physical Addresses 16 10 9 Virtual Addresses ? Key Value p f f p TLB Page Table 54 o ©צבי מלמד –המסלול האיטי TLB-Miss Paging H/W • זיכרון אסוציאטיבי – – כשניתנת ל TLB-כתובת מסוימת שדרושה )מספר דף( ,מתבצעת במקביל השוואה לכל הכתובות ששמורות אצלו – האם הכתובת שניתנה זהה לאחת מהן • נמצאה התאמה? – כן תוכן הזיכרון "מוצג" ומשתמשים בו – לא נדלק ביט TLB- MISS ©צבי מלמד 55 TLB - Translation Look-aside Buffer • נניח: – מרחב כתובת של 32סיביות )(4GB – דף בגודל 4096) 2^12בתים( – מספר הכניסות בטבלת הדפים = 2^20 :מיליון – מספר הכניסות ב – TLB-בד"כ בתחום64-1024 : • מדוע אם כן ה TLB-עוזר לנו? – עקרון הלוקליות :בנקודות זמן סמוכות התוכנית פונה לכתובות סמוכות ,או למספר מצומצם של כתובות סמוכות ,שנמצאות במספר מצומצם של דפים – עקרון זה תורם להגדלת הhit-ratio - • – TLB-Reachכמות הכתובות שניתן להגיע אליהן בעזרת הTLB- – ככל שהדפים גדולים יותר – ה TLB-Reach -גדול יותר ©צבי מלמד 56 TLB - Translation Look-aside Buffer • באחריות החומרה -הטיפול ב) TLB -הוספת כניסה שלא נמצאה בו לתוך ה TLB-ובמידת הצורך ,פינוי כניסה אחרת( • באחריות מערכת ההפעלה – לעדכן את ה TLB-כאשר מוציאים דף לדיסק ,או מזיזים דף בזיכרון ,או תהליך סיים לרוץ )ודפיו התפנו כולם( • בזמן החלפת הקשר – יש לנקות את הTLB- – אלא אם כן ה TLB -מחזיק את מספר התהליך ,ואז הוא יכול להחזיק כתובות של מספר תהליכים בו זמנית ©צבי מלמד 57 memory access time calculation ...נניח • • • • • 58 TLB Hit Ratio = 80% TLB Search = 20 nsec (nano-seconds) Memory access time = 100 nsec (register access time = 0.5 nsec [the main CPU cycle] effective memory access time זמן הגישה לזיכרון בפועל נ"ש100 :ללא טבלת דפים נ"ש200 :TLB עם טבלת דפים ללא : TLB+ טבלת דפים 0.80*(20+100) + 0.20*(20+100+100) = 140 nsec – נ"ש122 : נקבל:hit ratio= 98% חישוב דומה עבור (0.98*120+0.02*220) ©צבי מלמד • • • • memory access time calculation • החישוב הנ"ל תיאורטי במקצת. • באופן מעשי ה TLB-נמצא כזיכרון מטמון על הCPU- • כאשר יש לנו TLB-Hitזמן הגישה לזיכרון הוא מחזור אחד ,שכן המידע מה TLB-מגיע במרוצת מחזור השעון של המעבד • כאשר יש לנו TLB-Missזמן הגישה הוא כפול )שתי גישות( ©צבי מלמד 59 טבלת הדפים והגנות )(protection • הגנה על הזיכרון מושגת בין ,היתר ,באמצעות טבלת הדפים. • בכל כניסה מסומנים מספר ביטים )לצד מספר המסגרת שאליה ממופה הדף(: – הדף לקריאה ,או לכתיבה ,או לביצוע )מכיל קוד( – מותרת פניה לדף במצב משתמש או רק במצב גרעין – האם הדף וולידי )בתוקף( – נכלל במרחב הכתובות של התהליך )בלינוקס יתכנו חורים במרחב הכתובות( – האם הדף בזיכרון או בדיסק ©צבי מלמד 60 מבנה טבלת הדפים • כתובת 32 -סיביות או 64סיביות • נניח – 32סיביות ,וגודל דף 2^12 :בתים .מספר דפים ~מיליון • גודל הטבלה) :בהנחה 4 ,בתים לכל כניסה( 1024 ≈ 4MB :דפים • הקצאת גודל זיכרון כזה ,ושיהיה רציף – אילוץ קשה – מה גם ...שלעתים קרובות חלקים גדולים ממרחב הכתובות כלל אינם בשימוש • השאיפה: – לארגן את הטבלה בדרך אחרת ,חלופית. – נכיר מספר גישות לכך ©צבי מלמד 61 מבנה טבלת הדפים • גישה א': – להפוך את הטבלה לעץ בעל שתיים או יותר רמות – גישה שכיחה ,מקובלת גם בלינוקס – two level paging – 20הביטים של "כתובת הדף" מחולקים לשתי קבוצות של 10ביטים: • – 10 MS-Bitsהכניסה בטבלה החיצונית • הטבלה החיצונית מכילה 2^10כניסות • – 10 LS-Bitsה offset -בתוך הטבלה החיצונית ,משמשת במצביע לטבלה הפנימית. • בטבלה הפנימית :כל כניסה היא בת 10סיביות שמתאימה ל- "10הסיביות הנמוכות" של כתובת הדף • גישה זאת מקובלת במעבדי Pentium • גישה זאת נקראת) forward-mapped page table:תרגום חופשי: "טבלת דפים עם מיפוי קדימה"( ©צבי מלמד 62 טבלת הדפים בעלת 2רמות ©צבי מלמד 63 דוגמא – טבלת מיפוי בשתי רמות מיפוי בשתי רמות מזיכרון סיביות20 ווירטואלי של סיביות16 לזיכרון פיזי של CPU p1 p2 20 PTBR 16 o 10 + Virtual Addresses 1 page table p1 f + p2 First-Level Page Table 64 Physical Addresses ©צבי מלמד Second-Level Page Table Memory f 16 o 10 ”can we use “forward mapped page table ?for 64 bit addressing • השיטה איננה יעילה/סבירה עבור כתובות של 64ביט ...בגלל ריבוי הרמות. • נכיר שיטות אחרות ©צבי מלמד 65
© Copyright 2025