Operating System Concepts (7)

Module 7: Deadlocks.• System Model.• Deadlock Characterization.• Methods for Handling Deadlocks.• Deadlock Prevention.• Deadlock Avoidance.• Deadlock Detection.• Recovery from Deadlock.• Combined Approach to Deadlock Handling. Silberschatz and Galvin 1999 The Deadlock Problem.• A set of blocked processes each holding a resource and waiting. to acquire a resource held by another process in the set• Example. – System has 2 tape drives – P1 and P2 each hold one tape drive and each needs another. one• Example. – semaphores A and B, initialized to 1 P0 P1. wait (A); wait(B). wait (B); wait(A). Silberschatz and Galvin 1999 Bridge Crossing Example.• Traffic only in one direction• Each section of a bridge can be viewed as a resource• If a deadlock occurs, it can be resolved if one car backs up. (preempt resources and rollback)• Several cars may have to be backed upif a deadlock occurs• Starvation is possible Silberschatz and Galvin 1999 System Model.• Resource types R1, R2, . . ., Rm. CPU cycles, memory space, I/O devices.• Each resource type Ri has Wi instances.• Each process utilizes a resource as follows:. – request. – use. – release. Silberschatz and Galvin 1999 Deadlock CharacterizationDeadlock can arise if four conditions hold simultaneously. • Mutual exclusion: only one process at a time can use a. resource • Hold and wait: a process holding at least one resource is. waiting to acquire additional resources held by other processes • No preemption: a resource can be released only voluntarily by. the process holding it, after that process has completed its task • Circular wait: there exists a set {P0, P1, , P0} of waiting. processes such that P0 is waiting for a resource that is held by. P1, P1 is waiting for a resource that is held by P2, , Pn–1 is. waiting for a resource that is held by Pn, and P0 is waiting for a. resource that is held by P0 Silberschatz and Galvin 1999 Resource-Allocation set of vertices V and a set of edges E. • V is partitioned into two types:. – P = {P1, P2, , Pn}, the set consisting of all the processes in. the system. – R = {R1, R2, , Rm}, the set consisting of all resource types. in the system • request edge – directed edge P1 Rj • assignment edge – directed edge Rj Pi. Silberschatz and Galvin 1999 Resource-Allocation Graph (Cont.)• Process.• Resource Type with 4 instances.• Pi requests instance of Rj. Pi. Rj• Pi is holding an instance of Rj. Pi. Rj. Silberschatz and Galvin 1999 Example of a Resource Allocation Graph. Silberschatz and Galvin 1999 Resource Allocation Graph With A Deadlock. Silberschatz and Galvin 1999 Resource Allocation Graph With A Cycle But No Deadlock. Silberschatz and Galvin 1999 Basic Facts.• If graph contains no cycles no deadlock• If graph contains a cycle. – if only one instance per re

Không thể tạo bản xem trước, hãy bấm tải xuống
Đã phát hiện trình chặn quảng cáo AdBlock
Trang web này phụ thuộc vào doanh thu từ số lần hiển thị quảng cáo để tồn tại. Vui lòng tắt trình chặn quảng cáo của bạn hoặc tạm dừng tính năng chặn quảng cáo cho trang web này.