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 22231
498 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12846
497 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 357
496 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 316
» early_fixmap_init 질문 [3] file 에러 2019.12.17 288
494 16기 리눅스 커널 스터디 27주차 질문입니다. [1] daeroro 2019.12.18 800
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 716
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 261
485 16기 리눅스 커널 스터디 C조 16주차 질문입니다. [2] cien 2019.09.28 1152
484 early_fixmap_init 함수 질문 [2] 에러가왜안뜨지 2019.09.12 345
483 cgroup의 구조 및 학습 방법에대해 질문드립니다. file dfx 2019.08.25 256
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