인프런 커뮤니티 질문&답변

madlife9161님의 프로필 이미지
madlife9161

작성한 질문수

FreeRTOS 프로그래밍

커널소스분석-태스크 스택메모리

섹션 5 <커널소스분석-태스크 스택메모리> 질문 드립니다!

작성

·

182

1

안녕하세요 강사님 :) 1:12 부근에서 "ARM은 메모리를 높은 주소부터 낮은 방향으로 쓴다" 고 말씀하셨는데, 이것은 리틀 엔디안 방식을 이용한다는 것을 의미하는 것일까요??

그리고 맞다면 인터넷에 검색해보니 ARM은 리틀 엔디안 or 빅 엔디안 중 선택해서 사용한다고 나와 있는 것을 봤는데 모든 ARM processor가 리틀 엔디안을 쓰는 것이 맞을까요..??

답변 1

0

홍영기님의 프로필 이미지
홍영기
지식공유자

안녕하세요. madlife9161님!

일반적으로, 프로그램의 데이터 영역(data segment)은 낮은 주소에서 시작하여 메모리의 상위 주소로 성장하고, 스택(stack segment)은 높은 주소에서 시작하여 낮은 주소로 성장합니다. 이를 전문 용어로 stack growth 라고 함. 이렇게 하면 두 영역이 중간에서 충돌할 가능성을 최소화하고, 필요에 따라 동적으로 확장할 수 있습니다.

초기 ARM 디자인에서 이렇게 스택을 사용하였고, 이후의 디자인에서도 이와 같은 방식을 계속 유지하고 있습니다. 하지만, 모든 CPU 아키텍처가 이와 같은 방식을 따르는 것은 아닙니다. 예를 들어, x86 아키텍처는 반대로 스택이 낮은 주소에서 높은 주소로 성장하는 "푸시 업" 방식을 사용합니다.

이 주제와 리틀엔디안, 빅엔디안과는 별개의 내용으로 보시면 됩니다.

제 강의 ARM Cortex-M 프로세서 프로그래밍에서 이 내용들을 다루고 있습니다. 참고해주세요.

 

madlife9161님의 프로필 이미지
madlife9161

작성한 질문수

질문하기