start_kernel - setup_arch - paging_init 공부 중에 잘 이해되지 않는 내용이 있어 질문드립니다.

 

  void __init paging_init(void)

  {

      pgd_t *pgdp = pgd_set_fixmap(__pa_symbol(swapper_pg_dir));                                                                                                                                            

 

      map_kernel(pgdp);

      map_mem(pgdp);

   

      pgd_clear_fixmap();

   

      cpu_replace_ttbr1(lm_alias(swapper_pg_dir));

      init_mm.pgd = swapper_pg_dir;

   

      memblock_free(__pa_symbol(init_pg_dir),

                __pa_symbol(init_pg_end) - __pa_symbol(init_pg_dir));

   

      memblock_allow_resize();

  }

 

위의 코드를 분석한 결과,

pgd_set_fixmap을 사용해서 fixmap을 통해 swapper_pg_dir에 접근할 수 있게 하고

map_kernel과 map_mem에서 swapper_pg_dir에 pud/pmd/pte 페이지 테이블과 물리주소를 매핑하고

init_mm.pgd를 swapper_pg_dir로 업데이트를 하는 것으로 이해했습니다.

(실제 스터디는 map_mem까지 진행해서 cpu_replace_ttbr1 아직 보지 않은 상태입니다)

 

그런데 각 페이지 테이블을 만든 후에 p*d_clear_fixmap을 호출하는데

함수를 따라가면 매핑할때와 동일한 ptep에 "0"을 write하고 있습니다.

 

처음에는 이 의미를 전혀 이해하지 못하다가

http://jake.dothome.co.kr/map64/ 페이지의 "paging_init() – ARM64" 단락에서

"코드 라인 8에서 fixmap 영역의 pgd 엔트리에 매핑한 pgd 테이블을 매핑 해제한다."를 보고

'fixmap에서swapper_pg_dir에 대한 매핑을 해제하는 것으로 받아들였습니다.'*

 

위 내용에서 아직 이해하지 못한 내용은,

우선 *에 대한 해석이 맞는지 입니다.

그리고 그 해석이 맞다면 어떻게 p*d_clear_fixmap가

만들어진 swapper_pg_dir에는 영향을 주지않고

fixmap에서 swapper_pg_dir에 대한 매핑을 해제하는게 가능한지 입니다.

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 709
507 인터럽트 발생 관련해서 질문 드리고 싶습니다. [3] 코딩의노예 2020.07.07 115
506 RCU 관련해서 질문 하나 드려봅니다. [2] 코딩의노예 2020.07.03 270
505 멀티스레드 시간측정 질문 file 뇨뇸 2020.05.03 175
504 리눅스 소스 분석 관련 질문 [4] AlanWalker 2020.04.22 365
» 16기 리눅스 커널 스터디 39주차 질문입니다. [6] rnsscman 2020.03.22 267
502 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 135
501 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 211
500 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 155
499 early_fixmap_init 질문 [3] file 에러 2019.12.17 130
498 16기 리눅스 커널 스터디 27주차 질문입니다. [1] daeroro 2019.12.18 146
497 커널 빌드시 최적화 관련 질문 [2] 김개미 2019.12.17 519
496 16기 리눅스 커널 스터디 25주차 질문입니다. [3] rnsscman 2019.12.03 200
495 16기 리눅스 커널 스터디 C조 23주차 질문입니다. [2] 이파란 2019.11.16 187
494 16기 리눅스 커널 스터디 C조 19주차 질문입니다. (두 번째) [2] rnsscman 2019.10.29 165
493 16기 리눅스 커널 스터디 C조 19주차 질문입니다. [2] 이파란 2019.10.19 178
492 asid 관련해서 질문드립니다. [3] suesueng 2019.10.21 150
491 16기 리눅스 커널 스터디 C조 18주차 질문입니다. [2] cien 2019.10.12 163
490 unflatten_dt_nodes 질문 [3] file 에러 2019.10.12 120
489 16기 리눅스 커널 스터디 C조 cpu_bit_bitmap 질문 [2] sjahn 2019.10.05 138
488 16기 리눅스 커널 스터디 C조 cgroup_init_early 부분 질문 [2] 이파란 2019.09.21 142
XE Login