Rechercher une page de manuel
mlock
Langue: ko
Version: 1995년 11월 26일 (fedora - 25/11/07)
Section: 2 (Appels système)
이름
mlock - 메모리의 일정 영역에 대한 페이징을 금지시킨다.사용법
#include <sys/mman.h> int mlock(const void *addr, size_t len);
설명
mlock은 addr부터 len 바이트 만큼의 메모리에 대한 페이징을 금지시킨다. 지정된 메모리 범위의 일부를 포함하는 모든 페이지들은 mlock 시스템 콜이 성공했을 때 RAM에 상주하는 것이 보장된다. 그리고 이 페이지들은 munlock이나 munlockall에 의해 잠금이 풀릴 때까지 또는 프로세스가 종료할 때까지 또는 exec에 의해 다른 프로그램이 시작할 때까지 RAM에 상주하는 것이 보장된다. fork에 의한 자식 프로세스는 페이지 잠금을 상속받지 않는다.메모리 잠금은 주로 두 가지 경우에 응용된다: 실시간 알고리즘과 high-security 데이타 처리. 실시간 응용프로그램의 경우는 결정론적인 타이밍과 스케줄링 같은 것이 요구되는데, 이 때 페이징은 예상치 못한 프로그램 실행 지연을 야기하는 주요 원인이다. 또한 실시간 응용프로그램은 보통 sched_setscheduler로 실시간 스케쥴러를 사용한다. 암호 보안 소프트웨어는 데이터로 암호나 보안키 같은 중요 바이트를 처리한다. 페이징 결과, 이 데이터가 지속적인 스왑 저장 장치에 저장되며 보안 소프트웨어가 RAM에서 이 데이터를 지우고 끝난 후에도 오랫동안 외부에 노출될 수 있다.
메모리 잠근은 스택이 아니다. 즉, mlock이나 mlockall이 여러번 호출되어 여러번 잠겼던 페이지는 상응하는 범위에 대한 munlock이나 munlockall를 단 한번 호출하여 잠금을 풀 수 있다. 여러 위치나 여러 프로세스에 의해 잠겨진 페이지는 적어도 하나의 위치나 프로세스에 의해 잠겨져 있는 한 RAM에서 계속적으로 잠금이 유지된다.
mlock과 munlock를 이용할 수 있는 POSIX 시스템에서 _POSIX_MEMLOCK_RANGE는 <unistd.h>에 정의되어 있으며 <limits.h>에서 PAGESIZE는 페이지당 바이트 수를 가리킨다.
반환값
성공시, mlock은 0을 리턴한다. 에러시, -1이 리턴되며, errno는 적절한 값으로 설정된다. 그리고 해당 프로세스의 주소 공간의 잠금에 어떠한 변화도 일어나지 않는다.에러
- ENOMEM
- 지정된 주소의 일정 부분이 해당 프로세스 주소 공간의 페이지와 일치하지 않거나, 프로세스가 허용되는 잠금 페이지의 최대 수를 초과했다.
- EPERM
- 호출한 프로세스가 올바른 권한을 갖고 있지 않다. 단지 루트 프로세스에만 페이지의 잠금을 허용된다.
- EINVAL
- len이 양수가 아니다.
호환
POSIX.1b, SVr4. SVr4는 EAGAIN 에러 조건을 추가적으로 기술한다.관련 항목
munlock(2), mlockall(2), munlockall(2)역자
정강훈 <skyeyes@soback.kornet.net>, 2000년 5월 20일Contenus ©2006-2024 Benjamin Poulain
Design ©2006-2024 Maxime Vantorre