Lecture Operating systems Internals and design principles (6 E) Chapter 6 William Stallings

51 420 0
Lecture Operating systems Internals and design principles (6 E) Chapter 6  William Stallings

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

Chapter 6 Concurrency: Deadlock and starvation. This chapter examines two problems that plague all efforts to support concurrent processing: deadlock and starvation. We begin with a discussion of the underlying principles of deadlock and the related problem of starvation. Then we examine the three common approaches to dealing with deadlock: prevention, detection, and avoidance.

Operating Systems: Internals and Design Principles, 6/E William Stallings Chapter Concurrency: Deadlock and Starvation Patricia Roy Manatee Community College, Venice, FL ©2008, Prentice Hall Deadlock • Permanent blocking of a set of processes that either compete for system resources or communicate with each other • • No efficient solution Involve conflicting needs for resources by two or more processes Deadlock Deadlock Deadlock Reusable Resources • • Used by only one process at a time and not depleted by that use Processes obtain resources that they later release for reuse by other processes Reusable Resources • Processors, I/O channels, main and secondary memory, devices, and data structures such as files, databases, and semaphores • Deadlock occurs if each process holds one resource and requests the other Reusable Resources Reusable Resources • Space is available for allocation of 200Kbytes, and the following sequence of events occur P1 P2 Request 80 Kbytes; • Request 70 Kbytes; Request 60 Kbytes; Request 80 Kbytes; Deadlock occurs if both processes progress to their second request Consumable Resources • • • • Created (produced) and destroyed (consumed) Interrupts, signals, messages, and information in I/O buffers Deadlock may occur if a Receive message is blocking May take a rare combination of events to cause deadlock Dining Philosophers Problem Dining Philosophers Problem Dining Philosophers Problem Dining Philosophers Problem UNIX Concurrency Mechanisms • • • • • Pipes Messages Shared memory Semaphores Signals UNIX Signals Linux Kernel Concurrency Mechanism • • Includes all the mechanisms found in UNIX Atomic operations execute without interruption and without interference Linux Atomic Operations Linux Atomic Operations Linux Spinlocks Linux Semaphores Linux Memory Barrier Operations Solaris Thread Synchronization Primitives • • • • Mutual exclusion (mutex) locks Semaphores Multiple readers, single writer (readers/writer) locks Condition variables Solaris Synchronization Data Structures Windows Synchronization Objects ... depicts a state of the system of resources and processes Conditions for Deadlock • Mutual exclusion – Only one process may use a resource at a time • Hold -and- wait – A process may hold allocated resources... channels, main and secondary memory, devices, and data structures such as files, databases, and semaphores • Deadlock occurs if each process holds one resource and requests the other Reusable Resources... preemption Hold and wait Existence of Deadlock • • • • Mutual Exclusion No preemption Hold and wait Circular wait Deadlock Prevention • Mutual Exclusion – Must be supported by the OS • Hold and Wait

Ngày đăng: 16/05/2017, 13:52

Từ khóa liên quan

Mục lục

  • Slide 1

  • Deadlock

  • Deadlock

  • Deadlock

  • Deadlock

  • Reusable Resources

  • Reusable Resources

  • Reusable Resources

  • Reusable Resources

  • Consumable Resources

  • Example of Deadlock

  • Resource Allocation Graphs

  • Conditions for Deadlock

  • Conditions for Deadlock

  • Resource Allocation Graphs

  • Resource Allocation Graphs

  • Possibility of Deadlock

  • Existence of Deadlock

  • Deadlock Prevention

  • Deadlock Prevention

Tài liệu cùng người dùng

Tài liệu liên quan