-
페이지 교체운영체제/가상 메모리 2018. 2. 4. 20:42
모든 메모리가 사용 중이어서 빈 프레임이 없는 경우 페이지 교체가 필요하다. 기본적인 페이지 교체 만약 빈 프레임이 없다면 현재 사용되고 있지 않은 프레임을 찾아 그것을 비워버린다. 그리고 페이지 테이블을 변화시킴으로써 프레임을 비어 있게 한다. 이 때 페이징 시스템은 두 가지 중요한 문제를 해결해야 한다. 그것은 프레임 할당 알고리즘과 페이지 교체 알고리즘이다. 즉 여러 프로세스가 존재하는 경우 얼마나 많은 프레임을 할당해야 할 지, 어떤 페이지를 교체해야 할 지를 결정해야 한다. 일반적으로 페이지 부재율이 가장 낮은 페이지 교체 알고리즘을 선정한다. 페이지 교체 알고리즘의 성능은 특정 메모리 참조 나열에 대해 알고리즘을 적용하여 페이지 부재 발생 횟수를 계산하여 평가한다. 이 때 메모리 주소의 나열을..
-
쓰기 시 복사운영체제/가상 메모리 2018. 2. 4. 20:35
가상 메모리는 프로세스 생성시 페이지를 공유하여 생성 시간을 줄일 수 있다.과거에 자식 프로세스가 생성될 때에는 부모 프로세스의 페이지를 자식프로세스에 복사해 주는 방식으로 자식 프로세스의 주소 공간을 구성해 주었다.하지만 대부분의 상황에서 자식 프로세스는 만들어지자마자 곧 exec 시스템 호출을 사용해 메모리 공간을 다른 프로그램으로 교체한다.그러면 부모로부터 복사해 온 페이지들은 다 쓸모 없게 된다. 그래서 부모의 페이지를 다 복사해오는 대신 쓰기 시 복사 방식이 사용된다. 쓰기 시 복사 방식은 자식 프로세스가 시작할 때 부모의 페이지를 당분간 함께 공유하여 사용하고 둘 중 한 프로세스가 공유중인 페이지에 쓸 때 페이지의 복사본이 생성된다. 이 방식을 사용할 경우 수정되는 페이지만 복사본을 만들어 효..
-
요구 페이징운영체제/가상 메모리 2018. 2. 4. 20:33
필요한 페이지만을 물리 메모리에 적재하는 것을 요구 페이징 이라고 한다.프로세스를 실행할 때 메모리에 전체 프로세스를 읽어오지 않고 필요한 페이지만 적재하는 게으른 스왑퍼를 사용한다. 기본 개념스왑 인시 페이저는 실제로 사용될 페이지들이 어떤 것인지 추측하고 실제 사용 될 페이지만 메모리로 가져온다.이로써 시간 낭비와 메모리 공간 낭비를 줄일 수 있다. 이를 위해서는 어느 페이지가 메모리에 올라와 있는지를 구별할 수 있어야 한다.따라서 약간의 하드웨어 지원을 필요로 한다. 유효 무효 비트 기법이 여기에 사용될 수 있는데 비트가 유효하다고 설정되면 해당 페이지가 메모리에 있다는 의미이고 무효하다고 설정되면 해당 페이지가 유효하지 않거나 디스크에만 존재한다는 것을 의미한다. 만약 프로세스가 메모리에 올라와 ..
-
배경운영체제/가상 메모리 2018. 2. 4. 20:01
프로세스를 실행할 때 동적 적재 방법을 사용하면 전체 프로세스를 메모리에 올려야 한다는 제약을 완화시키는데 도움이 된다. 프로그램을 일부분만 메모리에 올려놓고 실행 할 수 있을 때의 장점 프로그램은 물리 메모리 크기에 의해 더 이상 제약 받지 않게 된다. 더 많은 프로그램을 동시에 수행할 수 있게 된다. swap에 필요한 입 출력 횟수가 줄어들기 때문에 프로그램이 보다 빨리 실행된다. 가상 메모리는 실제의 물리 메모리 개념과 사용자의 논리 메모리 개념을 분리시켜 프로그램의 일부분만 메모리에 올려놓고 실행 가능하다. 프로세스의 가상 주소 공간은 그 프로세스가 메모리에 저장되는 논리적인 모습을 말한다. 가상 주소 공간은 특정 논리주소에서 시작되어 연속된 공간을 차지한다. 힙과 스택 사이 비어 있는 가상 주소..
-
페이징운영체제/메모리 관리 전략 2018. 2. 4. 17:55
페이징은 프로세스가 적재되는 물리 주소 공간이 연속적이지 않아도 적재를 허용한다는 이점을 가진 메모리 관리 기법이다.페이징은 세그먼테이션과 달리 외부 단편화를 방지하고 단편화에 따른 압축 작업이 필요 없다. 기본 방법물리 메모리는 프레임이라 불리는 같은 크기의 블록들로 분할되고논리 메모리는 페이지라고 불리는 같은 크기의 블록으로 분할된다.프로세스가 실행될 때 프로세스의 페이지는 보조 메모리로부터 주 메모리 프레임으로 적재된다. CPU에서 나오는 모든 주소는 페이지 번호와 페이지 변위의 두 개의 부분으로 나누어진다.페이지 번호는 페이지 테이블을 액세스 할 때 사용되며 페이지 테이블은 주 메모리에서의 페이지 주소를 가지고 있다.이 페이지 주소에 페이지 변위를 더하면 원하는 물리 주소가 된다. 페이징 기법을 ..