mprotect

Autres langues

Langue: ko

Version: 1997년 05월 31일 (fedora - 25/11/07)

Section: 2 (Appels système)

이름

mprotect - 메모리 영역에 대한 접근를 제어한다.

사용법

 #include <sys/mman.h>
 
 int mprotect(const void *addr, size_t len, int prot);
 

설명

mprotect는 메모리 영역에 대한 접근을 제어한다. 만일 그 영역을 보호하기 위해 접근이 허용되지 않는다면, 프로그램은 SIGSEGV를 받는다.

prot는 다음 값들의 비트 OR이다:

PROT_NONE
메모리를 접근할 수 없다.
PROT_READ
메모리를 읽을 수 있다.
PROT_WRITE
메모리를 쓸 수 있다.
PROT_EXEC
메모리에 실행 코드를 둘 수 있다.

새로 설정한 보호 모드는 기존의 보호 모드를 대체한다. 예를 들어, 이전에 메모리가 PROT_READ로 표시되어 있는데, mprotectprotPROT_WRITE로 호출된다면, 그 영역은 더 이상 읽기 전용이 아니다.

반환값

성공시, mprotect는 0을 리턴한다. 에러시, -1이 리턴되며, errno는 적당한 값으로 설정된다.

에러

EINVAL
addr가 유효한 포인터가 아니거나, 또는 PAGESIZE의 배수가 아니다.
EFAULT
메모리를 접근할 수 없다.
EACCES
메모리가 지정된 모드로 설정될 수 없다. 예를 들어, 읽기 전용 접근을 하도록 파일을 mmap(2) 했는데 mprotectPROT_WRITE를 요청할 때 발생한다.
ENOMEM
내부 커널 구조체를 할당할 수 없다.

예제

 #include <stdio.h>
 #include <stdlib.h>
 #include <errno.h>
 #include <sys/mman.h>
 
 #include <limits.h>    /* PAGESIZE 때문에 */
 #ifndef PAGESIZE
 #define PAGESIZE 4096
 #endif
 
 int
 main(void)
 {
     char *p;
     char c;
 
     /* 버퍼를 할당한다; 기본적으로 PROT_READ|PROT_WRITE
            보호 모드로 설정된다. */
     p = malloc(1024+PAGESIZE-1);
     if (!p) {
         perror("Couldn't malloc(1024)");
         exit(errno);
     }
 
         /* PAGESIZE의 배수가 되도록 정렬; 2의 제곱으로 가정한다. */
     p = (char *)(((int) p + PAGESIZE-1) & ~(PAGESIZE-1));
 
     c = p[666];         /* 읽기; ok */
     p[666] = 42;        /* 쓰기; ok */
 
         /* 버퍼를 읽기 전용으로 한다. */
     if (mprotect(p, 1024, PROT_READ)) {
         perror("Couldn't mprotect");
         exit(errno);
     }
 
     c = p[666];         /* 읽기; ok */
     p[666] = 42;        /* 쓰기; 프로그램은 SIGSEGV로 죽는다. */
 
     exit(0);
 }
 

호환

SVr4, POSIX.1b (공식적으로 POSIX.4). SVr4는 EAGAIN 에러 코드을 추가적으로 정의한다. SVr4 에러 조건은 리눅스와 정확히 대응되지는 않는다. POSIX.1b에서는 mprotectmmap(2)으로 확보한 메모리 영역에서만 사용될 수 있다고 말한다.

관련 항목

mmap(2)

역자

정강훈 <skyeyes@soback.kornet.net>, 2000년 5월 15일