일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- ret2libc
- Security
- stride
- 유스케이스
- 게임개발
- STCF
- sampling theory
- 배경 그림
- TSet
- MAC
- linear difference equation
- dirty cow
- 운영체제
- frequency-domain spectrum analysis
- 메카님
- 게임 개발
- 언리얼엔진
- AINCAA
- Race condition
- DSP
- Rr
- Unity #Indie Game
- MLFQ
- CTF
- 유니티
- DP
- dtft
- RBAC
- Double free
- pdlc
- Today
- Total
다양한 기록
메모리 가상화 - introduction 본문
CPU 가상화 -> 타임 쉐어링
메모리 가상화 -> 스페이스 쉐어링
1. Early Systems
물리 메모리를 그대로 사용함
메모리에 OS와 하나의 프로그램이 올라감
프로텍션 X
이슈: 프로그램이 물리 메모리보다 크면?
개발자가 프로그램을 나눠서 올리고 내리고 반복 => 오버레이
2. Multiprogramming and Time Sharing
* 멀티 프로그래밍 단어 자체는 메모리 상에 여러 프로세스가 올라간 거
* 여기에 CPU 가상화까지 타임 쉐어링
프로텍션 중요, 어떻게 물리 메모리를 잘 나눠줄 것이냐
3. 버추얼 메모리
가상적인 메모리 공간을 프로세스가 혼자 사용
프로세스의 개수만큼 버추얼 메모리가 존재
물리 메모리는 쉐어 / 버추얼 메모리는 독점
목표:
- 사용하기 편해야 함
- 빨라야 함
- 프로텍션 (Isolation)
* 어쨌든 개발자들이 보는 모든 주소는 가상 주소임
Types of Memory
Static: Code(text), Data
Dynamic: Heap, Stack
CPU 가상화
- 제한된 직접 수행
- 특권 명령어, 타이머 인터럽트
메모리 가상화
- 주소 변환: 성능 좋아야 하고 컨트롤이 되어야 함.. 변환은 하드웨어(MMD), 컨트롤은 OS가(새로운 버추얼 메모리 할당)
void func() {
int x = 3000;
x = x + 3;
}
128: movl 0x0(%ebx), %eax
132: addl $0x03, %eax
135: movl %eax, 0x0(%ebx)
어셈블리 코드만 보면 총 5번의 메모리 접근이 있음
(물리 메모리는 고려하지 않은 경우)
버추얼 메모리 공간을 0~16KB 까지 있다고 가정,
피지컬 메모리 공간을 0~64KB
그리고 32~48KB에 프로세스가 올라간다고 가정
주소 변환(가상 주소 -> 물리 주소)
첫 명령어 주소: 128 -> 32KB + 128
변수 x : 15KB -> 32KB + 15KB = 47KB
In general: base address + offset
Base register
Bound(limit) register
Physical address = base register + virtual address
바운드 레지스터보다 더 큰 주소에 접근하면 세그멘테이션 파울트
1. 버추얼 메모리는 배타적으로 가지고, 피지컬 메모리는 공유
2. 버추얼 메모리는 0부터 시작, 피지컬 메모리는 어디서부터든 실행 가능
3. 버추얼 메모리 메모리 사이즈와 독립적, CPU 비트에 의해 결정
버추얼 메모리는 컴파일러가 만들어짐 (레이아웃)
물리 메모리는 OS가 결정
주소 변환은 하드웨어가 함
MMU (Memory management unit)
주소 변환을 위한 CPU의 일부
베이스, 바운드 레지스터, 세그멘테이션 관련 레지스터, 페이징 관련 레지스터, TLB, 회로
* TLB는 주소 변환을 가속하기 위한 캐시
요약
OS
메모리 관리, 할당, 프리
문맥 교환 시 베이스와 바운드 레지스터 교체
예외 시 처리
HW
매 실행마다 가상주소 - 물리주소 변환해줘야 함
기법
1. 연속적
2. 불연속적 - 세그멘테이션
3. 불연속적 - 페이징
'운영체제' 카테고리의 다른 글
Paging (페이징)과 TLB (0) | 2024.06.16 |
---|---|
Segmentation (세그멘테이션) (0) | 2024.06.15 |
플래시 메모리과 파일 시스템 (0) | 2024.06.15 |
Consistency other approaches / Ext2,3,4 (0) | 2024.06.15 |
Consistency / Journaling (0) | 2024.06.15 |