ARM64 CPU Context Switch

아띨라 2022.07.24 13:02 조회 수 : 472

ARMv8 Linux Context Switch  대해서 공부하고 있습니다.

 

코드는 아래와 같습니다.

 

ENTRY(cpu_switch_to)
    mov    x10, #THREAD_CPU_CONTEXT
    add    x8, x0, x10
    mov    x9, sp
    stp    x19, x20, [x8], #16        // store callee-saved registers
    stp    x21, x22, [x8], #16
    stp    x23, x24, [x8], #16
    stp    x25, x26, [x8], #16
    stp    x27, x28, [x8], #16
    stp    x29, x9, [x8], #16
    str    lr, [x8]
    add    x8, x1, x10
    ldp    x19, x20, [x8], #16        // restore callee-saved registers
    ldp    x21, x22, [x8], #16
    ldp    x23, x24, [x8], #16
    ldp    x25, x26, [x8], #16
    ldp    x27, x28, [x8], #16
    ldp    x29, x9, [x8], #16
    ldr    lr, [x8]
    mov    sp, x9
    msr    sp_el0, x1
    ret
ENDPROC(cpu_switch_to)

 

질문 1,  Context Switch  시에 왜  Callee Register 하는 이유가 있을 까요?

PCS(Procedure Call Standard)나 ABI(Application Binary Interface) 등을 참고 하라는데 이해가 안되서요.

Task Context 라는 것이 어찌 보면 Sequence of function 이고, Callee Register 해도  Task Context 가 유지 되나요?

이전 ARM 에서는 R0 ~ R15 모두 했던 걸로 기억하는데요. 정확히 이해가 안됩니다.

 

질문 2,  PSTATE 는 왜 안하는지 모르겠어요.

 이전  ARM Core 에 비하여 Condition Flag를 관여하는 Instruction 이 적어진 것 알겠는데, 일부는 있던데요. 이런  Instruction 사이에 Context Switch 가 있어나면 어떻게 되는 것인가요? 

 

공부하는데 이해가 안되는 부분이어서 질문 남겨 봅니다. 의견 주시면 감사하겠습니다.

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22077
518 arm a53 아키텍처는 cache size를 configuration 할 수 없나요? [1] mnth 2023.12.03 211
517 Nested Interrupt on ARM64 [7] 아띨라 2022.07.24 634
516 러스트 언어나 리눅스커널+러스트 어떻게 생각하세요? 해볼만 할까요? [2] 김기오 2022.11.28 778
515 리눅스 스케줄링에서 SCHED_FIFO에 대해 문의드립니다. [1] Neo2013 2023.02.09 779
514 __no_granule_support에서의 wfe, wfi 중복 사용 [2] min 2022.10.03 161
513 TLBi operation 질문 [5] 컴퓨터 2022.09.18 382
» ARM64 CPU Context Switch [2] 아띨라 2022.07.24 472
511 vmcore 파일 생성방법 질문 드립니다. [2] sppedpower 2013.08.28 5264
510 인터럽트 발생 관련해서 질문 드리고 싶습니다. [6] 코딩의노예 2020.07.07 930
509 커널 빌드시 최적화 관련 질문 [5] 김개미 2019.12.17 1547
508 mmap후 파일 올리기 [3] 읏짜 2022.01.13 783
507 [질문-해결됨] compaction 후 기존 PTE 매핑에 뜬금 스왑 엔트리가 나와요! [12] 이파란 2021.05.17 1908
506 16기 리눅스 커널 스터디 C조 18주차 질문입니다. [3] cien 2019.10.12 18558
505 iamroot선배님들의 조언 부탁드립니다 [2] 이파란 2021.04.15 762
504 오드로이드에 관해 akqk13012 2021.03.26 443
503 critical section에 대한 커널 코드 검증 방법 문의 [7] file mnth 2021.01.09 1460
502 RCU 관련해서 질문 하나 드려봅니다. [2] 코딩의노예 2020.07.03 647
501 멀티스레드 시간측정 질문 file 뇨뇸 2020.05.03 510
500 리눅스 소스 분석 관련 질문 [4] AlanWalker 2020.04.22 730
499 16기 리눅스 커널 스터디 39주차 질문입니다. [6] rnsscman 2020.03.22 707
XE Login