inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

시스템 소프트웨어 개발을 위한 Arm 아키텍처의 구조와 원리 - 1부 저자 직강 (2024년 버전)

3.2.2.4 CPSR 레지스터와 SPSR 레지스터가 업데이트 되는 방식

3.2.2.4 모드 복귀 부분

155

jjjj

작성한 질문수 13

0

IRQ 모드에서 슈퍼바이저 모드로 복귀할 때의 SPSR_irq.M에 왜 다시 0x13을 넣어주는지 잘 모르겠습니다. 이미 해당 레지스터는 0x13으로 지정되어 있는데 SPSR_irq가 아니라 SPSR_svc.M에 CPSR.M을 넣고 오히려 CPSR.M을 0x13으로 변경해야하는 것이 아닌가요?

임베디드 arm-architecture microprocessors cortex-a

답변 2

0

최원식

작성자님이 맞는것 같습니다.

0

인프런 AI 인턴

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

ARM 아키텍처에서 모드시스템으로 작동할 때, 슈퍼바이저 모드와 같은 특정 모드에 진입하거나 복귀할 때 SPSR_irq와 같은 서브모드 상태 레지스터(SPSR)의 역할이 중요합니다.

질문에 대한 핵심 이해

  1. 모드 전환과 SPSR:

    • IRQ 모드와 슈퍼바이저 모드를 전환할 때, SPSR_irq는 그 전환 전에 시스템의 상태 정보를 보존합니다.
    • SPSR_irq.M0x13을 넣는 것은 슈퍼바이저 모드 (SVC)로의 복귀를 의미하며, 이는 기본적으로 하드웨어에서 이전에 복귀할 모드 정보를 저장하는 역할을 합니다.
  2. CPSR와의 관계:

    • 예외 처리 후 원래 모드로 정상 복귀하려면, CPSR.MSPSR_irq.M의 값으로 갱신해야 합니다.
    • SPSR_irq는 명령어 실행 전에 현재의 CPSR 정보(상태)를 저장하고, 복귀 시 이를 읽어 원래의 상태로 복원합니다.

참고할 수 있는 유사한 질문:

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

5장 Armv7 동작모드와 6장 Armv8 익셉션 레벨 차이

0

63

2

시스템 소프트웨어 직무 관련 질문드려요

0

90

2

책관련 질문드려요

0

87

2

4.2.1. 실습을 어떻게 진행하는것인가요?

0

74

2

3.2.1.4 실습과 관련한 질문

0

81

2

Arm Architecture 관련 공부

0

59

1

유저 모드 뱅크드 레지스터 질문입니다

0

65

2

Armv8의 Exception Level에서 질문이 있습니다.

0

159

2

5.4.3 실습에서 궁금한점이 있습니다.

0

146

2

리눅스 커널 동작 모드별 스택 포인터 초기화

0

168

2

TRACE32 사용 실습에서 RASPIAN KERNEL DEBUG

0

280

2

강의 내용 짤린건가요?

0

275

1

TRACE32 프로그램

0

349

1

[3.2.2.4] Exception 발생시 CPSR <-> SPSR의 동작 질문

0

267

1

강의 자료 관련 문의

0

268

1

강의자료

0

237

2

강의하신 강의자료

0

258

1

CMP 명령어 예제 중

0

298

1

MVN 명령어 사용이유 질문

0

357

1

MOVS 명령어 질문

0

321

2

여러 가지 질문

0

355

2

ADC, SBC 어셈블리 명령어(4.2.2.4강)

0

356

1

ARMv7 범용레지스터

0

441

1

강의록 문의사항

0

303

2