-
카테고리
-
세부 분야
임베디드 · IoT
-
해결 여부
미해결
MOVS 명령어 질문
23.12.23 18:09 작성 조회수 139
0
안녕하세요. "MOVS PC, LR" 명령어 수행시에 무조건 SVC모드로만 전환되는 것인지 아니면 다른 모드로도 전환될수 있는 것인지 궁금합니다.
시스템 소프트웨어 개발을 위한 Arm 아키텍처의 구조와 원리 - 1부 저자 직강
5.4.3 실습: 어보트 모드(데이터 어보트)에서 슈퍼바이저 모드 변경 실습 (TRACE32)
강의실 바로가기
답변을 작성해보세요.
0
0
김동현 (Austin Kim)
지식공유자2023.12.23
네, Supervisor(SVC) 모드 이외에 다른 동작 모드로 스위칭할 수 있습니다.
동작 모드를 바꾸는 동작은 다음과 같은데요;
1. SPSR_<mode> 레지스터의 M[4:0] 비트에 변경하려는 동작 모드의 비트값을 저장
2. LR(R14) 레지스터에 동작 모드가 변경되면서 분기할 주소를 업데이트
3. 'SUBS PC, LR, #4' 혹은 'MOVS PC, LR' 명령어를 실행
SPSR_<mode> 레지스터의 M[4:0] 비트에 변경하려는 동작 모드의 비트값을 저정하면 됩니다.
혹시 추가로 다른 궁금한 점이 있으면 질문 남겨주세요.
감사합니다.
답변 2