vm_area_struct와 mmap에 대해 질문입니다.
글쓴이: inwjivj / 작성시간: 수, 2012/07/04 - 1:39오후
리눅스 커널을 공부하는 학생입니다.
vm_area_struct는 가상 메모리의 구역을 나눠주는 구조체로 알고 있는데요.
어떤 책을 보니까 vm_area_struct는 프로세스의 text, data, stack, heap 영역등을 나눠준다고 들었는데요.
그럼 text영역당 vm_area_stuct가 하나, data영역당 vm_area_stuct 하나씩 등으로 만들어지는 건가요?
mmap 라는 명령어는 vm_area_struct를 만들어준다고 알고 있는데요. text, data, stack, heap 중에 어느 부분에서 생기는건가요? 상관이 없는건가요?
마지막으로 커널 영역도 vm_area_struct로 메모리 영역을 받는건가요?
Forums:
리눅스 화면조차 구경한 지 10년 넘어서 이 답변은
리눅스 화면조차 구경한 지 10년 넘어서 이 답변은 문제가 있을 수 있습니다.
모바일이라 타이핑하기 힘드니 한글로 의사소통만 해요.
메모리를 다음의 큰그림으로 그리면
1.실제물리메모리
2.cpu특성으로초기화된 페이지
3.사용자프로세서 하나하나의 거짓 메모리
vm_접두사가 붙었다는 것은 3 번을 관리하기 위한 것이란 말이고 이는 일반적으로 프로세서,커널내에서 메모리뿐만 아니라 이 하나의 프로세서에 대한 모든 것을 하나의 task_라는 접두사를 붙여 관리.
즉 커널이 응용을 관리하는게 task 이고 그 테스크 안에 메모리부분이 vm 이다...
직관적으로
ls 라는 명령어 파일은 실행파일안에 초기 메모리 모양을 그대로(?) 갖고 있다고 봐도 되는데 그 말은 ls 를 딱 치면 커널에 테스크가 하나 생기고 그 안에 vm 으로 이 메모리 모양이 들어오는데 여기까지는 ls안에 그려진 거짓주소이므로 이를 2 번 커널 메모리 빈자리로 밀어넣는 작업관리가 필요하고 이게 mmap_ 접두사,메모리 맵핑 으로 사용됨.
즉 ls도 pwd도 su도 메모리 4기가를 자기혼자 쓰는 것처럼 예를들어 1번지부터 10번지까지 코드...이렇게 그리게 되면 커널은 task 를 3개 만들고 각 테스크안에 메모리부분이 vm 으로 들어감.따라서 모든 프로그램이 똑같은 주소를 써도 커널 안에서는 task 로 갖혀 관리되고 실제 커널 메모리 IO 때는 mmap 관련 함수로 해결하니 문제가 없음...
커널 자체는 2번 위에서 움직이는 하나의 커다란 실행 이미지입니다.좀 크게 생각하면 커널도 코드.데이타.스텍 의 실행파일이 메모리에 통채로 올려진 응용이라 봐도 되는데 이런 그림에서 vm 은 실제 메모리와 일치함.
즉 다른말로 하면 ls 가 지혼자 4기가를 쓰는 것처럼 이미지를 그리듯 커널은 실제로 커널 지혼자 4기가를 쓰는 ls다...이래 봐도 된다는 말입니다. vm 이 없는...
대략 이런 그림에 대한 혼란이 있어보이는 질문입니다.
vm_area_struct
그럼 text영역당 vm_area_stuct가 하나, data영역당 vm_area_stuct 하나씩 등으로 만들어지는 건가요?
-> 네 하나씩 만들어 집니다. vm_area_struct는 가상 주소가 연속적이고 permission이 같은 한 덩어리의 가상영역을 표시하는 커널 자료구조 입니다.
mmap 라는 명령어는 vm_area_struct를 만들어준다고 알고 있는데요. text, data, stack, heap 중에 어느 부분에서 생기는건가요? 상관이 없는건가요?
-> stack, heap과 같은 mmap이라는 공간이 있습니다. mmap은 주로 stack과 heap 사이에 존재합니다.
마지막으로 커널 영역도 vm_area_struct로 메모리 영역을 받는건가요?
-> 네, vm_area_struct는 프로세스 주소 공간을 설명하는 자료 구조입니다. 프로세스가 사용하는 유저 영역과 커널 영역을 모두 합쳐서 프로세스 주소 공간이라고 합니다.
HelloWorld
댓글 달기