Διεργασίες και Νήματα (1/2)

Σχετικά έγγραφα
Διεργασίες - Σύνοψη. Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος. Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής

Χρονοδρομολογητής Κυκλικής Επαναφοράς

Διαχείριση Διεργασιών και Διαδιεργασιακή Επικοινωνία

Διαχείριση Διεργασιών και Διαδιεργασιακή Επικοινωνία

UNIX System Programming

Περιγραφή και Έλεγχος ιεργασιών

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ II. Υφαντόπουλος Νικόλαος Υποψήφιος Διδάκτορας Contact:

Εργαστήριο ΔΙΕΡΓΑΣΙΕΣ - ΔΙΑΧΕΙΡΙΣΗ

1. Εισαγωγή. Λειτουργικά Συστήματα Η/Υ. Διεργασίες. Ορισμός ΚΕΦΑΛΑΙΟ 3 - ΔΙΕΡΓΑΣΙΕΣ. Κεφάλαιο 3 «Διεργασίες»

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκή περίοδος

Εικονική Μνήμη (1/2)

Διεργασίες και Νήματα (2/2)

Λειτουργικά Συστήματα (ΗΥ321)

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκή περίοδος

Λύβας Χρήστος Αρχική επιµέλεια Πιτροπάκης Νικόλαος και Υφαντόπουλος Νικόλαος

Παράλληλη Επεξεργασία

Διεργασίες (μοντέλο μνήμης & εκτέλεσης) Προγραμματισμός II 1

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκό Έτος

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκή περίοδος

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκή περίοδος

Λειτουργικά Συστήματα (Λ/Σ)

Σκελετός Παρουσίασης

Λειτουργικά Συστήματα. Τ.Ε.Ι. Ιονίων Νήσων Σχολή Διοίκησης και Οικονομίας - Λευκάδα

Λειτουργικά Συστήματα (διαχείριση επεξεργαστή, μνήμης και Ε/Ε)

Τι είναι ένα λειτουργικό σύστημα (ΛΣ); Μια άλλη απεικόνιση. Το Λειτουργικό Σύστημα ως μέρος του υπολογιστή

ΚΕΦΑΛΑΙΟ 3: Λειτουργικά Συστήµατα

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκή περίοδος

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκό Έτος

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκό Έτος Κανονική Εξέταση Λύσεις

Δίκτυα Επικοινωνιών ΙΙ: Network Programming UDP Sockets, Signals

Εργαστήριο Λειτουργικών Συστημάτων 8ο εξάμηνο, Ακαδημαϊκή περίοδος

Δημιουργία & Τερματισμός Διεργασιών. Προγραμματισμός II 1

ιεργασίες και νήµατα Προγραµµατισµός ΙΙΙ 1 lalis@inf.uth.gr

Δημιουργία & Τερματισμός Διεργασιών. Προγραμματισμός II 1

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ ΔΙΕΡΓΑΣΙΕΣ

Εισαγωγικά & Βασικές Έννοιες

Λειτουργικά Συστήματα

Εργαστήριο Λειτουργικών Συστημάτων 8o εξάμηνο, Ροή Υ, ΗΜΜΥ

2. Σκοποί και Λειτουργίες των ΛΣ. Λειτουργικά Συστήματα Η/Υ. Περίληψη. Ι. Προστασία Υλικού ΚΕΦΑΛΑΙΟ 2 - ΕΞΕΛΙΞΗ ΚΑΙ ΣΚΟΠΟΙ ΛΣ

Εισαγωγή στα Λειτουργικά Συστήματα

Ε-85: Ειδικά Θέµατα Λογισµικού

Εισαγωγικά & Βασικές Έννοιες

Εισαγωγή εκτελέσιμου κώδικα σε διεργασίες

Το μάθημα. Λειτουργικά Συστήματα Πραγματικού Χρόνου Βασικές Έννοιες 6. Ενσωματωμένα Συστήματα (embedded systems) Παραδείγματα

Προγραμματισμός συστημάτων UNIX/POSIX

Ντίρλης Νικόλαος- ΕΤΥ 2 ο Φροντιστήριο Παρασκευή, 18/10/2013 Β4. Λειτουργικά Συστήματα- Φροντιστήριο 2

Εισαγωγή στην Πληροφορική

Εισαγωγή στην Πληροφορική

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ ΟΡΓΑΝΩΣΗ Η/Υ

Ενότητα 2 (Κεφάλαιο 3) Περιγραφή και Έλεγχος Διεργασιών. Περιεχόμενα. Ανάγκη ύπαρξης διεργασιών 1

Προγραμματισμός συστημάτων UNIX/POSIX. Σήματα (signals)

Υποστήριξη Λ.Σ. ΜΥΥ-106 Εισαγωγή στους Η/Υ και στην Πληροφορική

ΤρόποςΑξιολόγησης: α) Εργαστήρια (Προαιρετικάµε 20% - 35% βαρύτητα µόνοθετικά) β) Τελική Γραπτή Εξέταση

Προγραμματισμός Ταυτόχρονος Προγραμματισμός

Λειτουργικά Συστήματα Πραγματικού Χρόνου

Επιτεύγµατα των Λ.Σ.

Λειτουργικά Συστήματα

Λειτουργικά συστήματα πραγματικού χρόνου

Το λειτουργικό σύστημα. Προγραμματισμός II 1

Διαχείριση Κύριας Μνήμης

Μάθημα 8: Επικοινωνία Συσκευών με τον Επεξεργαστή

Βασικές Έννοιες Πρ Ταο υγρ τόα χ μ ρ μ ο α ν τισμ ος Π ό ρ ςο ΙΙΙ γραμματισμός 1

3.1 Λειτουργικό Σύστηµα. Λειτουργικό Σύστηµα (2) ΚΕΦΑΛΑΙΟ 3: Λειτουργικά Συστήµατα. Ο υπολογιστής σαν σκέτο hardware έχει περιορισµένη χρησιµότητα

ΛΟΓΙΣΜΙΚΟ (software)

Λειτουργικά Συστήματα

Οργάνωση Υπολογιστών (IΙI)

Διαδιεργασιακή επικοινωνία (inter-process communication IPC) Προγραμματισμός II 1

Εισαγωγή στα Λειτουργικά συστήματα Ι. Καθηγητής Κώστας Αναγνωστόπουλος

Διεργασίες (μοντέλο μνήμης & εκτέλεσης) Προγραμματισμός II 1

Θέτοντας και επιστρέφοντας την τιµή της προτεραιότητας διεργασίας

Λειτουργικά Συστήματα Πραγματικού Χρόνου

Προηγμένοι Μικροεπεξεργαστές. Εργαστήριο 4 - Editor

Οργάνωση ενός σύγχρονου Υπολογιστικού Συστήματος ή Ηλεκτρονικού Υπολογιστή (Η/Υ) Τα σύγχρονα συστήματα Η/Υ έχουν την παρακάτω οργάνωση:

Λειτουργικά Συστήματα (ΗΥ321)

Κεφάλαιο 3. Διδακτικοί Στόχοι

Λειτουργικά Συστήματα

Λιβανός Γιώργος Εξάμηνο 2017Β

ΗΜΥ Εργαστήριο Οργάνωσης Υπολογιστών και Μικροεπεξεργαστών

Ένα πρόγραμμα σε εκτέλεση, Μια ασύγχρονη δραστηριότητα,

Πανεπιστήμιο Θεσσαλίας Τμήμα Πληροφορικής

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκό Έτος

Λιβανός Γιώργος Εξάμηνο 2017Β

Εργαστήριο Λειτουργικών Συστημάτων 8ο εξάμηνο, Ακαδημαϊκή περίοδος

Βασικές συσκευές Ε/Ε. Είσοδος Έξοδος στον υπολογιστή. Ένα τυπικό υπολογιστικό σύστημα σήμερα. Οργάνωση Υπολογιστών (IΙI) Μ.

Προγραμματισμός συστημάτων UNIX/POSIX

Λειτουργικά Συστήματα

Σκοπός Μαθήματος. Λειτουργικά Συστήματα Η/Υ. Γενικές Πληροφορίες. Στόχοι Μαθήματος ΚΕΦΑΛΑΙΟ 1 - ΕΙΣΑΓΩΓΗ. Θεωρία: Εργαστήριο: Κεφάλαιο 1 «Εισαγωγή»

Προγραμματισμός συστημάτων UNIX/POSIX. Διεργασίες (processes)

Λειτουργικά Συστήματα

Προηγμένοι Μικροεπεξεργαστές. Φροντιστήριο 4 Real Mode Interrupts

Μάθημα 6 ο. Χρονοδρομολόγηση (Scheduling)

ΔΙΑΧΥΤΑ ΚΑΙ ΕΝΣΩΜΑΤΩΜΕΝΑ ΣΥΣΤΗΜΑΤΑ

Κεφάλαιο 3: Λειτουργικά Συστήματα

Λειτουργικά Συστήματα (Λ/Σ)

Το λειτουργικό σύστημα. Προγραμματισμός II 1

Αρχιτεκτονική Υπολογιστών

Λειτουργικά Συστήματα (Λ/Σ)

Εργαστήριο 7 fork(), exec(), signals

Τμήμα Οικιακής Οικονομίας και Οικολογίας. Οργάνωση Υπολογιστών

Εισαγωγή Χαρακτηριστικά του πυρήνα του Linux Ο ρόλος του λειτουργικού συστήματος...7

Transcript:

Εθνικό Μετσόβιο Πολυτεχνείο Σχολή Ηλεκτρολόγων Μηχ. και Μηχανικών Υπολογιστών Εργαστήριο Υπολογιστικών Συστημάτων Διεργασίες και Νήματα (1/2) Λειτουργικά Συστήματα Υπολογιστών 7ο Εξάμηνο, 2016-2017

Διεργασίες - Σύνοψη Οργάνωση ενός σύγχρονου ΛΣ Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος Διεργασία Process Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής Πίνακας Ελέγχου Διεργασίας Χρονοδρομολόγηση ρ ησε συστήματα καταμερισμού μ χρόνου Λειτουργίες διεργασιών Δημιουργία διεργασιών - το μοντέλο του UNIX Διαδιεργασιακή ήεπικοινωνία

Διεργασίες - Σύνοψη Οργάνωση ενός σύγχρονου ΛΣ Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος Διεργασία Process Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής Πίνακας Ελέγχου Διεργασίας Χρονοδρομολόγηση ρ ησε συστήματα καταμερισμού μ χρόνου Λειτουργίες διεργασιών Δημιουργία διεργασιών - το μοντέλο του UNIX Διαδιεργασιακή ήεπικοινωνία

Οργάνωση ενός ΛΣ Διεργασία 1 Διεργασία 2 Διεργασία 3 Χώρος Χρήστη Υπηρεσίες ΛΣ Χώρος Πυρήνα Οδηγοί Συσκευών Υλικό Υλικό

Οργάνωση ενός ΛΣ Διεργασία 1 Διεργασία 2 Διεργασία 3 κλήσεις συστήματος Χώρος Χρήστη Υπηρεσίες ΛΣ Χώρος Πυρήνα Οδηγοί Συσκευών Υλικό Υλικό

Λειτουργία ενός Σύγχρονου Συστήματος (1) Βασισμένη σε αιτήματα / συμβάντα / διακοπές Το ΛΣ ενεργοποιείται όταν γίνει κάτι από τα παρακάτω: Αίτηση διακοπής από το λογισμικό (trap, software interrupt) Ολοκλήρωση λειτουργίας Ε/Ε (διακοπή υλικού, hardware interrupt) Εσφαλμένη ή μη επιτρεπόμενη εντολή, π.χ. διαίρεση με το μηδέν, (exception, εξαίρεση ) Ο έλεγχος περνάει σε προκαθορισμένο κώδικα του ΛΣ, ανάλογα με τη διακοπή (άνυσμα διακοπών), την αίτηση ή την εξαίρεση Ρουτίνα εξυπηρέτησης διακοπής Μετά το τέλος της, επιστροφή στο προηγούμενο σημείο, υπό προϋποθέσεις

Λειτουργία ενός Σύγχρονου Συστήματος (2) νήματα εκτέλεσης Ν CPU(s) κρυ υφή μνήμ μη εκτέλεση εντολών εντολές και δεδομένα μνήμη αίτηση Ε /Ε δεδομέ ένα διακο πή Απευθείας Πρόσβαση στη Μνήμη (DMA) μονάδες Ε/Ε

Λειτουργία ενός Σύγχρονου Συστήματος (3) Ανάγκη για Προστασία / Απομόνωση Των υπόλοιπων προγραμμάτων Των δομών του ΛΣ Από κακογραμμένο / κακόβουλο κώδικα Λύση: Δύο καταστάσεις λειτουργίας Κατάσταση Χρήστη User Mode Κατάσταση Επόπτη Supervisor / Kernel Mode Πρέπει να παρέχεται από το Υλικό (x86;) Ορισμένες εντολές είναι προνομιούχες (privileged) Οι ρουτίνες εξυπηρέτησης διακοπών τρέχουν σε κατάσταση επόπτη

Οργάνωση ενός ΛΣ Διεργασία 1 Διεργασία 2 Διεργασία 3 κλήσεις συστήματος Χώρος Χρήστη Υπηρεσίες ΛΣ Χώρος Πυρήνα Οδηγοί Συσκευών Υλικό Υλικό

Κλήση Συστήματος Χώρος Χρήστη compute Init ret compute syscall from syscall trap return from interrupt t service syscall Χώρος Πυρήνα Αίτηση προς το ΛΣ (π.χ. Ε/Ε από συσκευή ή αρχείο, αναμονή συμβάντος, διαχείριση διεργασιών) Μετάβαση από κατάσταση χρήστη σε κατάσταση πυρήνα (privileged mode) Κι αν χρειάζεται να περιμένει έως ότου ολοκληρωθεί μια λειτουργία Ε/Ε; Πόσο είναι το κόστος της κλήσης; Υπάρχουν κι άλλοι τρόποι. SYSENTER / SYSEXIT interrupt User Kernel

Διεργασίες - Σύνοψη Οργάνωση ενός σύγχρονου ΛΣ Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος Διεργασία Process Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής Πίνακας Ελέγχου Διεργασίας Χρονοδρομολόγηση σε συστήματα καταμερισμού χρόνου Λειτουργίες διεργασιών Δημιουργία διεργασιών - το μοντέλο του UNIX Διαδιεργασιακή Επικοινωνία

Διεργασία Process Διεργασία: ένα πρόγραμμα υπό εκτέλεση Ένα ζωντανό πρόγραμμα, φορτωμένο στη μνήμη Διεργασία = κώδικας + κατάσταση Πολλές διεργασίες μπορεί να έχουν κοινό πρόγραμμα, κοινό κώδικα Κάθε μία έχει τη δική της, χωριστή κατάσταση Πολλές διεργασίες εκτελούνται ταυτόχρονα κάτω από ΛΣ καταμερισμού μ χρόνου Multiprogramming με time sharing Αναγνωρίζεται από μοναδικό όprocess ID(PID)

Τι είναι μια Διεργασία;

κώδικας - program text Τι είναι μια Διεργασία;

Τι είναι μια Διεργασία; κώδικας - program text Αρχιτεκτονική κατάσταση Μετρητής προγράμματος (PC) Καταχωρητές CPU (%eax, %ebx, %ecx)

Τι είναι μια Διεργασία; κώδικας - program text Αρχιτεκτονική κατάσταση Μετρητής προγράμματος (PC) Καταχωρητές CPU (%eax, %ebx, %ecx) Ιδιωτικός, απομονωμένος χώρος μνήμης Τμήμα δεδομένων (data segment) μεταβλητές Σωρός (heap) Στοίβα (stack)

Τι είναι μια Διεργασία; κώδικας - program text Αρχιτεκτονική κατάσταση Μετρητής προγράμματος (PC) Καταχωρητές CPU (%eax, %ebx, %ecx) Ιδιωτικός, απομονωμένος χώρος μνήμης Τμήμα δεδομένων (data segment) μεταβλητές Σωρός (heap) Στοίβα (stack) Χρησιμοποιούμενοι πόροι του συστήματος Ανοιχτά αρχεία, δικτυακές συνδέσεις

Στιγμιότυπο Διεργασίας στη Μνήμη 2ΤΒ Στοίβα Σωρός Δεδομένα 0 Κείμενο

Στιγμιότυπο Διεργασίας στη Μνήμη 2ΤΒ Στοίβα Σωρός Δεδομένα 0 Κείμενο

Σύγχρονα ΛΣ καταμερισμού χρόνου Διεργασία: η βασική μονάδα εκτέλεσης σε σύγχρονα ΛΣ καταμερισμού χρόνου Ταυτόχρονη, απομονωμένη εκτέλεση Με τη δική της αρχιτεκτονική κατάσταση Σε δικό της, απομονωμένο χώρο μνήμης Αλληλεπίδραση ημε τον έξω κόσμο κλήσεις συστήματος

Σύγχρονα ΛΣ καταμερισμού χρόνου Διεργασία: η βασική μονάδα εκτέλεσης σε σύγχρονα ΛΣ καταμερισμού χρόνου Ταυτόχρονη, απομονωμένη εκτέλεση Με τη δική της αρχιτεκτονική κατάσταση Σε δικό της, απομονωμένο χώρο μνήμης Αλληλεπίδραση ημε τον έξω κόσμο κλήσεις συστήματος Το ΛΣ δημιουργεί και συντηρεί την ψευδαίσθηση της αποκλειστικής χρήσης της μηχανής καταμερισμός χρόνου ανάμεσα στις υπό εκτέλεση διεργασίες Ανάγκη για χρονοδρομολόγηση (CPU Scheduling) Δυνητικά σε πολλούς επεξεργαστές (SMP/multicore) Με δίκαιη κατανομή πόρων ανάμεσα στις διεργασίες

Καταμερισμός Χρόνου: η γενική ιδέα CPU t Ο υπολογιστικός χρόνος κατανέμεται ανάμεσα στις διεργασίες που είναι έτοιμες να τρέξουν (P1, P2, P3) Κάθε διεργασία τρέχει για χρόνο <= του κβάντου χρόνου (time quantum) Το χρονοδρομολογητή ενεργοποιούν διακοπές χρονιστή (timer interrupts) interrupt User Kernel

Καταμερισμός Χρόνου: η γενική ιδέα CPU P 1 timer t Ο υπολογιστικός χρόνος κατανέμεται ανάμεσα στις διεργασίες που είναι έτοιμες να τρέξουν (P1, P2, P3) Κάθε διεργασία τρέχει για χρόνο <= του κβάντου χρόνου (time quantum) Το χρονοδρομολογητή ενεργοποιούν διακοπές χρονιστή (timer interrupts) interrupt User Kernel

Καταμερισμός Χρόνου: η γενική ιδέα CPU P 1 S timer t Ο υπολογιστικός χρόνος κατανέμεται ανάμεσα στις διεργασίες που είναι έτοιμες να τρέξουν (P1, P2, P3) Κάθε διεργασία τρέχει για χρόνο <= του κβάντου χρόνου (time quantum) Το χρονοδρομολογητή ενεργοποιούν διακοπές χρονιστή (timer interrupts) interrupt User Kernel

Καταμερισμός Χρόνου: η γενική ιδέα CPU P 1 S P 2 S P 3 S P 1 timer timer timer t Ο υπολογιστικός χρόνος κατανέμεται ανάμεσα στις διεργασίες που είναι έτοιμες να τρέξουν (P1, P2, P3) Κάθε διεργασία τρέχει για χρόνο <= του κβάντου χρόνου (time quantum) Το χρονοδρομολογητή ενεργοποιούν διακοπές χρονιστή (timer interrupts) interrupt User Kernel

Καταμερισμός Χρόνου: η γενική ιδέα tq CPU P 1 S P 2 S P 3 S P 1 timer timer timer t Ο υπολογιστικός χρόνος κατανέμεται ανάμεσα στις διεργασίες που είναι έτοιμες να τρέξουν (P1, P2, P3) Κάθε διεργασία τρέχει για χρόνο <= του κβάντου χρόνου (time quantum) Το χρονοδρομολογητή ενεργοποιούν διακοπές χρονιστή (timer interrupts) interrupt User Kernel

Κατάσταση Διεργασίας Μεταβάσεις Κάθε διεργασία μεταβαίνει από κατάσταση σε κατάσταση (process state) Νέα (New) δημιουργείται Υπό Εκτέλεση (Running) εκτελείται τώρα στη CPU Έτοιμη (Ready) έτοιμη προς εκτέλεση σε CPU, χρειάζεται χρόνο CPU Σε Αναμονή (Waiting) περιμένει να ολοκληρωθεί E/E, αναμονή συμβάντος, δεν είναι υποψήφια για εκτέλεση σε CPU Τερματισμένη (Terminated) η εκτέλεσή της έχει ολοκληρωθεί

Νέα (New) Κύκλος Ζωής μιας Διεργασίας (1)

Κύκλος Ζωής μιας Διεργασίας (1) Νέα (New) αποδοχή Έτοιμη (Ready)

Κύκλος Ζωής μιας Διεργασίας (1) Νέα (New) αποδοχή Έτοιμη Υπό Εκτέλεση (Ready) (Running) επιλογή από χρονοδρομολογητή

Κύκλος Ζωής μιας Διεργασίας (1) Νέα (New) αποδοχή εκπνοή κβάντου χρόνου Έτοιμη Υπό Εκτέλεση (Ready) (Running) επιλογή από χρονοδρομολογητή

Κύκλος Ζωής μιας Διεργασίας (1) Νέα (New) αποδοχή εκπνοή κβάντου χρόνου Έτοιμη Υπό Εκτέλεση (Ready) (Running) επιλογή από χρονοδρομολογητή ολοκλήρωση Ε/Ε ή συμβάντος Σε Αναμονή (Waiting) αίτηση Ε/Ε ή αναμονή συμβάντος

Κύκλος Ζωής μιας Διεργασίας (1) Νέα (New) αποδοχή εκπνοή κβάντου χρόνου Τερματισμένη (Terminated) έξοδος Έτοιμη Υπό Εκτέλεση (Ready) (Running) επιλογή από χρονοδρομολογητή ολοκλήρωση Ε/Ε ή συμβάντος Σε Αναμονή (Waiting) αίτηση Ε/Ε ή αναμονή συμβάντος

Πίνακας Ελέγχου Διεργασίας (1) Process Control Block (PCB) Ταυτότητα διεργασίας (PID) Κατάσταση διεργασίας (process state) Νέα, Έτοιμη, Υπό Εκτέλεση, Σε Αναμονή, Τερματισμένη Αρχιτεκτονική κατάσταση (architectural t state) t Μετρητής προγράμματος, καταχωρητές CPU Πληροφορίες χρονοδρομολόγησης Προτεραιότητα, δείκτες σε ουρές χρονοδρομολογητή Πληροφορίες διαχείρισης μνήμης Δεσμευμένες περιοχές μνήμης, είδος και όρια πρόσβασης Πληροφορίες για έλεγχο πρόσβασης Ταυτότητα χρήστη, δικαιώματα πρόσβασης, δυνατότητες Πληροφορίες για τρέχουσα κατάσταση λειτουργιών Ε/Ε Πίνακας ανοιχτών αρχείων

Πίνακας Ελέγχου Διεργασίας (2) PCB ταυτότητα διεργασίας κατάσταση διεργασίας μετρητής προγράμματος καταχωρητές CPU δεδομένα διαχείρισης μνήμης (περιοχές, όρια) πίνακας ανοιχτών αρχείων δικαιώματα πρόσβασης (αριθμός χρήστη, δυνατότητες)

Πίνακας Ελέγχου Διεργασίας (2) $ cat /usr/src/linux/include/linux/sched.h... struct task_struct { volatile long state; /* -1 unrunnable, 0 runnable, >0 stopped */ void *stack;... int prio, static_prio, i normal_prio; unsigned int rt_priority;... struct mm_struct *mm, *active_mm;... pid _ t pid;... const struct cred *cred; /* effective (overridable) subjective task * credentials (COW) */... /* open file information */ struct files_struct struct *files;... }; real-life Linux PCB in C

Διεργασίες - Σύνοψη Οργάνωση ενός σύγχρονου ΛΣ Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος Διεργασία Process Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής Πίνακας Ελέγχου Διεργασίας Χρονοδρομολόγηση σε συστήματα καταμερισμού χρόνου Λειτουργίες διεργασιών Δημιουργία διεργασιών - το μοντέλο του UNIX Διαδιεργασιακή Επικοινωνία

Καταμερισμός Χρόνου: η γενική ιδέα tq CPU P 1 S P 2 S P 3 S P 1 timer timer timer t Ο υπολογιστικός χρόνος κατανέμεται ανάμεσα στις διεργασίες που είναι έτοιμες να τρέξουν (P1, P2, P3) Κάθε διεργασία τρέχει για χρόνο <= του κβάντου χρόνου (time quantum) Το χρονοδρομολογητή ενεργοποιούν διακοπές χρονιστή (timer interrupts) interrupt User Kernel

Εναλλαγή Περιβάλλοντος Λειτουργίας (1) Context Switch: Η CPU αλλάζει από διεργασία σε διεργασία Αποθήκευση κατάστασης παλιάς (στο PCB της) Επαναφορά νέας διεργασίας (από το PCB της) Πόσο διαρκεί; Είναι χαμένος χρόνος για τη CPU Πόσο συχνά; το σύστημα πρέπει να είναι αποκρίσιμο

Εναλλαγή Περιβάλλοντος Λειτουργίας (2) P 0 P 1 διακοπή ή κλήση συστήματος Αποθήκευση κατάστασης στο PCB P 0 Τι ποσοστό του Επαναφορά κατάστασης από PCB P 1 χρόνου χάνεται στο context tswitch; διακοπή ή κλήση συστήματος Αποθήκευση κατάστασης στο PCB P 1 Επαναφορά κατάστασης από PCB P 0 interrupt User Kernel

Κύκλος Ζωής μιας Διεργασίας (2) create() / fork() Ουρά Έτοιμων Διεργασιών (Ready List) CPU exit() Εκπνοή κβάντου χρόνου I/O read() / write() Αίτηση I/Ο Διακοπή / άλλο συμβάν sleep() / wait() Αναμονή για συμβάν

Διεργασίες - Σύνοψη Οργάνωση ενός σύγχρονου ΛΣ Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος Διεργασία Process Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής Πίνακας Ελέγχου Διεργασίας Χρονοδρομολόγηση σε συστήματα καταμερισμού χρόνου Λειτουργίες ί διεργασιών Δημιουργία διεργασιών - το μοντέλο του UNIX Διαδιεργασιακή Επικοινωνία

Λειτουργίες Διεργασιών Δημιουργία και καταστροφή διεργασιών Δυναμική, κατά τη λειτουργία του συστήματος (fork()) Μέσω κλήσεων συστήματος

Λειτουργίες Διεργασιών Δημιουργία και καταστροφή διεργασιών Δυναμική, κατά τη λειτουργία του συστήματος (fork()) Μέσω κλήσεων συστήματος Ιεραρχία διεργασιών Μια γονική διεργασία δημιουργεί διεργασίες-παιδιά (parent και children processes) Προκύπτει ιεραρχική οργάνωση, σε δέντρο διεργασιών

Λειτουργίες Διεργασιών Δημιουργία και καταστροφή διεργασιών Δυναμική, κατά τη λειτουργία του συστήματος (fork()) Μέσω κλήσεων συστήματος Ιεραρχία διεργασιών Μια γονική διεργασία δημιουργεί διεργασίες-παιδιά (parent και children processes) Προκύπτει ιεραρχική οργάνωση, σε δέντρο διεργασιών Τερματισμός διεργασίας Οικειοθελής, όταν ολοκληρώσει το έργο της (exit()) Βίαιος, λόγω εξωτερικού παράγοντα Αποστολή σήματος (kill()) από άλλη διεργασία τερματισμός από το λειτουργικό όλόγω εσφαλμένης λειτουργίας ( This program has performed an illegal operation στα Windows)

Λειτουργίες Διεργασιών Δημιουργία και καταστροφή διεργασιών Δυναμική, κατά τη λειτουργία του συστήματος (fork()) Μέσω κλήσεων συστήματος Ιεραρχία διεργασιών Μια γονική διεργασία δημιουργεί διεργασίες-παιδιά (parent και children processes) Προκύπτει ιεραρχική οργάνωση, σε δέντρο διεργασιών Τερματισμός διεργασίας Οικειοθελής, όταν ολοκληρώσει το έργο της (exit()) Βίαιος, λόγω εξωτερικού παράγοντα Αποστολή σήματος (kill()) από άλλη διεργασία τερματισμός από το λειτουργικό όλόγω εσφαλμένης λειτουργίας ( This program has performed an illegal operation στα Windows) Ο γονέας ενημερώνεται (wait()) Κι αν πεθάνει πριν από το παιδί του;

Δέντρο Διεργασιών στο Linux init (1) syslogd (2781) cupsd (3043) smbd (2978) smbd (3018) sshd (20484) sshd (678) bash (1835) vi (1892) firefox (1903) pstree (2001)

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ } else { } PID=981 mypid = getpid(); child(); father();

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ } else { } PID=981 mypid = getpid(); child(); father();

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ } else { } PID=981 mypid = getpid(); child(); father();

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : -1 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = -1, errno = if (p < 0) { ENOMEM perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : -1 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = -1, errno = if (p < 0) { ENOMEM perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : -1 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = -1, errno = if (p < 0) { ENOMEM perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : -1 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = -1, errno = if (p < 0) { ENOMEM perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981

Δημιουργία στο μοντέλο του UNIX: fork()

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ } else { } PID=981 mypid = getpid(); child(); father();

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ } else { } PID=981 mypid = getpid(); child(); father();

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: 987 pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: 987 pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Δεδομένα : 987 p =? mypid =? Κείμενο: pid_t p, mypid; p = fork(); p = 987 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=981 Δεδομένα : 0 p =? mypid =? Κείμενο: 987 pid_t p, mypid; p = fork(); p = 0 if (p < 0) { perror( fork ); exit(1); }elseif(p == 0){ mypid = getpid(); child(); } else { father(); } PID=987

Δημιουργία στο μοντέλο του UNIX: fork() Όλες οι διεργασίες προκύπτουν με fork() [σχεδόν όλες] Ίδιο πρόγραμμα με γονική διεργασία, αντίγραφο χώρου μνήμης, κληρονομεί ανοιχτά αρχεία, συνδέσεις, δικαιώματα πρόσβασης Αντικατάσταση προγράμματος διεργασίας: execve() Η γονική διεργασία ενημερώνεται για το θάνατο του παιδιού με wait() συλλογή τιμής τερματισμού (exit status) Μέχρι τότε, παιδί που έχει καλέσει την exit() είναι zombie Αν ο γονέας πεθάνει πρώτα, η διεργασία γίνεται παιδί της init (PID = 1), που κάνει συνεχώς wait() prog-a Prog-A fork 981 981 wait Prog-A 987 Prog-B 987 (zombie) Prog-B execve 987 exit

Διεργασίες - Σύνοψη Οργάνωση ενός σύγχρονου ΛΣ Διακοπές, προνομιούχος κατάσταση Κλήσεις συστήματος Διεργασία Process Ορισμός, μεταβάσεις κατάστασης κύκλος ζωής Πίνακας Ελέγχου Διεργασίας Χρονοδρομολόγηση σε συστήματα καταμερισμού χρόνου Λειτουργίες διεργασιών Δημιουργία διεργασιών - το μοντέλο του UNIX Διαδιεργασιακή Επικοινωνία

Διαδιεργασιακή Επικοινωνία (IPC) Inter-Process Communication (IPC) Διεργασίες που συνεργάζονται. Γιατί;

Διαδιεργασιακή Επικοινωνία (IPC) Inter-Process Communication (IPC) Διεργασίες που συνεργάζονται. Γιατί; Παράλληλη εκτέλεση, επιτάχυνση Δομημένη σχεδίαση, διαχωρισμός προνομίων Ταυτόχρονη πρόσβαση σε κοινά δεδομένα

Διαδιεργασιακή Επικοινωνία (IPC) Inter-Process Communication (IPC) Διεργασίες που συνεργάζονται. Γιατί; Παράλληλη εκτέλεση, επιτάχυνση Δομημένη σχεδίαση, διαχωρισμός προνομίων Ταυτόχρονη πρόσβαση σε κοινά δεδομένα Διαφορετικοί Μηχανισμοί από ΛΣ σε ΛΣ Μοιραζόμενη Μνήμη (Shared Memory Segments) Μηνύματα η μ (Microkernels - Mach, POSIX messages) Σήματα (UNIX) Pipes (UNIX, Win32)

Μοιραζόμενη Μνήμη Εικονική ήμνήμη P0 Εικονική ήμνήμη P1 Φυσική Μνήμη Πρόσβαση σε κοινό τμήμα μνήμης (shared memory segment) Για περισσότερες από μία διεργασίες Άμεση αλληλεπίδραση, με εντολές load/store Χωρίς κλήσεις συστήματος Ενημέρωση για αλλαγές; έλεγχος (polling) Πώς εξασφαλίζεται ότι δεν γράφουν στο ίδιο σημείο ταυτόχρονα; Το κοινό τμήμα απεικονίζεται στο χώρο εικονικής μνήμης των διεργασιών

Μοιραζόμενη Μνήμη Εικονική ήμνήμη P0 Εικονική ήμνήμη P1 Φυσική Μνήμη Πρόσβαση σε κοινό τμήμα μνήμης (shared memory segment) Για περισσότερες από μία διεργασίες Άμεση αλληλεπίδραση, με εντολές load/store Χωρίς κλήσεις συστήματος Ενημέρωση για αλλαγές; έλεγχος (polling) Πώς εξασφαλίζεται ότι δεν γράφουν στο ίδιο σημείο ταυτόχρονα; Το κοινό τμήμα απεικονίζεται στο χώρο εικονικής μνήμης των διεργασιών

Μοιραζόμενη Μνήμη Εικονική ήμνήμη P0 Εικονική ήμνήμη P1 Φυσική Μνήμη Πρόσβαση σε κοινό τμήμα μνήμης (shared memory segment) Για περισσότερες από μία διεργασίες Άμεση αλληλεπίδραση, με εντολές load/store Χωρίς κλήσεις συστήματος Ενημέρωση για αλλαγές; έλεγχος (polling) Πώς εξασφαλίζεται ότι δεν γράφουν στο ίδιο σημείο ταυτόχρονα; Το κοινό τμήμα απεικονίζεται στο χώρο εικονικής μνήμης των διεργασιών

Μοιραζόμενη Μνήμη Εικονική ήμνήμη P0 Εικονική ήμνήμη P1 Φυσική Μνήμη Πρόσβαση σε κοινό τμήμα μνήμης (shared memory segment) Για περισσότερες από μία διεργασίες Άμεση αλληλεπίδραση, με εντολές load/store Χωρίς κλήσεις συστήματος Ενημέρωση για αλλαγές; έλεγχος (polling) Πώς εξασφαλίζεται ότι δεν γράφουν στο ίδιο σημείο ταυτόχρονα; Το κοινό τμήμα απεικονίζεται στο χώρο εικονικής μνήμης των διεργασιών

Επικοινωνία με πέρασμα μηνυμάτων (1) Διεργασία 1 Διεργασία 2 Μ Χώρος Χρήστη Πυρήνας Χώρος Πυρήνα Επικοινωνία χωρίς μοιραζόμενη μνήμη μέσω κλήσεων συστήματος

Επικοινωνία με πέρασμα μηνυμάτων (1) Διεργασία 1 Διεργασία 2 Μ Χώρος Χρήστη sendmsg() Μ Πυρήνας Χώρος Πυρήνα Επικοινωνία χωρίς μοιραζόμενη μνήμη μέσω κλήσεων συστήματος

Επικοινωνία με πέρασμα μηνυμάτων (1) Διεργασία 1 Διεργασία 2 Μ Μ Χώρος Χρήστη sendmsg() recvmsg() Μ Πυρήνας Χώρος Πυρήνα Επικοινωνία χωρίς μοιραζόμενη μνήμη μέσω κλήσεων συστήματος

Επικοινωνία με πέρασμα μηνυμάτων (2) Σχεδιαστικές αποφάσεις

Επικοινωνία με πέρασμα μηνυμάτων (2) Σχεδιαστικές αποφάσεις Άμεση ή έμμεση επικοινωνία;

Επικοινωνία με πέρασμα μηνυμάτων (2) Σχεδιαστικές αποφάσεις Άμεση ή έμμεση επικοινωνία; Σύγχρονη ή ασύγχρονη επικοινωνία;

Επικοινωνία με πέρασμα μηνυμάτων (2) Σχεδιαστικές αποφάσεις Άμεση ή έμμεση επικοινωνία; Σύγχρονη ή ασύγχρονη επικοινωνία; Προσωρινή αποθήκευση μηνυμάτων σε απομονωτές Προσωρινή αποθήκευση μηνυμάτων σε απομονωτές (buffering)

Επικοινωνία με πέρασμα μηνυμάτων (2) Ονοματολογία Άμεσα, συμμετρικά send(p, message); receive(q, message) όπου P, Q είναι Process IDs Άμεσα, ασύμμετρα send(p, message); receive(id, message) όπου το P δίνεται, το id τίθεται από την receive() Έμμεσα, με χρήση γραμματοθυρίδων (mailboxes) / θυρών (ports) send(a, message); receive(a, message) όπου Α το αναγνωριστικό της θυρίδας (π.χ. ένας ακέραιος) δημιουργία και καταστροφή θυρίδων;

Επικοινωνία με πέρασμα μηνυμάτων (3) Συγχρονισμός Αποστολές με ή χωρίς αναμονή (blocking / non-blocking send) Λήψη με ή χωρίς αναμονή (blocking / non-blocking receive) Σύγχρονος ή ασύγχρονος τρόπος λειτουργίας (rendez-vous) Προσωρινή ρ αποθήκευση σε απομονωτές Χωρίς προσωρινή αποθήκευση (σύγχρονα) Πεπερασμένη χωρητικότητα ο αποστολέας μπλοκάρει όταν ο απομονωτής γεμίσει Απεριόριστη χωρητικότητα με δυναμική δέσμευση χώρου

Σήματα στο UNIX (1) Ενσωματωμένα ήδη από τις πρώτες εκδόσεις του UNIX (Έκδοση 7) Ασύγχρονη Ειδοποίηση για Εξωτερικό Γεγονός Κάθε σήμα έχει ένα συμβολικό όνομα SIGINT, SIGTSTP, SIGCONT, SIGSTOP, SIGFPE, SIGSEGV, SIGABRT, SIGQUIT, SIGWINCH, SIGTERM, SIGKILL Και διαφορετική σημασία, π.χ. Διακοπή Πληκτρολογίου, Ctrl-C (SIGINT) Αναστολή από το πληκτρολόγιο (SIGTSTP) Τερματισμός (SIGTERM) Βίαιος Τερματισμός (SIGKILL) Κάποια αποστέλλονται αυτόματα από το ΛΣ κάποια από άλλη Κάποια αποστέλλονται αυτόματα από το ΛΣ, κάποια από άλλη διεργασία (kill())

Σήματα στο UNIX (2) Για εισερχόμενο σήμα, εκτελείται προκαθορισμένη ενέργεια (συνήθως τερματισμός) Η wait() επιστρέφει ανάλογο status Το σήμα μπορεί να συλληφθεί, οπότε εκτελείται συνάρτηση χειρισμού του (signal(), sigaction()) π.χ., όταν πατηθεί Ctrl-C, C, σώσε το ανοιχτό αρχείο Τα SIGSTOP και SIGKILL δεν πιάνονται Αναξιόπιστος μηχανισμός επικοινωνίας Ασύγχρονος, με race conditions Το POSIX προβλέπει αξιόπιστα σήματα (sigprocmask(), sigsuspend())

Σωληνώσεις στο UNIX (1) Διεργασία write fd[1] άκρο εγγραφής M read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο ανάγνωσης Ένας από τους βασικότερους μηχανισμούς στο UNIX Μονόδρομη μεταφορά δεδομένων Από το άκρο εγγραφής στο άκρο ανάγνωσης Δημιουργία με pipe(), επικοινωνία με write() και read() Αν η σωλήνωση είναι άδεια; η read() μπλοκάρει

Σωληνώσεις στο UNIX (1) Διεργασία Χώρος Χρήστη Χώρος Πυρήνα int fd[2]; int num1, num2; pipe(fd); write(fd[1], &num1, sizeof(num1)); read(fd[0], &num2, sizeof(num2));

Σωληνώσεις στο UNIX (1) Διεργασία Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης int fd[2]; int num1, num2; pipe(fd); write(fd[1], &num1, sizeof(num1)); read(fd[0], &num2, sizeof(num2));

Σωληνώσεις στο UNIX (1) Διεργασία write fd[1] άκρο εγγραφής M Χώρος Χρήστη Χώρος Πυρήνα άκρο ανάγνωσης int fd[2]; int num1, num2; pipe(fd); write(fd[1], &num1, sizeof(num1)); read(fd[0], &num2, sizeof(num2));

Σωληνώσεις στο UNIX (1) Διεργασία write fd[1] άκρο εγγραφής M int fd[2]; int num1, num2; read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο ανάγνωσης pipe(fd); write(fd[1], &num1, sizeof(num1)); read(fd[0], &num2, sizeof(num2));

Σωληνώσεις στο UNIX (1) Διεργασία write fd[1] read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης int fd[2]; int num1, num2; pipe(fd); write(fd[1], &num1, sizeof(num1)); read(fd[0], &num2, sizeof(num2));

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας Χώρος Χρήστη Χώρος Πυρήνα pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] read fd[0] Διεργασία παιδί write fd[1] read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] Διεργασία παιδί write fd[1] read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] Διεργασία παιδί read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] άκρο εγγραφής M Διεργασία παιδί read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Σωληνώσεις στο UNIX (2) Διεργασία πατέρας write fd[1] Διεργασία παιδί read fd[0] Χώρος Χρήστη Χώρος Πυρήνα άκρο εγγραφής άκρο ανάγνωσης pipe(fd); fork(); ο πατέρας κλείνει το άκρο ανάγνωσης το παιδί κλείνει το άκρο εγγραφής

Ερωτήσεις;

Ερωτήσεις; και στη λίστα: OS@lists.cslab.ece.ntua.gr