티스토리 뷰
Chapter 8. Memory Management - (3), (4)
Multilevel Paging and Performance
- Address space가 더 커지면 다단계 페이지 테이블 필요
- 페이지 테이블이 여러개 있을 수 있지만 그만큼 여러 단계를 거쳐야 하고, 주소 변환을 위해 각 단계에 접근하기 때문에
- 각 단계의 페이지 테이블이 메모리에 존재하므로 logical address의 physical address 변환에 더 많은 메모리 접근 필요
- TLB를 통해 메모리 접근 시간을 줄일 수 있음
- 4단계 페이지 테이블을 사용하는 경우
- 메모리 접근 시간이 100ns, TLB(주소 변환을 용이하게 해주는 캐시 메모리) 접근 시간이 20ns이고
- TLB hit ratio가 98%인 경우 effective memory access time = 0.98 * 120 + 0.02 * 520 = 128 nanoseconds.
- 결과적으로 주소 변환을 위해 28ns만 소요됨. (메모리 접근 시간이 100ns이기 때문에)
- 젤 왼쪽 테이블이 Logical memory, Logical Memory의 개수 만큼 가운데에 있는 페이지 테이블에 엔트리가 존재함.
- 논리적인 메모리가 최종적으로 물리적인 페이지 어디에 적재되어 있는지에 대해서도 페이지 테이블에 저장해둠.
- 주소 변환 정보만 들어있는 것이 아니라 vaild-invaild bit이 같이 들어있음.
- Logical memory의 최대 개수만큼 페이지 테이블 엔트리가 존재하기 때문에, 현재 사용하고 있지 않는 영역이더라도 엔트리가 존재함. 사진 속 6,7 페이지가 없지만 페이지 테이블은 존재하는 것도 이와 같음. 이로 인해 vaild-invaild bit를 통해 이미 물리적으로 적재된 페이지인지 판별 가능.
- 항상 메모리에 올라와있지 않거나, 물리적으로 적재되어 있지 않은 경우 invaild bit를 표기하여 파악 가능.
💡 Memory Protection
- page table의 각 entry마다 아래의 bit를 둔다.
- Protection bit
- page에 대한 접근 권한 (read/write/read-only)
- Valid-Invaild bit
- "valid"는 해당 주소의 frame에 그 프로세스를 구성하는 유효한 내용이 있음을 뜻함 (접근 허용)
- "invalid"는 해당 주소의 frame에 유효한 내용이 없음을 뜻함. (접근 불허)
- 이 때, 유효한 내용이 없다는 의미는 프로세스가 그 주소 부분을 사용하지 않고 있거나,
해당 페이지가 메모리에 올라와 있지 않고 swap area(backing store)에 임시 저장되어 있는 경우를 뜻함.
- 이 때, 유효한 내용이 없다는 의미는 프로세스가 그 주소 부분을 사용하지 않고 있거나,
- Protection bit
💡 Inverted Page Table
- page table이 매우 큰 이유
- 모든 process 별로 그 logical address에 대응하는 모든 page에 대해 page table entry가 존재.
- 대응하는 page가 메모리에 있든 아니든 간에 page table에는 entry로 존재
- 공간 오버헤드가 큰 편.
- Inverted page table
- page frame 하나 당 page table에 하나의 entry를 둔 것 (system-wide)
- 각 page table entry는 각각의 물리적 메모리의 page frame이 담고 있는 내용 표시
(process-id, process의 logical address) - 단점 : 테이블 전체를 탐색해야 함 (시간적인 오버헤드 존재)
- 해결 방법 : associative register 사용 (expensive) -> 별도의 하드웨어를 사용하여 시간적인 오버헤드를 줄이는 방법
- 실제 물리적 메모리의 프레임 개수만큼 페이지 테이블에 엔트리가 존재.
- 페이지 테이블의 첫 번째 엔트리에는 물리적 메모리의 첫 번째 프레임에 들어가는 논리적 메모리의 첫 번째 프레임의 주소가 있고,
- 페이지 테이블의 두 번째 엔트리에는 물리적 메모리의 두 번째 프레임에 들어가는 논리적 메모리의 두 번째 프레임의 주소가 있음.
- 페이지 주소 변환이란, 논리적 메모리의 주소를 참조해서 물리적 메모리를 찾아가는 과정이지만, Inverted Page Table은 반대.
- 논리적 페이지의 페이지 번호 p가 물리적 메모리의 몇 번째 프레임에 위치했는지 찾기 위해서는, 페이지 테이블을 모두 뒤져서 p가 자리한 엔트리를 찾은 뒤 물리적 메모리의 어디에 위치해있는지 알 수 있음.
목적에는 부합하지 않으나 그럼에도 이걸 사용하는 건 페이지 테이블이 메모리에서 차지하는 공간을 줄이기 위한 것. 하지만 시간적인 오버헤드 존재. 뿐만 아니라 p가 어느 프로세스의 p인지 파악하기 위해 프로세스를 구분하는 pid 역시 저장해야 함.
- CPU가 logical address를 줌
- 1번에서 받은 주소를 가지고 page entry를 뒤져서 p가 위치하는 물리적 메모리의 frame 위치를 파악
- p가 여러 개 존재할 수 있기 때문에 현재 CPU를 점유하고 있는 프로세스의 PID를 동시에 줘서 그 PID를 가진 P가 물리적 메모리의 어떤 위치에 존재하는지 찾음.
- 찾아진 위치가 page table에서 몇 번째 떨어진 위치인지(여기서는 f만큼 떨어진 엔트리) 파악해서 물리적 메모리에 가서 f번째 떨어진 엔트리를 찾음으로써 주소 변환을 완료.
💡 Shared Page
- Shared code (Re-entrant Code, 재진입 가능 코드, Pure code)
- read-only로 하여 프로세스 간에 하나의 code만 메모리에 올림 (코드 공유).
e.g. text editors, compilers, window systems - shared code는 모든 프로세스의 logical address space에서 동일한 위치에 있어야 함.
- 공유할 수 있는 코드를 하나만 올려서 여러 프로세스와 매핑. Read-only로만 세팅해서 물리적 메모리에 하나의 code만 올림.
- read-only로 하여 프로세스 간에 하나의 code만 메모리에 올림 (코드 공유).
- Private code and data
- 각 프로세스들은 독자적으로 메모리에 올림
- Private data는 logical address space의 아무 곳에 와도 무방
- 만약 하나의 워드 프로그램을 3개 사용한다고 하면, 같은 프로그램을 사용하기 때문에 프로그램 코드는 share가 가능함. 이렇게 share가 가능한 코드들에 대해서는 물리적 메모리에 하나의 코드만 올려서 이걸 공유함. 각각의 프로세스마다 다른 데이터 코드만 메모리에 별도로 올려서 사용.
2. Segmentation (세그먼테이션 기법)
- 의미 있는 크기, 공간별로 자름. 크기가 균일하지 않음.
- 작게는 프로세스를 구성하는 주소 공간(함수) 하나하나를 의미 단위로 잘라 세그먼트로 정의
- 크게는 프로그램 전체를 하나의 세그먼트로 정의 가능.
- 코드 세그먼트 / 데이터 세그먼트 / 스택 세그먼트 등으로 자름. 함수 별로도 자를 수 있음.
- logical unit 예제
- main(), function, global variables, stack, symbol table, arrays
- main(), function, global variables, stack, symbol table, arrays
💡 Segmentation Architecture
- Logical address는 다음의 두 가지로 구성됨. < Segment-number, offset >
- Segment table (주소변환이 필요하므로 테이블 존재)
- each table entry has
base (starting physical address of segment, 물리 주소),
limit (length of the segment, 세그먼트의 개수)
- each table entry has
- STBR(Segment-table base register)
- 물리적 메모리에서의 segment table의 위치
- table이 어느 위치에 저장되어 있는지
- STLR(Segent-table length register)
- 프로그램이 사용하는 segment의 수
- segment number s가 STLR보다 작으면 오류 발생 !!
- 프로그램이 사용하는 segment의 수
- 프레임의 크기가 일괄적인 페이징 기법과 달리, 세그먼트 기법은 unit별로 크기가 다르기 때문에 물리적 메모리에서 세그먼트가 시작하는 위치인 base와 함께 세그먼트의 크기인 limit 값도 가지고 있음.
- 페이징에서는 프레임 크기가 모두 동일하기 때문에 프레임 번호만으로도 주소를 찾아갈 수 있음
- 주소 변환 시 확인해야할 것은 세그먼트 번호가 STLR보다 작아야 하고, 세그먼트의 크기 limit보다,
세그먼트가 위치하는 곳을 나타내는 offset의 크기 d의 값이 더 크면 역시 scope error이기 때문에 오류 발생. - 이러한 오류가 발생하지 않을 때 비로소 세그먼트가 시작하는 위치 base에서 offset의 크기 d를 더한 주소로 이동해 주소 변환을 진행함.
- Protection
- 각 세그먼트 별로 protection bit가 있음
- Each entry
- Vaild bit = 0 => illegal segment
- Read/Write/Execution 권한 bit
- Sharing
- shared segment (같은 논리 주소 보유)
- same segment number
- segment는 의미 단위이기 때문에 공유와 보안에 있어서 paging보다 훨씬 효과적이다. (장점)
- Allocation
- first fit / best fit
- external fragmentation 발생
- segment의 길이가 동일하지 않으므로 가변 분할 방식에서와 동일한 문제점들이 발생함. (단점)
정리
- 단점: segmentation의 크기가 동일하지 않기 때문에 hole 문제가 발생 가능
- 장점: 의미단위로 일을 처리할 때에는 매우 효과적.
의미 단위로 세그먼트를 나누기 때문에 Read/ Write 등등을 구분하는 게 자연스러움
💡 Example of Segments
- 페이지는 개수가 정말 많지만, 세그먼트는 운영해보면 개수가 몇개 안됨. (이론적인 비교는 앞쪽, 실질적인 비교는 이러함)
- 그러므로 테이블에 의한 메모리 낭비는 페이징이 더 심함. 세그먼트는 좀 더 적음.
- 사진은 5개의 세그먼트로 형성된 경우, 0번 세그먼트의 시작 위치 (base)와 크기(limit)가 표로 형성되어 있음.
- 세그먼트 별로 물리 메모리에 적재되어 있을 수도 있고, 아닐 수도 있음.
Sharing of Segments
💡
- 같은 역할을 하기 때문에 공유를 하는 것
- 세그먼트 번호가 같고, 물리적인 세그먼트 위치가 같아야 함.
- 주소 변환 시 같은 주소로 변환됨. private segment의 경우 다른 위치에 적재되어 있음.
💡 Segmentation with paging
- segment 하나가 여러 개의 page로 구성. 때문에 메모리에 올라갈 때 page 단위로 잘려서 올라감.
segment table entry가 물리적 메모리에서 segment가 어디서 시작하는지 나타내는 base address가 아니라 segment를 구성하는 page의 위치를 나타내는 page table의 base address를 가지고 있음.
이를 통해 segment의 크기가 각각 달라 hole이 발생하는 문제를 해결. - 어떤 segment를 read-only로 설정할 것인지 등등의 의미단위 작업은 segment table에서 미리 설정.
- logical address에서 s를 통해 setment table 내의 몇 번째 segment entry를 나타내는지 확인
- 그렇게 알게 된 segment table의 s에서 segment 내부의 page의 시작 위치인 page-table base를 확인
- 한편, 물리적 메모리에서 해당 segment가 어디에서 시작하는지 나타내는 offset값 d와 s를 비교하여 error를 검출
- 3번에서 이상이 없다면 offset값 d를 나눠서 page의 page-table에서 몇 번째 page entry인지 나타내는 p값과 page의 어디에서 시작되는지 나타내는 offset 값 d'를 확인
- 1~4번에서 얻은 값을 통해 최종적으로 논리적 주소를 물리적 메모리 주소로 변환
- 이 모든 작업은 MMU라는 하드웨어와 CPU가 해줘야 하는 일.
여기서 운영체제가 하는 일은 없음. 운영체제는 IO Device에 접근할 때. 하지만 메모리 접근 시에는 하드웨어가 작업.
⬇︎⬇︎ 강의 링크 ⬇︎⬇︎
http://www.kocw.net/home/search/kemView.do?kemId=1046323
'Study' 카테고리의 다른 글
[OS] KOCW 운영체제 강의 정리 (17) | Chapter 9. Virtual Memory - 2 (0) | 2022.04.02 |
---|---|
[OS] KOCW 운영체제 강의 정리 (16) | Chapter 9. Virtual Memory - 1 (0) | 2022.04.02 |
[OS] KOCW 운영체제 강의 정리 (14) | Chapter 8. Memory Management - 2 (0) | 2022.03.19 |
[OS] KOCW 운영체제 강의 정리 (13) | Chapter 8. Memory Management - 1 (0) | 2022.03.19 |
[OS] KOCW 운영체제 강의 정리 (12) | Chapter 7. Deadlock (0) | 2022.03.12 |
댓글