일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 자바
- 깃허브
- package-private
- Effective Java
- 스터디
- 뮤텍스
- 이펙티브 자바
- 세마포어
- 디지털
- Public
- OS
- 메모리
- 알고리즘
- 개발
- 깃
- 정보처리기사
- spring
- 운영체제
- 컴퓨터공학
- 스프링
- 신입
- 신입사원
- 공채
- 프로그래밍
- 우리카드
- 컴퓨터과학
- java
- CS
- IT
- github
Archives
- Today
- Total
주니어 개발자 성장기
Memory Management(메모리 관리) 3 - 페이징 본문
Noncontiguous allocation(불연속 할당/ 분산 할당)
하나의 프로세스가 메모리의 여러 영역에 분산되어 올라갈 수 있음
Paging
address binding
이 복잡해짐- 동일한 크기의 페이지로 프로세스를 나눠 메모리에 적재
- 내부 단편화 발생 가능
- 페이지 테이블에는 각 페이지가 물리 메모리에 몇 번 프레임에 있는지 원소로 기록되어 있다.
- 논리 주소는 페이지 넘버($p$)와 오프셋($d$)로 구성되어 있다.
Page Table의 구현
- 프로그램마다 페이지 테이블이 별도로 존재한다.
- 페이지 테이블은 메인 메모리에 상주한다.
- 그래서 모든 메모리 접근 연산에는 2번의 Memory access가 필요하다.
- 페이지 테이블 접근 1회
- 실제 data / instruction 접근 1회
- Page-table base register(PTBR)가 페이지 테이블 자체를 가리킴
- Page-table length register(PTLR)가 테이블 크기를 보관한다.
- 그래서 모든 메모리 접근 연산에는 2번의 Memory access가 필요하다.
- 속도 향상을 위해
associative register
혹은translation look-aside buffer
(TLB)라고 불리는 고속의 lookup hardware cache를 사용한다.
TLB
- 메모리 주소 변환을 위한 메인 메모리와 CPU 사이의 하드웨어다.
- 메인 메모리보다 접근 속도가 빠르다.
- 페이지 테이블의 전부를 저장하는 것이 아니라 빈번히 참조되는 페이지의 정보만 가지고 있다.
- TLB는
parallel search
가 가능하다. (요청된 페이지 정보가 없을 수도 있기 떄문에 전체 탐색 비용을 줄이기 위해서) - 프로세스마다 메모리 주소체계가 다르기 때문에
context switch
발생 시flush
된다.
Effective Access Time
- TLB 접근 시간 = $ε$
- 메모리 접근 시간 = $1$
- Hit ratio = $α$
실제 평균 메모리 접근 시간(Effective Access Time)은?
$EAT=(1+ε)α+(2+ε)(1-α)=2+ε-α$
Two-Level Page Table
- 현대의 컴퓨터는 address space가 매우 큰 프로그램을 지원한다.
- 32bit address 사용시 $2^{32}$(4G)의 주소 공간을 갖는다.
- page size가 4K이면 1M개의 page table entry가 필요하다.
- 각 page entry가 4B이면 프로세스당 4M의 페이지 테이블이 필요하다.
- 그러나 대부분의 프로그램은 4G의 주소 공간 중 지극히 일부분만 사용하므로 page table 공간이 심하게 낭비된다.
- 32bit address 사용시 $2^{32}$(4G)의 주소 공간을 갖는다.
- page table 자체를 page로 구성하는 해결법이 바로
Two-Level Page Table
이다. - 사용되지 않는 주소 공간에 대한
outer page table
의 엔트리 값은 NULL(대응하는 inner page table이 없다.)이다. - NULL인 엔트리에 대한
inner page table
이 메모리 상에 만들어지지 않기 때문에 공간을 상당히 절약할 수 있게 되는 것이다.
예시
page offset
- 한 페이지의 사이즈가 4KB이므로 Byte단위로 주소를 구분하기 위해서 $2^{12}$bit가 필요하다.inner page number
- 한 페이지의 사이즈가 4KB이고 엔트리가 4B이므로 1K개 즉, $2^{10}$bit가 필요하다.outer page number
- 나머지 $2^{10}$bit를 가지게 된다.
Multilevel Paging and Performance
- Address space가 더 커지면 다단계 페이지 테이블 필요
- 각 단계의 페이지 테이블이 메모리에 존재하므로
logical address
의physical address
변환에 더 많은 메모리 접근 필요 - TLB를 통해 메모리 접근 시간을 줄일 수 있음
- 4단계 페이지 테이블을 사용하는 경우
- 메모리 접근 시간이 $100ns$, TLB 접근 시간이 $20ns$이고 TLB hit ratio가 98%인 경우
- $EAT = 0.98 × 120 + 0.02 × 520 = 128ns$
- 결과적으로 주소 변환을 위해 $28ns$만 소요된다.
Valid(v) / Invalid (i) Bit in a Page Table
- 페이지 테이블 엔트리에는
frame number
외에도 사용되지 않는 영역을 체크하기 위한valid-invalid bit
가 존재한다. - 이유는 테이블이라는 자료구조 특성상 인덱스로 접근하기 때문에 모든 엔트리가 있어야 하고 사용이 되지 않으면 invalid로 체크하는 것이다.
valid
는 해당 주소의 frame에 그 프로세스를 구성하는 유효한 내용이 있음을 뜻함 (접근 허용)invalid
는 해당 주소의 frame에 그 프로세스를 구성하는 유효한 내용이 없음을 뜻함 (접근 불허)- 프로세스가 그 주소 부분을 사용하지 않는 경우
- 해당 페이지가 메모리에 올라와 있지 않고
swap area
에 있는 경우
Protection Bit
- page에 대한 접근 권한을 나타낸다 (read/write/read-only)
- 예를 들어
code
영역은 내용이 바뀌면 안되기 때문에 read-only로 보호한다.
- 예를 들어
- 다른 프로세스의 접근을 막는 것은 아니다.
Inverted Page Table Architecture
추후 정리
Shared Pages
추후 정리
출처
반효경, "운영체제 2014-1", KOCW, http://www.kocw.net/home/cview.do?cid=3646706b4347ef09
'CS스터디 > 운영체제' 카테고리의 다른 글
Memory Management(메모리 관리) 4 - 세그먼테이션 (0) | 2024.06.30 |
---|---|
Memory Management(메모리 관리) 2 - 연속 할당 (0) | 2024.04.06 |
Memory Management(메모리 관리) 1 - 주소 바인딩, Swapping, Linking (0) | 2024.04.05 |
Deadlock(교착상태) 조건과 처리 (0) | 2024.04.03 |
Process Synchronization - Monitor (0) | 2024.04.02 |