start_kernel - setup_arch - early_fixmap_init 함수 중에

이해되지 않는 부분이 있어 질문드립니다.

 

질문1

 

pgd = READ_ONCE(*pgdp);

 

v5.1의 코드에서는 위의 보이는 코드와 같이 pgdp로부터 pgd를 구할 때 READ_ONCE를 사용하고 있습니다

하지만 모기향 2판에 사용된 코드(p.162)에서는 READ_ONCE 사용해서 변수에 저장하는 대신

포인터 변수를 참조해서 그 값을 사용하고 있습니다.

아래의 링크를 통해 페이지 테이블의 엔트리에 접근하는 코드에 READ_ONCE를 추가하는 커밋을 찾을 수 있었지만

아직 그 내용을 이해하지 못했는데 왜 페이지 테이블의 엔트리에 접근할 때 READ_ONCE를 사용해야 하는 것 일까요?

https://github.com/torvalds/linux/commit/20a004e7b017cce282a46ac5d02c2b9c6b9bb1fa

 

질문2

 

    if (CONFIG_PGTABLE_LEVELS > 3 && 

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

        /*   

         * We only end up here if the kernel mapping and the fixmap

         * share the top level pgd entry, which should only happen on

         * 16k/4 levels configurations.

         */

        BUG_ON(!IS_ENABLED(CONFIG_ARM64_16K_PAGES));

        pudp = pud_offset_kimg(pgdp, addr);

    } else {

        if (pgd_none(pgd))

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

        pudp = fixmap_pud(addr);

    } 

 

위의 코드는 if 문의 조건에 따라

이미 만들어진 pgd 페이지 테이블로부터 또는

__pgd_populate_ 후 pudp를 구하고 있습니다

 

여기에서 if 문의 조건이 true이면

pgd 페이지 테이블이 이미 만들어진 것으로 판단하는 것으로 보입니다

 

그리고 if 문의 조건이 참이 되기 위해서는 아래의 2개가 모두 true이어야 하고

  • CONFIG_PGTABLE_LEVELS > 3
  • !(pgd_none(pgd) || pgd_page_paddr(pgd) == __pa_symbol(bm_pud))

 

이를 위해서는 아래의 2개가 모두 false이어야 하는데

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

 

이해가 되지 않는 부분은

pgd_page_paddr(pgd) == __pa_symbol(bm_pud) 에 대한 의미입니다

 

pgd_page_paddr(pgd) == __pa_symbol(bm_pud) 의 논리 연산의 결과가

false가 아니라 true가 되어야

pgd 페이지 테이블이 이미 만들어진 것으로 판단할 수 있을 것 같은데

어째서 그 반대인 것 일까요?

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22230
518 arm a53 아키텍처는 cache size를 configuration 할 수 없나요? [1] mnth 2023.12.03 264
517 리눅스 스케줄링에서 SCHED_FIFO에 대해 문의드립니다. [1] Neo2013 2023.02.09 798
516 러스트 언어나 리눅스커널+러스트 어떻게 생각하세요? 해볼만 할까요? [2] 김기오 2022.11.28 917
515 __no_granule_support에서의 wfe, wfi 중복 사용 [2] min 2022.10.03 172
514 TLBi operation 질문 [5] 컴퓨터 2022.09.18 397
513 Nested Interrupt on ARM64 [7] 아띨라 2022.07.24 672
512 ARM64 CPU Context Switch [2] 아띨라 2022.07.24 502
511 mmap후 파일 올리기 [3] 읏짜 2022.01.13 833
510 [질문-해결됨] compaction 후 기존 PTE 매핑에 뜬금 스왑 엔트리가 나와요! [12] 이파란 2021.05.17 1912
509 iamroot선배님들의 조언 부탁드립니다 [2] 이파란 2021.04.15 772
508 오드로이드에 관해 akqk13012 2021.03.26 444
507 critical section에 대한 커널 코드 검증 방법 문의 [7] file mnth 2021.01.09 1467
506 인터럽트 발생 관련해서 질문 드리고 싶습니다. [6] 코딩의노예 2020.07.07 944
505 RCU 관련해서 질문 하나 드려봅니다. [2] 코딩의노예 2020.07.03 652
504 멀티스레드 시간측정 질문 file 뇨뇸 2020.05.03 519
503 리눅스 소스 분석 관련 질문 [4] AlanWalker 2020.04.22 738
502 16기 리눅스 커널 스터디 39주차 질문입니다. [6] rnsscman 2020.03.22 720
501 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12846
500 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 357
499 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 316
XE Login