TLBi operation 질문

컴퓨터 2022.09.18 21:32 조회 수 : 399

안녕하세요.

 

아래 코드에서 질문이 있어서 남겨봅니다.

 

SYM_FUNC_START(__cpu_setup)
    tlbi    vmalle1                // Invalidate local TLB
    dsb    nsh

 

"__create_page_tables()" 에서 idmap_pg_dir과 init_pg_dir을 생성하고 __cpu_setup을 통해 MMU를 enable하기 전에 TLB를 invalidate해주고 있는 코드입니다. 궁금한 점은:

 

* "tlbi vmalle1" 명령어는 local TLB, 즉 이 명령어를 실행하는 core에 대해서만 영향이 있다라고 해석 [1] 하였는데 그렇다면 이 invlidation은 TLB-l1에서만 invalidate해주는 것일까요? 만약 그렇다면 TLB-l2에는 아직 stale entry들이 존재할 수 있는데 그 부분은 나중 코드 어디서 해결해주고 있을까요?

 

* 만약 "tlbi vmalle1" 명령어가 TLB-l2의 entry들도 invalidate해주고 있다면 "tlbi vmalle1"와 "tlbi vmalle1is"의 차이가 무엇일까요?

 

 

[1] ARM DDI 0487F.c, ID072120, C5.5.73 TLBI VMALLE1, TLB Invalidate by VMID, All at stage 1, EL1

The invalidation applies to the PE that executes this System instruction.

 

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22245
517 alloc과 free함수에 대해서 질문입니다. [1] 정재훈 2011.06.28 93641
516 안드로이드 system 폴더안의 파일을 인식못하는데.. [5] 김영일 2011.04.14 69690
515 x86에서 ZONE_DMA 영역의 사용 [1] 홍문화 2011.05.02 58273
514 커널에서 page alloc에 관해서 [1] 미다리로23 2017.02.05 34574
513 디바이스 드라이버 모듈에서 작성한 함수를 커널에서 사용하는 방법 [1] 개짖는소리 2017.02.06 27040
512 Linux kernel의 CFS(Completely Fair Scheduling) 스케줄러에서 time slice 구하는 방법? [10] 김재호 2010.04.30 25222
511 "만들면서 배우는 OS..." 4장 kernel.asm 중 idtr 설정 질문드립니다 쿨쿨 2013.06.18 24954
510 리눅스 스케줄러 관련 [9] 홍문화 2011.02.23 22947
509 NFS NAS SAN 이란 무엇인가? file 박은병 2010.04.13 21880
508 s3c2440기반의 리눅스 커널 분석 중 MM관련 질문입니다. 유태경 2007.09.02 21523
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 18825
504 tty, tty0, console, vc 는 각각 뭐하는 디바이스인지? [3] 이창만 2008.12.04 18552
503 ARM A8 이상의 프로세서를 공부할 때 스터디 방향 [4] 유강희 2011.06.15 18515
502 임베디드 OS 만들기 내용과 관련하여 문의드립니다. [5] 송인재 2010.03.25 18321
501 far call 이란 무엇인가요? [4] 박한범 2010.04.13 17840
500 파일시스템에 관한 질문(Htree [6] 사앙조 2017.05.22 17069
499 SMP관련 질문입니다. [2] 컴퓨터 2017.04.13 16583
XE Login