early_fixmap_init 질문

에러 2019.12.17 22:52 조회 수 : 288

안녕하세요 

 

이전에 early_fixmap_init 함수에 init_mm -> pgd 테이블 이해가 되지 않아 질문 올립니다.

질문 1.

 

설명해주신 그림을 보면 pgd 메모리 영역은 fixmap 영역과 따로 분리 되어있습니다. 

 

early_fixmap_init-1a.png

 

 

하지만 early_fixmap_init 함수에 pgdp = pgd_offset_k(addr) 코드를 따라가 보면,

pgd_offset_k는 argument로 addr를 가지고 오고 addr은  FIXADDR_START로 가지고 옵니다.

따라서, pgdp = pgd_offset_k(addr);  

                  = FIXADDR_START + index 로 이해했습니다.

여기서 FIXADDR_START는 아래 그림과 같이 FIXMAP 영역 시작 주소로 나옵니다.

 

fixmap-6c.png

 

즉, pgd 와 fixmap 영역은 분리 된 영역이 아닌 같은 시작 주소로 이해 되었는데

아래 그림과 같이 이해해도 괜찮을까요??

early_fixmap_init_01.png

 

 

 

 

질문 2.

__pgd_populate의 3번째 인자(PMD_TYPE_TABLE) 가 이해 되지 않습니다.

위 그림에서 조금 소스를 조금 더 진행해 보았을 때 아래와 같은 그림으로 이해했습니다.  

 

early_fixmap_init_02.png

 

아래 소스를 실행해 보았을 때,

 

 

dbg_x1 = __pa_symbol(bm_pud);  // 0x4140e000

dbg_x1 = __pa_symbol(bm_pmd); // 0x4140d000

dbg_x1 = __pa_symbol(bm_pte);  // 0x4140c000

 

dbg_x1 = PMD_TYPE_TABLE;      // 0x03

dbg_x1 = PUD_TYPE_TABLE;      // 0x03

 

__pgd_populate(pgdp, __pa_symbol(bm_pud), 0x00);   // *pgdp = 0x4140e000

__pgd_populate(pgdp, __pa_symbol(bm_pud), 0x01);   // *pgdp = 0x4140e001

__pgd_populate(pgdp, __pa_symbol(bm_pud), PUD_TYPE_TABLE); //*pgdp = 0x4140e003

 

bm_pud, bm_pmd, bm_pte 는 __pa_symbol함수를 사용 하여 각각 물리 주소를 확인 할 수 있었습니다.

그런데 __pgd_populate를 실행 후 실제 *pgdp 값을 확인 해보니 bm_pud 물리주소가 들어가는 것이 아닌 마지막 인자 값만큼 더한 주소를 넣었습니다. 

 

실제 아래 커널 소스  실행 후

 

__pgd_populate(pgdp, __pa_symbol(bm_pud), PUD_TYPE_TABLE); 

*pgdp 값은  0x4140e003으로 찍히더군요. 단순히 배열의 index 값으로 생각 했었는데 index 값이면 배열 값마다 1byte 밖에 저장이 안된다는 것이니 아닌 것 같고...... pud_type_table이 무슨 용도로 사용되는지 궁금합니다.

 

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22228
517 alloc과 free함수에 대해서 질문입니다. [1] 정재훈 2011.06.28 93581
516 안드로이드 system 폴더안의 파일을 인식못하는데.. [5] 김영일 2011.04.14 69651
515 x86에서 ZONE_DMA 영역의 사용 [1] 홍문화 2011.05.02 58153
514 커널에서 page alloc에 관해서 [1] 미다리로23 2017.02.05 34542
513 디바이스 드라이버 모듈에서 작성한 함수를 커널에서 사용하는 방법 [1] 개짖는소리 2017.02.06 27018
512 Linux kernel의 CFS(Completely Fair Scheduling) 스케줄러에서 time slice 구하는 방법? [10] 김재호 2010.04.30 25210
511 "만들면서 배우는 OS..." 4장 kernel.asm 중 idtr 설정 질문드립니다 쿨쿨 2013.06.18 24937
510 리눅스 스케줄러 관련 [9] 홍문화 2011.02.23 22940
509 NFS NAS SAN 이란 무엇인가? file 박은병 2010.04.13 21877
508 s3c2440기반의 리눅스 커널 분석 중 MM관련 질문입니다. 유태경 2007.09.02 21522
507 /dev 폴더에 있는 node파일 중에서 어떤 것을 open해야 플래쉬를 사용할 수 있을까요? [1] 박종주 2012.02.17 19849
506 sparsemem에 대한 질문이 있습니다. [5] 안정모 2010.03.20 19717
505 16기 리눅스 커널 스터디 C조 18주차 질문입니다. [3] cien 2019.10.12 18796
504 tty, tty0, console, vc 는 각각 뭐하는 디바이스인지? [3] 이창만 2008.12.04 18547
503 ARM A8 이상의 프로세서를 공부할 때 스터디 방향 [4] 유강희 2011.06.15 18506
502 임베디드 OS 만들기 내용과 관련하여 문의드립니다. [5] 송인재 2010.03.25 18321
501 far call 이란 무엇인가요? [4] 박한범 2010.04.13 17840
500 파일시스템에 관한 질문(Htree [6] 사앙조 2017.05.22 17059
499 SMP관련 질문입니다. [2] 컴퓨터 2017.04.13 16580
XE Login