asid 관련해서 질문드립니다.

suesueng 2019.10.21 11:20 조회 수 : 724

https://lore.kernel.org/patchwork/patch/852156/

 

리눅스에 반영된 cpu_do_switch_mm 시에 위 패치에 대해서 궁금한게 있는데요..

 

패치 내용중 일부는 아래와 같습니다

여기서 패치전 코드는 TTBR0에 해당 user task의 pgd +  asid를 넣어주고 있었는데

 

패치 후에는 TTBR1에만 asid를 넣어주고 있는것을 확인했습니다.

제가 생각하기에 TTBR0 과 TTBR1 레지스터 모두에 asid 를 넣어주어야 하지 않을까 싶은데요..

 

왜 asid 를 커널에만 사용하는건지... 아니면 제가 잘못 이해하고 있는건지 궁금합니다.

 

 

diff --git a/arch/arm64/mm/proc.S b/arch/arm64/mm/proc.S
index 877d42fb0df6..0bd7550b7230 100644
--- a/arch/arm64/mm/proc.S
+++ b/arch/arm64/mm/proc.S
@@ -139,9 +139,12 @@  ENDPROC(cpu_do_resume)
  */
 ENTRY(cpu_do_switch_mm)
 	pre_ttbr0_update_workaround x0, x2, x3
+	mrs	x2, ttbr1_el1
 	mmid	x1, x1				// get mm->context.id
-	bfi	x0, x1, #48, #16		// set the ASID
-	msr	ttbr0_el1, x0			// set TTBR0
+	bfi	x2, x1, #48, #16		// set the ASID
+	msr	ttbr1_el1, x2			// in TTBR1 (since TCR.A1 is set)
+	isb
+	msr	ttbr0_el1, x0			// now update TTBR0
 	isb
 	post_ttbr0_update_workaround
 	ret
@@ -225,7 +228,7 @@  ENTRY(__cpu_setup)
 	 * both user and kernel.
 	 */
 	ldr	x10, =TCR_TxSZ(VA_BITS) | TCR_CACHE_FLAGS | TCR_SMP_FLAGS | \
-			TCR_TG_FLAGS | TCR_ASID16 | TCR_TBI0
+			TCR_TG_FLAGS | TCR_ASID16 | TCR_TBI0 | TCR_A1
 	tcr_set_idmap_t0sz	x10, x9
 
 	/*
번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22257
518 arm a53 아키텍처는 cache size를 configuration 할 수 없나요? [1] mnth 2023.12.03 282
517 리눅스 스케줄링에서 SCHED_FIFO에 대해 문의드립니다. [1] Neo2013 2023.02.09 802
516 러스트 언어나 리눅스커널+러스트 어떻게 생각하세요? 해볼만 할까요? [2] 김기오 2022.11.28 934
515 __no_granule_support에서의 wfe, wfi 중복 사용 [2] min 2022.10.03 176
514 TLBi operation 질문 [5] 컴퓨터 2022.09.18 400
513 Nested Interrupt on ARM64 [7] 아띨라 2022.07.24 680
512 ARM64 CPU Context Switch [2] 아띨라 2022.07.24 510
511 mmap후 파일 올리기 [3] 읏짜 2022.01.13 855
510 [질문-해결됨] compaction 후 기존 PTE 매핑에 뜬금 스왑 엔트리가 나와요! [12] 이파란 2021.05.17 1914
509 iamroot선배님들의 조언 부탁드립니다 [2] 이파란 2021.04.15 776
508 오드로이드에 관해 akqk13012 2021.03.26 445
507 critical section에 대한 커널 코드 검증 방법 문의 [7] file mnth 2021.01.09 1470
506 인터럽트 발생 관련해서 질문 드리고 싶습니다. [6] 코딩의노예 2020.07.07 947
505 RCU 관련해서 질문 하나 드려봅니다. [2] 코딩의노예 2020.07.03 652
504 멀티스레드 시간측정 질문 file 뇨뇸 2020.05.03 524
503 리눅스 소스 분석 관련 질문 [4] AlanWalker 2020.04.22 742
502 16기 리눅스 커널 스터디 39주차 질문입니다. [6] rnsscman 2020.03.22 721
501 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12860
500 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 358
499 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 316
XE Login