inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Tổng quan về Kiến trúc Armv8-A dành cho lập trình viên mới (Tác giả trực tiếp giảng dạy)

Các thanh ghi AAPCS

SP와 SP_ELn의 관계

33

jyhan0625

1 câu hỏi đã được viết

0

SP와 SP_ELn의 관계에 대해 궁금해서 추가로 공부해보니, SP는 Exception Level에 대응되는 SP_ELn을 가리키는 alias(하드웨어적인 매핑) 이라고 합니다. 그럼 SP는 가리키기만 할 뿐, 실질적 존재는 SP_ELn 레지스터이니, SP_ELn이 업데이트 될 때 SP가 동시에 업데이트 된다는 설명이 부자연스럽다고 느꼈습니다. SP는 항상 별칭으로 가리키고 있을 뿐인 것이니.... 제 이해가 맞는 걸까요?

임베디드 arm-architecture cpu-architecture armv8

Câu trả lời 2

0

austinkim

(늦게 답변을 드려서 죄송합니다.)

제가 진행한 이번 강의는 너무 Arm 아키텍처 관점으로만 SPn와 SP를 설명드린 것 같습니다.

일반적으로 EL0이나 EL1, EL2 그리고 EL3에서는 소프트웨어 관점으로 바라보는 스택은 SP 레지스터로만 관리됩니다. 함수를 C 언어로 프로그램한 다음에 해당 코드를 어셈블리 명령어로 분석하면 SP 레지스터만 보일 뿐입니다.

예를 들어, 아래 코드를 보겠습니다.

NUX:FFFFFFC010B05F90|__smccc_workaround.:hint #0x10 ; #16

NUX:FFFFFFC010B05F94| sub sp,sp,#0x20 ; sp,sp,#32

'sub sp,sp,#0x20' 명령어는 실행되는 위 코드가 실행되는 익셉션 레벨에 따라

아래 레지스터가 함께 업데이트 됩니다

- EL0: sp, sp_el0

- EL1: sp, sp_el1

- EL2: sp, sp_el2

- EL3: sp, sp_el3

감사합니다.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. jyhan0625님.

Armv8-A 아키텍처에서의 SP와 SP_ELn의 관계를 잘 이해하시려는 모습이 인상 깊습니다. 질문하신 내용에 대해 설명드리겠습니다.

SP와 SP_ELn 관계 설명

  1. SP는 별칭 역할:

    • SP(스택 포인터)는 실제로 하드웨어 내부에서 특정 Exception Level의 스택 포인터 레지스터(SP_ELn)를 가리키는 별칭입니다. 즉, SP는 각각의 예외 레벨에서 SP_ELn 레지스터와 동기화된 상태로 작동합니다.
  2. SP_ELn 업데이트:

    • SPSR_ELn 레지스터는 Exception Level n에 해당하는 스택 포인터 레지스터입니다. 예를 들어, EL0의 경우에는 SP_EL0이 사용되며, EL1에서는 SP_EL1이 사용됩니다.
    • 따라서, 시스템이 특정 예외 레벨에서 동작할 때, 실제로 사용되는 것은 해당 예외 레벨의 SP_ELn이며, SP는 그 레지스터의별칭 역할을 합니다.
  3. 업데이트 동작:

    • SP가 업데이트된다는 것은 실제로 SP가 가리키고 있는 SP_ELn가 변경되는 것이며, 이것은 사용자의 코드가 스택을 조작할 때 자동으로 일어납니다.

관련하여 더 많은 정보를 확인하고 싶으시다면, 아래 유사한 질문에서 참고할 수 있는 정보를 찾아보실 수 있습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

PCB 레이아웃 질문

0

20

2

독학용 PDF 관련 질문

0

26

2

LPDDR4 과제 Rank/Channel 질문

0

29

1

수업관련

0

27

1

벅 컨버터 스위치 off 상태일 때 흐름

0

36

2

PCB 발주

0

36

1

32. MOSFET의 특성과 동작 영역 강의 내용 중 P=I^2R질문

0

25

2

LDO 선정 이유

0

26

1

안녕하세요. 계속 프로젝트를 해야지 하다가 결제하고 환경 설정 중입니다.

0

22

1

13강 프로젝트생성해보기 관련 질문

0

35

3

LPDDR4의 VDD2 / VDDQ 전원 질문

0

40

1

벅컨버터 사용 및 그라운드 분리

0

57

2

ODT_CA 셋업 관련 문의

0

47

1

CS에 관한 질문

0

36

1

[HDL 32장-2부] 참고 링크 관련

1

42

2

EEPROM I2C 풀업저항

0

51

2

강의 만료일 연장 신청

0

44

2

측정관련 질문

0

62

2

제조사측 문의시 대처하는 방법

0

32

0

직접 만들어 봐야 내 지식이 된다

0

32

1

벅컨버터 출력전압

0

57

2

난방실만들기.4 진행 중, m_state 값 초기화가 안됩니다..

0

42

2

[HDL 22장] F/F CE 관련 질문

1

49

2

아직 보드 5개가 있습니다 - 4월 3일

0

40

1