ARM64 CPU Context Switch

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

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 22244
518 arm a53 아키텍처는 cache size를 configuration 할 수 없나요? [1] mnth 2023.12.03 274
517 리눅스 스케줄링에서 SCHED_FIFO에 대해 문의드립니다. [1] Neo2013 2023.02.09 800
516 러스트 언어나 리눅스커널+러스트 어떻게 생각하세요? 해볼만 할까요? [2] 김기오 2022.11.28 926
515 __no_granule_support에서의 wfe, wfi 중복 사용 [2] min 2022.10.03 175
514 TLBi operation 질문 [5] 컴퓨터 2022.09.18 399
513 Nested Interrupt on ARM64 [7] 아띨라 2022.07.24 677
» ARM64 CPU Context Switch [2] 아띨라 2022.07.24 506
511 mmap후 파일 올리기 [3] 읏짜 2022.01.13 842
510 [질문-해결됨] compaction 후 기존 PTE 매핑에 뜬금 스왑 엔트리가 나와요! [12] 이파란 2021.05.17 1912
509 iamroot선배님들의 조언 부탁드립니다 [2] 이파란 2021.04.15 774
508 오드로이드에 관해 akqk13012 2021.03.26 445
507 critical section에 대한 커널 코드 검증 방법 문의 [7] file mnth 2021.01.09 1468
506 인터럽트 발생 관련해서 질문 드리고 싶습니다. [6] 코딩의노예 2020.07.07 944
505 RCU 관련해서 질문 하나 드려봅니다. [2] 코딩의노예 2020.07.03 652
504 멀티스레드 시간측정 질문 file 뇨뇸 2020.05.03 521
503 리눅스 소스 분석 관련 질문 [4] AlanWalker 2020.04.22 739
502 16기 리눅스 커널 스터디 39주차 질문입니다. [6] rnsscman 2020.03.22 720
501 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12853
500 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 358
499 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 316
XE Login