• 카테고리

    질문 & 답변
  • 세부 분야

    임베디드 · IoT

  • 해결 여부

    해결됨

테일 체이닝 관련 질문 드립니다.

23.03.28 08:58 작성 조회수 381

1

강사님. 강의 잘 보고 있습니다. 감사합니다.

테일체이닝 관련 실습 진행 중 질문이 생겨 글 남깁니다.

이번엔 질문이 좀 많습니다.

최대한 잘 정리해보도록 하겠습니다.

상황 - 테일 체이닝이 발생될거라 생각되는 지점에 Breakpoint를 걸었습니다.

먼저 예상되는 상황은 EXTI0_IRQHandler 함수가 호출되기 전 스크래치 레지스터[r0-r3]와 그 외 사용되는 레지스터들이 스택에 저장될 것이라 생각됩니다.

1. 1.EXTI0_IRQHandler 함수 호출 전의 어셈블리어를 볼 수 없어 이 부분도 사실인지는 잘 모르겠습니다.

 

여기서 if(SCB->ICSR & (1<<26) ) 가 참이라면, EXTI0_IRQHandler 동작이 끝난 후 SysTick_Handler가 실행될거라 예상이 됩니다.

2. 테일 체이닝이 없다면 EXTI0_IRQHandler가 끝나고 복귀가 이뤄질 때, 먼저 저장했던 r7과 lr값을 pop한 후

EXTI0_IRQHandler 호출 전 스택에 저장한 스크래치 및 그 외 레지스터들을 pop할 것으로 생각이 됩니다.

그 후에 SysTick_Handler가 호출이 될텐데... 호출 전에 레지스터들이 스택에 먼저 push될 것이고 {r7, lr}도 push될 것이라 생각이됩니다.

테일 체이닝은 레지스터 복원없이 바로 다음 인터럽트가 실행될 수 있다고 하셨습니다.

그렇다면 위 예제에서 EXTI0_IRQHandler 끝난 후 복원없이 SysTick_Handler가 실행된다는 말인데, 제 생각엔 {r7, lr}은 복원되어야하고, 그 외 레지스터들은 따로 복원없이 실행되어야할 것 같은데 맞나요?

 

3. EXTI0_IRQHandler 호출 전 사용되는 레지스터들이 스택에 push되는게 맞다면 그것을 disassembly 창같은 것으로 확인할 수 있는 방법이 있나요?

 

4. if (SCB->SHCSR & (1<<11))에서 SHCSR의 11번째 비트는 SYSTICKACT인데, 즉 SysTick 타이머 인터럽트 동작 중에 우선순위가 더 높은 EXTI0가 발생했고, 결과적으로 SysTick_Handler가 실행되다 중단되고EXTI0_IRQHandler가 실행하여 저 구문이 실행된 것으로 이해해도 될까요?

 

많은 질문을 드려 죄송합니다.

답변 1

답변을 작성해보세요.

0

김상현님의 프로필

김상현

질문자

2023.03.28

갑자기 드는 생각인데 혹시 스크래치 레지스터들은 r7이 가리키는 주소에 저장되나요? 만약 그렇다면 테일 체이닝에서 복원할 때 r7은 복원을 안하는지 궁금합니다.

안녕하세요. 김상현님!

제 강의를 열심히 시청해주시고 왕성하게 질문도 해주시는 김상현님을 항상 응원합니다 ^^
지금하셨던 다양한 질문의 답은 모두 영상속에 있습니다. 제가 확인해보니 아직 그 영상들을 시청하지 않으신 것으로 확인되는군요. 강의 s526_인터럽트 선점 부터 s532_익셉션 리턴 사례 분석 까지의 영상들을 시청하시면 스스로 답을 찾으실 것으로 예상합니다.