Practical Session 11 File Systems & Midterm 2012

Slides:



Advertisements
Similar presentations
More on File Management
Advertisements

Slide 2-1 Copyright © 2004 Pearson Education, Inc. Operating Systems: A Modern Perspective, Chapter 2 Using the Operating System 2.
Concepts about the file system 2. The disk structure 3. Files in disk – The ext2 FS 4. The Virtual File System (c) 2013, Prof. Jordi Garcia.
Chapter 4 : File Systems What is a file system?
UNIX File Systems (Chap 4. in the book “the design of the UNIX OS”) Acknowledgement : Soongsil Univ. Presentation Materials.
CS 104 Introduction to Computer Science and Graphics Problems Operating Systems (4) File Management & Input/Out Systems 10/14/2008 Yang Song (Prepared.
Introduction to Kernel
Home: Phones OFF Please Unix Kernel Parminder Singh Kang Home:
Ceng Operating Systems
6/24/2015B.RamamurthyPage 1 File System B. Ramamurthy.
1 File Management in Representative Operating Systems.
CS-502 Fall 2006Processes in Unix, Linux, & Windows 1 Processes in Unix, Linux, and Windows CS502 Operating Systems.
1 Course Outline Processes & Threads CPU Scheduling Synchronization & Deadlock Memory Management File Systems & I/O Networks, Protection and Security.
7/15/2015B.RamamurthyPage 1 File System B. Ramamurthy.
Phones OFF Please Processes Parminder Singh Kang Home:
Contiguous Allocation of Disk Space. Linked Allocation.
Rensselaer Polytechnic Institute CSCI-4210 – Operating Systems David Goldschmidt, Ph.D.
CS 6560 Operating System Design Lecture 13 Finish File Systems Block I/O Layer.
Chapter 4. INTERNAL REPRESENTATION OF FILES
File Systems CSCI What is a file? A file is information that is stored on disks or other external media.
File Management Chapter 12. File Management File management system is considered part of the operating system Input to applications is by means of a file.
UNIX Files File organization and a few primitives.
File System Implementation
Files & File system. A Possible File System Layout Tanenbaum, Modern Operating Systems 3 e, (c) 2008 Prentice-Hall, Inc. All rights reserved
Solutions for the First Quiz COSC 6360 Spring 2014.
1 Chapter 4. INTERNAL REPRESENTATION OF FILES THE DESIGN OF THE UNIX OPERATING SYSTEM Maurice J. bach Prentice Hall.
Processes, Threads, and Process States. Programs and Processes  Program: an executable file (before/after compilation)  Process: an instance of a program.
File Systems. 2 What is a file? A repository for data Is long lasting (until explicitly deleted).
Linux File system Implementations
Slide: 1 UNIX FILE SYSTEM By:Qing Yang ID: Operating System Research Topic December, 2000.
THE FILE SYSTEM Files long-term storage RAM short-term storage Programs, data, and text are all stored in files, which is stored on.
Lecture 19 Linux/Unix – File System
What is an Operating System? Various systems and their pros and cons –E.g. multi-tasking vs. Batch OS definitions –Resource allocator –Control program.
Operating Systems, 152 Practical Session 11 File Systems 1.
MINIX Presented by: Clinton Morse, Joseph Paetz, Theresa Sullivan, and Angela Volk.
Direct memory access. IO Command includes: buffer address buffer length read or write dada position in disk When IO complete, DMA sends an interrupt request.
File System Department of Computer Science Southern Illinois University Edwardsville Spring, 2016 Dr. Hiroshi Fujinoki CS 314.
Operating Systems, Winter Semester 2011 Practical Session 11 File Systems, part 1 1.
File System Design David E. Culler CS162 – Operating Systems and Systems Programming Lecture 23 October 22, 2014 Reading: A&D a HW 4 out Proj 2 out.
Operating Systems Practical Session 11 File Systems 1.
Introduction to Kernel
Today topics: File System Implementation
Process Management Process Concept Why only the global variables?
Chapter 3: Process Concept
Structure of Processes
Day 27 File System.
Chapter 11: File System Implementation
Filesystems.
KERNEL ARCHITECTURE.
Operating Systems: What and Why
Lecture 45 Syed Mansoor Sarwar
Processes in Unix, Linux, and Windows
Operation System Program 4
Chapter 11: File System Implementation
Operating Systems Practical Session 11 File Systems.
Operating Systems, 162 Practical Session 11 File Systems 1.
An overview of the kernel structure
Practical Session 11 File Systems & Midterm 2013
Chapter 11: File System Implementation
Processes in Unix, Linux, and Windows
File System B. Ramamurthy B.Ramamurthy 11/27/2018.
Operating Systems Lecture 6.
Mid Term review CSC345.
Processes in Unix, Linux, and Windows
Processes in Unix and Windows
UNIX File Systems (Chap 4. in the book “the design of the UNIX OS”)
Chapter 11: File System Implementation
Department of Computer Science
Internal Representation of Files
Structure of Processes
Presentation transcript:

Practical Session 11 File Systems & Midterm 2012 Operating Systems, 122 Practical Session 11 File Systems & Midterm 2012

Quick recap Files are an abstraction mechanism Several file types: User files (regular),Directory files, Special files (Block, Char) Access: sequentially (e.g. tapes) or random access (disk) Data: structured (records) or unstructured (set of bits and bytes) In short, a device file (also called as a special file) is an interface for a device driver that appears in a file system as if it were an ordinary file. This allows software to interact with the device driver using standard input/output system calls, which simplifies many tasks. Device file two types There are two types of device files based upon how data written to them and read from them is processed by the operating system and hardware: Character special files or Character devices Block special files or Block devices Understanding Character special files or Character devices Talks to devices in a character by character (1 byte at a time) Examples: Virtual terminals, terminals and serial modems etc Understanding Block special files or Block devices Talks to devices 1 block at a time ( 1 block = 512 bytes to 32KB) Examples: Hard disk, DVD/CD ROM, and memory regions etc

File system layout (Tanenbaum) Unix like file system.

Quick recap: Index-Nodes (i-nodes) The superblock object represents the entire file system and provides access to index-nodes. Each i-node is a data structure containing pointers to the disk blocks that contain the actual file contents. An i-node corresponds to a single file. An i-node needs to be in the main memory only if the correspondent file is open. Besides the data blocks pointers, the i-node also contains information on the file permissions, owner, etc

Quick recap: i-Nodes File Size HardLink count General file attributes The number of hard-links to the file File owner identifier: Ownership is divided between an individual owner and a "group" owner and defines the set of users who have access rights to a file. The superuser has access rights to all files in the system. File type: Files may be regular, directory, character or block special FIFO (pipes). File access permissions : File access times: giving the time the file was last modified, when it was last accessed, and when the inode was last modified. Number of links to the file: representing the number of names the file has in the directory hierarchy. Table of contents for the disk addresses of data in a file. Although users treat the data in a file as a logical stream of bytes, the kernel saves the data in discontiguous disk blocks. The inode identifies the disk blocks that contain the file's data. File size. Data in a file is addressable by the number of bytes from the beginning of the file, starting from byte offset 0, and the file size is 1 greater than the highest byte offset of data in the file. The inode does not specify the path name(s) that access the file. Usually between 10 and 12

Question 1: i-nodes How many time will the disk be accessed when a user executes the following command: more /usr/tmp/a.txt Assume that: The size of 'a.txt' is 1 block. The i-node of the root directory is not in the memory. Entries 'usr', 'tmp' and 'a.txt' are all located in the first block of their directories.

Question 1: i-nodes Accessing each directory requires at least 2 disk accesses: reading the i-node and the first block. In our case the entry we are looking for is always in the first block so we need exactly 2 disk accesses. According to assumption 2 the root directory's i-node is located on the disk so we need 6 disk accesses (3 directories) until we reach a.txt's i-node index. Since "more" displays the file's content, for a.txt we need its i-node + all the blocks of the file (1 block, according to assumption). Total disk accesses: 6 + 2 = 8.

Question 1: i-nodes A similar problem

Question 2: i-nodes The Ofer2000 Operating Systems, based on UNIX, provides the following system call: rename(char *old, char *new) This call changes a file’s name from ‘old’ to ‘new’. What is the difference between using this call, and just copying ‘old’ to a new file, ‘new’, followed by deleting ‘old’? Answer in terms of disk access and allocation.

Question 2: i-nodes rename - simply changes the file name in the entry of  its directory. copy -  will allocate a new i-node and the blocks for the new file, and copy the contents of the old file blocks to the new ones. delete - will release the i-node and blocks of the old file. copy + delete - is a much more complicated operation for the Operating System, note that you will not be able to execute it if you do not have enough free blocks or i-nodes left on your disk.

Question 3: i-nodes Write an implementation (pseudo code) of the system call: delete(i-node node) Which deletes the file associated with node. Assume that: node is associated with a regular file, and that delete is not recursive. The i-node has 10 direct block entries, 1 single indirect entry and 1 double indirect entry. You may use the system calls: read_block(block b) which reads block b from the disk. free_block(block b) and free_i-node(i-node node).

Question 3: i-nodes delete(i-node node){ // remove the direct blocks for each block b in node.direct do free_block(b); // remove the single indirect blocks single <-- read_block(node.single_indirect) for each entry e in single do free_block(e); free_block(single); // remove the double indirect blocks double <-- read_block(node.double_indirect) for each entry e in double do single <-- read_block(e) for each entry ee in single do free_block(ee); free_block(double); // remove the i-node free_i-node(node); }

Question 4: i-nodes What would be the maximal size of a file in a UNIX system with an address size of 32 bits if : The block size is 1K The block size is 4K (The i-node has 10 direct block entries)

Question 4: i-nodes Block size: 1K Direct: 10·1K Single indirect: each address is 32 bit = 4 byte then we have 256 pointers to blocks of size 1K (i.e. 256·1K) The same idea is applied for double and triple indirect. In total: 10·1K+256·1K+256·256·1K+256·256·256·1K

Question 4: i-nodes Block size: 4K Direct: 10·4K Single indirect: each address is 32 bit = 4 byte then we have 1024 pointers to blocks of size 4K (i.e. 1024·4K) The same idea is applied for double and triple indirect In total: 10·4K+1024·4K+1024·1024·4K+1024·1024·1024·4K

Question 5: i-nodes Assuming that the size of each block is 1K and the address size is 32 bits (4 bytes). Convert byte address (offset) 1,515,000 in our file to the physical address.

Question 5: I-Nodes Byte number 1,515,000 is calculated as follows: 1st byte of the double indirect block is 10k+256k = 272,384 byte number 1,515,000 is number 1,242,616 in the double indirect block every single indirect block has 256k bytes --> byte 1,242,616 is in the 5th single indirect block (4*256k = 1,048,576) Every entry is 1k, so byte 194,040 is in the 189th block – assume that it points to block 123 on the disk within block 123 , it is byte #504

Operating Systems MIDTERM 2012

(30 נקודות) תזמון (scheduling) Question 1 (30 נקודות) תזמון (scheduling)

Question 1 א. (5 נק'). תארו בקצרה אך באופן מדוייק וברור את אופן פעולתם של שני האלגוריתמים הבאים לתזמון: Round robin ו-Guaranteed scheduling. בפרט, תארו איזו "הגינות" (fairness) בתזמון מבטיחים שני האלגוריתמים. פתרון: Round robin – הינו אלג' preemptive, בעל פרמטר המגדיר את משך ה time slice אשר יקבל כל תהליך. האלג' בוחר תהליכים לריצה מבין התהליכים שהינם במצב ready על פי סדר מעגלי. הוגנות: שואף לתת זמן ריצה שווה לתהליכים במצב ready. האלג' מבטיח שאין starvation מכוון שזמן ההמתנה של כל תהליך חסום במספר התהליכים הממתינים כפול גודל ה time slice. Guaranteed scheduling – הינו אלג' preemptive, השואף לתת זמן ריצה שווה לכל התהליכים. עושה זאת על ידי שמירה של ערך המציין את היחס בין הזמן שהתהליך קיבל בפועל לבין הזמן שמגיע לו. האלג' יבחר להריץ את התהליך עם הערך הקטן ביותר. הוגנות: האלג' בוחר בכל שלב את התהליך ה-"מקופח" ביותר, ובכך מבטיח שלא יהיה starvation. חישוב היחס מתחשב גם בהתהליכים שיצאו ל I/O ובכך יפצה אותם על הזמן שיאבדו.

Question 1 ב. (5 נק'). נניח כי במערכת קיימים מספר חוטי קרנל (kernel threads) שהם CPU-bound ומספר חוטי קרנל שהם I/O-bound. איזה מבין שני האלגוריתמים מתאים יותר עבור מערכת כזו? נמקו בקיצור אך באופן מדוייק וברור. פתרון: במקרה זה נעדיף את אלגוריתם Guaranteed scheduling, וזאת מפני שהאלגוריתם יוודא שתהליכי ה IO-bound אשר לרוב ישתמשו בפחות זמן מעבד יקבלו אפשרות לרוץ באשר הם מוכנים. במובן כזה האלגוריתם שלנו יהיה קרוב יותר ל SJF מכוון שיעדיף תהליכים אשר יהיו זקוקים לזמן מעבד קצר יותר, ובנוסף יהיה הוגן יותר מבחינת הזמן הכולל שיקבל כל תהליך. תחת R.R. לעומת זאת, לאורך זמן תהיה העדפה ברורה (מבחינת זמן מעבד) לתהליכי ה CPU-bound.

Question 1 ג. (8 נק'). כאשר עסקנו במוניטורים, תיארנו את המימושים הבאים. 1) מימוש מוניטור בסמנטיקה של Hoare (בו מובטח כי החוט המקבל את הסיגנל הוא הבא לרוץ במוניטור), ו-2) מוניטור של Java, בו לא מתקיימת הבטחה שכזו ובכל פעם החוטים (threads) המעוניינים להיכנס אליו ונמצאים במצב ready מתחרים על הכניסה. נניח כי במערכת ישנם מספר חוטים המשתמשים במוניטור. האם הבחירה בין שני האלגוריתמים הנ"ל לתזמון תשפיע יותר על מימוש המשתמש במוניטור מטיפוס Hoare או על מוניטור של Java? נמקו תשובתכם בקיצור אך באופן מדוייק וברור.

Question 1 פתרון: הבחירה תשפיע יותר על מוניטור של Java, וזאת מכוון שבמצב זה אלגוריתם התזמון יחליט למעשה מי התהליך שיכנס למוניטור. אם יהיה זה Round robin, אז יהיה זה התהליך המעוניין הבא שניתקל בו במעבר המעגלי. אם יהיה זה Guaranteed scheduling, אזי התהליך שיכנס למוניטור יהיה התהליך המעוניין שקיבל את יחס הזמן הנמוך ביותר. במוניטור מטיפוס Hoare, המוניטור למעשה יבחר מי התהליך הבא שיוכל להכנס, ולכן לאלג' התזמון לא תהיה השפעה רבה על הריצה.

Question 1 ד. (12 נק'). נניח כי במערכת בעלת מעבד (CPU) יחיד ישנה קבוצת חוטים אשר כל אחד מהם רץ תמיד משך זמן T לפני שהוא עובר להמתנה ל-I/O וכי context switch אורך זמן S. נניח גם כי מערכת מופעל אלגוריתם תזמון round robin עם time-quantum באורך Q. ניתן להניח כי תמיד ישנם במערכת חוטים המוכנים לרוץ (אינם ממתינים ל-I/O). חשבו את ניצולת ה-CPU במערכת כפונקציה של פרמטרים אלו עבור המקרים הבאים: Q>T S<Q<T Q שואף לאפס

Question 1 פתרון: במקרה זה Q חסר משמעות. כל תהליך ירוץ זמן T ואז נבזבז S זמן ב C.S. לכן ניצולת המעבד תהיה: 𝑇 𝑇+𝑆 התקבלו תשובות בהן הונח ש 𝑇 𝑄 ∈ℕ. במצב כזה נקבל ניצולת מעבד: 𝑇 𝑇+ 𝑇 𝑄 𝑆 = 1 1+ 𝑆 𝑄 = 𝑄 𝑄+𝑆 כאשר 𝑄→0 נקבל על פי הנוסחה מהסעיף הקודם: lim 𝑄→0 𝑄 𝑄+𝑆 = 0 𝑆 =0

(35 נקודות) תהליכים וחוטים Question 2 (35 נקודות) תהליכים וחוטים

Question 2 א. (15 נק'). מהם הפלטים האפשריים של התוכנית הבאה, על המסך ובקובץ a.txt? עבור כל פלט, ציינו האם הוא מודפס על ידי התהליך האב, תהליך בן או חוט. הניחו כי התוכנית רצה על מערכת עם מעבד יחיד, וכי פתיחת הקובץ מצליחה. הניחו כי בכל תהליך המזהים של החוטים נקבעים בסדר עולה, החל מ-1. בנוסף, הניחו כי כאשר תכנית מרובת חוטים מבצעת פעולת fork רק החוט אשר ביצע את הקריאה משתכפל. הניחו גם כי כל פעולת הדפסה היא אטומית (כלומר, היא לא תופרע באמצע על ידי context switch).

Question 2 int main() { int fd; pthread_t tid[2]; printf("STARTED\n"); fd = dup(STDOUT_FILENO); close(STDOUT_FILENO); open("a.txt", O_WRONLY | O_CREAT | O_TRUNC); pthread_create(&tid[0], NULL, foo, NULL); fork(); pthread_create(&tid[1], NULL, foo, NULL); sleep(10); // sleep for 10 seconds printf("after fork x=%d\n", x); dup(fd); printf("FINISHED\n"); return 0; } int x = -1; void foo() { printf("x=%d\n", x); x = pthread_self(); // get thread ID }

Question 2 פתרון: On screen: STARTED FINISHED a.txt: x = -1 (parent)   STARTED FINISHED a.txt: x = -1 (parent) x = -1/1/2 (parent) x = -1/1 (child) after fork x = 1/2 (parent) after fork x = 1 (child) * first 3 lines can come in any order * last 2 lines could come in any order פתרון:

Question 2 ב. (10 נק'). הניחו כי ברשותכם שרת אינטרנט המספק בקשות משתמשים. לשרת מבנה נתונים בו הוא שומר ערכים שהובאו עבור בקשות שהתבצעו לאחרונה. בכל פעם שמתקבלת בקשה, מתבצעת פעולת חיפוש מהירה במבנה הנתונים. במידה והמידע הנדרש אינו מצוי במבנה הנתונים, מתבצע תהליך אחזור מתוך דיסק (I/O). הניחו כי לשרת מעבד יחיד. כמו כן הניחו כי לא ניתן לבצע שתי פעולות I/O לדיסק במקביל. נסמן ב-h את ההסתברות למציאת המידע הנדרש במבנה הנתונים, ב-c את הזמן הנדרש לאחזור מידע ממבנה הנתונים וב-t את משך הזמן הנדרש לאחזור מידע מהדיסק (ברור כי t>c). בפרט, כאשר המידע הנדרש לא נמצא במבנה הנתונים, משך האיחזור הכולל הוא t+c (ראשית יש לקרוא את המידע מן הדיסק למבנה הנתונים ואז לקראו ממבנה הנתונים). נתון כי שתי בקשות בלתי תלויות זו בזו, כל אחת מהן למידע שונה, מגיעות בו זמנית למערכת. מהו משך הזמן הצפוי עד להשלמת הבקשות במערכת מבוססת חוטי משתמש (user space threads)? מהו משך הזמן הצפוי עד להשלמת הבקשות במערכת מבוססת חוטי קרנל (kernel threads)?

Question 2 פתרון: חוטי משתמש: 2ch^2+2(c+t)(1-h)^2+h(1-h)(4c+2t) חוטי קרנל: 2ch^2+ (c+2t)(1-h)^2+h(1-h)(2c+t+c+t) פעמיים גישה של c+t מתחלק לשני מקרים סימטריים כל אחד 2c+t שאחד מסיים c השני מתחיל c בזמן ה t של הראשון גם מתחלק לשני מקרים: הצלחה + כישלון נותן 2c+t כישלון + הצלחה נותן c+t כי c<t

Question 2 ג. (10 נק'). נתון קטע הקוד הבא: void sigchld_handler(int s) { printf(“S”); } int main(){ signal(SIGCHLD, sigchld_handler); signal_block(SIGCHLD); if (fork() != 0) { printf(“A”); signal_unblock(SIGCHLD); printf(“B”); wait (); printf(“C”); } else { printf(“D”);

Question 2 ידוע כי הפקודות signal_block וכן signal_unblock חוסמות ומשחררות חסימה לסיגנלים. שרטטו גרף מכוון המתאר את הפלטים האפשריים לקוד זה. כל צומת בגרף תסמל הדפסה וכל קשת מכוונת תייצג יחס סדר מתחייב בין הדפסות. לדוגמא, אם עפ"י קוד מסוים ידוע כי יודפסו "X", "Y" ו- "Z" וכי ההדפסה של "X" תופיע בהכרח לפני ההדפסה של "Y" (אך "Z" יכול להופיע לפני או אחרי כל אחת מן ההדפסות האחרות), יתקבל הגרף הבא: X Y Z

Question 2 פתרון: void sigchld_handler(int s) { printf(“S”); } int main(){ signal(SIGCHLD, sigchld_handler); signal_block(SIGCHLD); if (fork() != 0) { printf(“A”); signal_unblock(SIGCHLD); printf(“B”); wait (); printf(“C”); } else { printf(“D”); A D B S C

(35 נקודות) סינכרוניזציה מניעה הדדית Question 3 (35 נקודות) סינכרוניזציה מניעה הדדית

Question 3 א. (5 נק'). בכיתה הגדרנו את התנאים חופש מקיפאון (deadlock freedom) וחופש מהרעבה (starvation freedom) עבור אלגוריתמים למניעה הדדית. כתבו את ההגדרות המדוייקות של תנאים אלו. פתרון: חופש מקיפאון: אם קבוצת תהליכים מנסה להיכנס לקטע הקריטי, אזי לאחר מספר סופי של צעדים אחד התהליכים יצליח להיכנס אליו. חופש מהרעבה: אם תהליך מנסה להיכנס לקטע הקריטי, אזי לאחר מספר סופי של צעדים הוא יצליח להיכנס אליו.

Question 3 ב. (10 נק'). בכיתה הגדרנו תנאי הוגנות (fairness) עבור בעיית המניעה ההדדית הקרוי first-in-first-out (FIFO). כתבו את ההגדרה המדוייקת של תנאי זה. האלגוריתם למניעה הדדית של פטרסון לשני תהליכים מובא בסוף שאלה זו. האם האלגוריתם מקיים תנאי FIFO? נמקו בקצרה אך במדוייק. פתרון: אם תהליך A ממתין (נמצא ב-waiting section) לפני שתהליך B התחיל לבצע את ה-doorway אזי B לא יכנס לפני A כן. אם אחד התהליכים נכנס להמתנה לפני שהשני החל לבצע את קטע הכניסה, אזי התהלך הראשון יכנס ראשון לקטע הקריטי

Question 3 ג. (10 נק'). בשאלה זו עליכם לממש אלגוריתם למניעה הדדית עבור שלושה תהליכים – p, q ו-r. על האלגוריתם לקיים מניעה הדדית וחופש מקיפאון. בנוסף, עליו לקיים את הדרישה הבאה המבטיחה עדיפות לתהליך p: אם p מתחיל להמתין למנעול טרם שהתהליך המחזיק במנעול החל לבצע את קוד היציאה (exit section) שלו, אזי p הוא התהליך הבא שיכנס לקטע הקריטי. לצורך המימוש מותר להשתמש אך ורק במשתנים התומכים בקריאות ובכתיבות. אין להשתמש בסוגים אחרים של משתנים (בפרט, אין להשתמש בסמפורים או בפעולות כגון test-and-set). ניתן גם להשתמש באלגוריתם של פטרסון למניעה הדדית עבור שני תהליכים כאבן בניין. הסבירו בקצרה את האלגוריתם שכתבתם ונמקו בקצרה מדוע הוא מקיים את שנדרש (אין צורך בהוכחה פורמלית).

Question 3 להלן האלגוריתם של פטרסון למניעה הדדית עבור שני תהליכים. שני הדגלים b[0] ו-b[1] מאותחלים לערך false. המשתנה turn מאותחל לערך 0 או 1 (אין זה משנה מבחינת נכונות האלגוריתם). Algorithm for p0 b[0]=true turn=0 await (b[1]=false OR turn=1) CS b[0]=false Algorithm for p1 b[1]=true turn=1 await (b[0]=false OR turn=0) CS b[1]=false

Question 3 פתרון: פתרון זה עושה שימוש באבן בניין מסוג פטרסון: אם אחד מהתהליכים q או r בקטע הקריטי אזי התהליך השני לא יחל לבצע את Peterson(p,qr) טרם שהראשון יצא ואזי אם p כבר מחכה ב Peterson(p,qr) הוא הבא שיכנס. אופן אחר להסתכל על כך – p "מתחרה" תמיד רק עם אחד משני התהליכים האחרים. האלגוריתם הוא גם חסר הרעבה. Algorithm for q Peterson(q,r).lock // as p0 Peterson(p,qr).lock // as p1 CS Peterson(p,qr).unlock // as p1 Peterson(q,r).unlock // as p0 Algorithm for r Peterson(q,r).lock // as p1 Peterson(p,qr).lock // as p1 CS Peterson(p,qr).unlock // as p1 Peterson(q,r).unlock // as p1 Algorithm for p Peterson(p,qr).lock // as p0 CS Peterson(p,qr).unlock // as p0

Question 3 פתרון: הפעם מימוש ללא אבני בניין: // We set for each process an id. q as 0, r as 1, and p as 2. intrested[1..3] = {false, false, false} turn[1..2] // init values are not important void enter(i) { // for i = 0 || 1 intrested[i] = true; turn[0] = 1- i; while (intrested[1-i] = true && turn[0] = 1-i); turn[1] = 2; while (Intrested[2] = true && turn[1] = 2); } void enterForProcess2() { intrested[2] = true; turn[1] = 0; while ((intrested[0] = true || intrested[1] = true) && turn[1] = 0); } void leave(i) { intrested[i] = false; }

Question 3 ד. (10 נק'). שלומציונה טוענת כי אלגוריתם המקיים את הדרישות של סעיף ג. בהכרח אינו מקיים חופש מהרעבה (starvation freedom). האם טענתה צודקת? נמקו תשובתכם בקצרה, אך באופן מדוייק וברור. פתרון: לא, ולראיה האלגוריתם לעיל. ומכל מקום, הדרישות של סעיף ג אינן גוררות שלא מתקיים חופש מהרעבה.