early_fixmap_init 함수 질문

에러가왜안뜨지 2019.09.12 12:59 조회 수 : 345

안녕하세요

 

http://jake.dothome.co.kr/fixmap/#comment-217495

 

링크를 통해 early_fixmap_init 을 공부하던 중 이해가 되지 않는 부분이 있어 질문을 하게 되었습니다.

제가 이해 하기로는

 early_fixmap_init 함수에서

코드 라인 10~18번은 page table level 에 따른 변환 level을 처리하는 과정으로 이해 했습니다.

CONFIG_PGTABLE_LEVEL4 로 해석해보겠습니다.

 

10번 line에 if문 조건에 의해  CONFIG_PGTABLE_LEVEL 이 4일 경우  아래 함수를 실행하는데

pgd_none(pgd) || pgd_page_paddr(pgd) == __pa_symbol(bm_pud)

PUD TABLE 같은 경우는 이미 커널 이미지 용도로 활성화 되어있기 때문에 fixmap 시작 주소에 해당하는 pud 엔트리 포인터를 구합니다.

 그리고 나머지 page table들을 활성화(?) 시키기 위해 아래 함수를 실행 합니다.

 __pgd_populate(pgdp, __pa_symbol(bm_pud), PUD_TYPE_TABLE);     //pgd table ->pud table 로 populate

__pud_populate(pudp, __pa_symbol(bm_pmd), PMD_TYPE_TABLE);    //pud table -> pmd table로 populate

__pmd_populate(pmdp, __pa_symbol(bm_pte), PMD_TYPE_TABLE);    //pmd table ->pte table로 populate

 

최종적으로

init_mm -> pgd table -> pud_table -> pmd_table -> pte_table

와 같이 page table이 활성화 되는 것으로 알고 있습니다.

 

제가 이해하고 있는게 맞다고 가정하고

CONFIG_PGTABLE_LEVEL3으로 해석 하면

 

if (CONFIG_PGTABLE_LEVELS > 3 &&  // level3이므로 if문은 무조건 거짓이 됩니다.

따라서 아래 조건문은 실행 하지 않습니다.

!(pgd_none(pgd) || pgd_page_paddr(pgd) == __pa_symbol(bm_pud)))

 

실행하지 않는다는 근거는

disassembly로 보았을 때 조건에 따라 분기하는  명령어가 보여서 입니다.

   0xffff0000111261f8 <+44>:  cbz  x0, 0xffff000011126210 <early_fixmap_init+68>

   0xffff000011126204 <+56>:  cmp  x1, x0

   0xffff000011126208 <+60>:  b.eq  0xffff000011126240 <early_fixmap_init+116>  // b.none

 

즉 아래 그림처럼 3단계의 페이지 테이블을 사용하므로 중간 pud 테이블이 생략되는 과정으로 이해했습니다.

 

early_fixmap_init-1a.png

 

 

문제는 pud가 생략되면 pgd 테이블에서 pmd 테이블로  populate 하는 작업이 보이지 않는데

어떻게 그림처럼 pgd table->pmd table로 갈 수 있는지 궁금합니다.

다른 함수에 후처리를 해주는건가요? 아니면 제가 early_fixmap_init 함수를 잘못 이해하고 있는 건가요??

 

감사합니다.

 

 

 

 

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22240
498 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12850
497 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 357
496 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 316
495 early_fixmap_init 질문 [3] file 에러 2019.12.17 288
494 16기 리눅스 커널 스터디 27주차 질문입니다. [1] daeroro 2019.12.18 801
493 16기 리눅스 커널 스터디 25주차 질문입니다. [3] rnsscman 2019.12.03 367
492 16기 리눅스 커널 스터디 C조 23주차 질문입니다. [2] 이파란 2019.11.16 389
491 16기 리눅스 커널 스터디 C조 19주차 질문입니다. (두 번째) [2] rnsscman 2019.10.29 234
490 16기 리눅스 커널 스터디 C조 19주차 질문입니다. [2] 이파란 2019.10.19 400
489 asid 관련해서 질문드립니다. [3] suesueng 2019.10.21 717
488 unflatten_dt_nodes 질문 [3] file 에러 2019.10.12 214
487 16기 리눅스 커널 스터디 C조 cpu_bit_bitmap 질문 [2] sjahn 2019.10.05 244
486 16기 리눅스 커널 스터디 C조 cgroup_init_early 부분 질문 [2] 이파란 2019.09.21 262
485 16기 리눅스 커널 스터디 C조 16주차 질문입니다. [2] cien 2019.09.28 1158
» early_fixmap_init 함수 질문 [2] 에러가왜안뜨지 2019.09.12 345
483 cgroup의 구조 및 학습 방법에대해 질문드립니다. file dfx 2019.08.25 257
482 head.S의 compute_indices 관련 문의 드립니다 [3] cien 2019.07.30 292
481 system register 접근 관련 질문드립니다. [2] cien 2019.07.23 454
480 task를 죽이는 do_exit 함수의 동작 중 이해가 안되는 것이 있어 질문드립니다. [2] 코딩의노예 2019.07.10 534
479 __inval_dcache_area의 동작에 대해 질문드립니다. [2] dfx 2019.07.08 228
XE Login