Tech

Diary

Lecture

About Me

개발중

DeadLock 1

JeongSeulho

2023년 02월 19일

준비중...
클립보드로 복사

📌blocked/asleep state

  • 프로세스가 특정 이벤트를 기다리는 상태
  • 프로세스가 필요한 자원을 기다리는 상태

📌Deadlock state

  • 프로세스가 발생 가능성이 없는 이벤트를 기다리는 경우
    • 프로세스가 deadlock 상태이다
  • 시스템내의 deadlock에 빠진 프로세스가 있는 경우
    • 시스템이 deadlock 상태이다

starvation 과 deadlock

  • deadlock : 불가능한 이벤트를 대기(가능성 0)
  • starvation : cpu할당을 대기(오래 기다리는 것 가능성이 0은 아님)

📌자원의 분류

📖선점 가능 여부에 따른 분류

  • preemptible resources
    • 선점 당한 후 돌아와도 문제가 없는 자원
    • CPU, 메모리 등
    • cpu의 context saving, restoring을 하기 때문
  • non-preemptible resources
    • 선점 당한 후 문제가 발생하는 자원
    • 디스크
    • usb에 복사중에 뺏기면 오류남

📖할당 단위에 따른 분류

  • total allocation resources
    • 자원 전체를 프로세스에게 할당
    • CPU(single core기준), disk
  • partitioned allocation resources
    • 하나의 자원을 여러 조각으로 나누어 프로세스에 할당
    • 메모리

📖동시 사용 가능 여부에 따른 분류

  • exclusive allocation resources
    • 한 순간에 한 프로세스만 사용 가능한 자원
    • CPU, 메모리, 디스크
  • shared allocation resources
    • 여러 프로세스가 동시에 사용 가능한 자원
    • 프로그램(sw), shared data

📖재사용 가능 여부에 따른 분류

  • SR(serially-reusable Resources)
    • 시스템 내에 항상 존재하는 자원
    • 사용이 끝나면 다른 프로세스가 사용 가능
    • CPU, 메모리, 디스크, 프로그램
  • CR(consumable Resources)
    • 한 프로세스가 사용한 후에 사라지는 자원
    • signal, message

deadlock을 발생시킬 수 있는 자원의 종류

  • non-preemptible resources
  • exclusive allocation resources
  • serially-reusable resources
  • consumable resources