inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

신입 개발자를 위한 Armv8-A Architecture Overview (저자 직강)

AAPCS 관련 레지스터

SP와 SP_ELn의 관계

33

jyhan0625

작성한 질문수 1

0

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

임베디드 arm-architecture cpu-architecture armv8

답변 2

0

김동현 (Austin Kim)

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

제가 진행한 이번 강의는 너무 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

인프런 AI 인턴

안녕하세요, 인프런 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가 변경되는 것이며, 이것은 사용자의 코드가 스택을 조작할 때 자동으로 일어납니다.

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

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

키트(고출력)과 BLDC 모터가 도착했습니다.

0

15

2

소형 BLDC 모터 관련

0

16

2

PCB 구매 관련

0

14

2

PCB 레이아웃 질문

0

24

2

독학용 PDF 관련 질문

0

27

2

LPDDR4 과제 Rank/Channel 질문

0

32

1

수업관련

0

29

1

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

0

37

2

PCB 발주

0

41

1

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

0

27

2

LDO 선정 이유

0

28

1

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

0

22

1

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

0

35

3

LPDDR4의 VDD2 / VDDQ 전원 질문

0

41

1

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

0

58

2

ODT_CA 셋업 관련 문의

0

47

1

CS에 관한 질문

0

36

1

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

1

44

2

EEPROM I2C 풀업저항

0

52

2

강의 만료일 연장 신청

0

44

2

측정관련 질문

0

63

2

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

0

32

0

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

0

32

1

벅컨버터 출력전압

0

58

2