[OS] Georgia Tech OS 강의 필기
P1L2. Introduction to Operating Systems
data:image/s3,"s3://crabby-images/e30da/e30dae9e524132cf82e80f5e52facd3c2f378fcf" alt=""
P2L1. Processes And Process Management
프로세스란?
- Instance of an executing program
- state of execution: program counter, stack
- parts & temporary holding area: data, register state, occupies state in memory
- may require special hardware: I/O devices
data:image/s3,"s3://crabby-images/03495/03495aae4fda7ae4ae0dfd824aa8769db73edeaf" alt=""
What does a process look like?
data:image/s3,"s3://crabby-images/3f0dd/3f0dd41ba22e0198dcda088fa06d0726f76a8607" alt=""
What is a Process Control Block (PCB)?
data:image/s3,"s3://crabby-images/0ffd5/0ffd516e176034bbfd94af3d338c7dcf375462d4" alt=""
How is a PCB Used?
data:image/s3,"s3://crabby-images/10d17/10d173ea6d6848b6ff7648a572fac6cd0b4b1e8a" alt=""
What is a Context Switch?
cold cache란?
- 메모리에 접근하는 것보다는 processor cache에 접근하는 것이 비용이 훨씬 적다.
- P1이 실행되는 동안 프로세서 캐시에 P1 데이터가 있다가, P2가 실행되면 P1의 데이터는 프로세서 캐시에서 사라진다.
- 결국 P2가 실행되다가 다시 P1이 실행되면 프로세서 캐시에 데이터가 없으므로 메모리에 접근해서 받아와야 한다. 이것이 바로 간접적인 비용이 되는 것
data:image/s3,"s3://crabby-images/21b43/21b439eedf66023e9dee68fff42516e293b39679" alt=""
Process Life Cycle
data:image/s3,"s3://crabby-images/a1df7/a1df71d17c06f753819a73f1a27b12f1a3bfc8c3" alt=""
data:image/s3,"s3://crabby-images/adadc/adadcbfee16d97acb837b3c41e2afcc86a125783" alt=""
Process Creattion
data:image/s3,"s3://crabby-images/7a7ab/7a7ab24c23241653d4b955b539b7b4e392df3120" alt=""
role of the CPU scheduler
data:image/s3,"s3://crabby-images/f4fdf/f4fdf9a9e2ea127a1b1785eace65af721a09577a" alt=""
Length of Process
data:image/s3,"s3://crabby-images/57c01/57c0148cea626f2b758205843fdb09aa0f4956a7" alt=""
data:image/s3,"s3://crabby-images/227da/227dae19b0bd25d2d06d796144ebd2e453788882" alt=""
What about I/O?
data:image/s3,"s3://crabby-images/67c38/67c38b42a286ec9b1932c15800a208d1cdffebe9" alt=""
Inter Process Communication
data:image/s3,"s3://crabby-images/f1ecd/f1ecd2b5d8437ed8473ae95a534481b023c9f1c1" alt=""
data:image/s3,"s3://crabby-images/b5b47/b5b476aff096c0476f47818d195e3c2f16b82cad" alt=""
P2L2. Threads and Concurrency
Introduction
data:image/s3,"s3://crabby-images/21df5/21df5a7e1a7e29a74f819190573eeb632f2e55e1" alt=""
data:image/s3,"s3://crabby-images/f1008/f1008d338b1e6c7f14ebe0c6cfbaa9c793e8c4c4" alt=""
data:image/s3,"s3://crabby-images/3873b/3873b25505e6539e89357c33f9b5f4d539b074b5" alt=""
Process vs. Thread
- Thread는 같은 Virtual Address Space 안에 있다.
- 각각의 스레드는 별도의 레지스터, 스택, 프로그램 카운터를 가지고 있다.
data:image/s3,"s3://crabby-images/9c394/9c39400275397d662881451df650474d8e1aeed6" alt=""
Why are threads useful?
- 스레드의 parallelization을 통해 작업 속도를 높일 수 있다.
- 스레드들은 주소공간을 공유하므로 메모리 효율성이 높다.
Benefits of Multithreading: Single CPU
- Thread Context Switch에 걸리는 시간이 어떤 스레드의 idle 시간보다 길면 Context Switch를 한다.
- 스레드의 context switch는 프로세스의 context switch에 비해 비용이 훨씬 적게 들기 때문에 효율적이다.
data:image/s3,"s3://crabby-images/9bfb8/9bfb8c41a0183d31fb0a49d3387486a9e92bba82" alt=""
Concurrency Control & Coordination
- Mutual Exclusion(mutex): exclusive access to only one thread at a time
- Condition Variable: waiting on other threads specific condition before proceeding
Thread Creation
data:image/s3,"s3://crabby-images/404cd/404cd30b01f38fc9818fe931df106c24d7e80084" alt=""
Mutual Exclusion
- Mutex는 lock 여부, owner, blocked threads에 대한 정보를 필요로 한다.
- critical section code block은 오직 하나의 스레드에 의해서만 실행될 수 있다.
data:image/s3,"s3://crabby-images/fb18f/fb18f6ddcf635ef849dc372edc06d31600e3d047" alt=""
Condition Variable
data:image/s3,"s3://crabby-images/a7fb0/a7fb04e6ce8d71b742600ca2cea617fe05ddb9d7" alt=""
data:image/s3,"s3://crabby-images/d6ab1/d6ab1b6e39e68f5d1d3d0176311484cd4b761814" alt="Powered by GraphCDN, the GraphQL CDN"