SP와 SP_ELn의 관계
33
1 câu hỏi đã được viết
SP와 SP_ELn의 관계에 대해 궁금해서 추가로 공부해보니, SP는 Exception Level에 대응되는 SP_ELn을 가리키는 alias(하드웨어적인 매핑) 이라고 합니다. 그럼 SP는 가리키기만 할 뿐, 실질적 존재는 SP_ELn 레지스터이니, SP_ELn이 업데이트 될 때 SP가 동시에 업데이트 된다는 설명이 부자연스럽다고 느꼈습니다. SP는 항상 별칭으로 가리키고 있을 뿐인 것이니.... 제 이해가 맞는 걸까요?
Câu trả lời 2
0
(늦게 답변을 드려서 죄송합니다.)
제가 진행한 이번 강의는 너무 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 인턴입니다. jyhan0625님.
Armv8-A 아키텍처에서의 SP와 SP_ELn의 관계를 잘 이해하시려는 모습이 인상 깊습니다. 질문하신 내용에 대해 설명드리겠습니다.
SP와 SP_ELn 관계 설명
SP는 별칭 역할:
- SP(스택 포인터)는 실제로 하드웨어 내부에서 특정 Exception Level의 스택 포인터 레지스터(SP_ELn)를 가리키는 별칭입니다. 즉, SP는 각각의 예외 레벨에서 SP_ELn 레지스터와 동기화된 상태로 작동합니다.
- SP(스택 포인터)는 실제로 하드웨어 내부에서 특정 Exception Level의 스택 포인터 레지스터(SP_ELn)를 가리키는 별칭입니다. 즉, SP는 각각의 예외 레벨에서 SP_ELn 레지스터와 동기화된 상태로 작동합니다.
SP_ELn 업데이트:
- SPSR_ELn 레지스터는 Exception Level n에 해당하는 스택 포인터 레지스터입니다. 예를 들어, EL0의 경우에는 SP_EL0이 사용되며, EL1에서는 SP_EL1이 사용됩니다.
- 따라서, 시스템이 특정 예외 레벨에서 동작할 때, 실제로 사용되는 것은 해당 예외 레벨의 SP_ELn이며, SP는 그 레지스터의별칭 역할을 합니다.
- SPSR_ELn 레지스터는 Exception Level n에 해당하는 스택 포인터 레지스터입니다. 예를 들어, EL0의 경우에는 SP_EL0이 사용되며, EL1에서는 SP_EL1이 사용됩니다.
업데이트 동작:
- SP가 업데이트된다는 것은 실제로 SP가 가리키고 있는 SP_ELn가 변경되는 것이며, 이것은 사용자의 코드가 스택을 조작할 때 자동으로 일어납니다.
- 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

