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 22170
517 alloc과 free함수에 대해서 질문입니다. [1] 정재훈 2011.06.28 93307
516 안드로이드 system 폴더안의 파일을 인식못하는데.. [5] 김영일 2011.04.14 69512
515 x86에서 ZONE_DMA 영역의 사용 [1] 홍문화 2011.05.02 57928
514 커널에서 page alloc에 관해서 [1] 미다리로23 2017.02.05 34415
513 디바이스 드라이버 모듈에서 작성한 함수를 커널에서 사용하는 방법 [1] 개짖는소리 2017.02.06 26941
512 Linux kernel의 CFS(Completely Fair Scheduling) 스케줄러에서 time slice 구하는 방법? [10] 김재호 2010.04.30 25186
511 "만들면서 배우는 OS..." 4장 kernel.asm 중 idtr 설정 질문드립니다 쿨쿨 2013.06.18 24883
510 리눅스 스케줄러 관련 [9] 홍문화 2011.02.23 22933
509 NFS NAS SAN 이란 무엇인가? file 박은병 2010.04.13 21873
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 18679
504 tty, tty0, console, vc 는 각각 뭐하는 디바이스인지? [3] 이창만 2008.12.04 18535
503 ARM A8 이상의 프로세서를 공부할 때 스터디 방향 [4] 유강희 2011.06.15 18488
502 임베디드 OS 만들기 내용과 관련하여 문의드립니다. [5] 송인재 2010.03.25 18317
501 far call 이란 무엇인가요? [4] 박한범 2010.04.13 17840
500 파일시스템에 관한 질문(Htree [6] 사앙조 2017.05.22 17032
499 SMP관련 질문입니다. [2] 컴퓨터 2017.04.13 16573
XE Login