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

정승우님의 프로필 이미지

작성한 질문수

[C++과 언리얼로 만드는 MMORPG 게임 개발 시리즈] Part1: C++ 프로그래밍 입문

스택과 메모리 질문입니다.

21.10.13 17:12 작성

·

297

0

안녕하세요. 현재 강사님의 강의를 수강중인 학생입니다.
스택과 메모리강의를 방금 보았는데 이해가 안되는 부분이 있어 질문 남깁니다.
 
 
먼저 사진 1입니다.
 
사진 1은 강의대로 짠 코드를 f5를 눌러 디버그 했을때의 사진입니다.
현재 rsp는 0x60fe38이라고 나와있습니다.
 
질문1. 현재 0x60fe38에 들어있는 값은 의미가 있는 값인가요?
 
그 후 디버깅을 더 진행시켜봤습니다.
 
사진2 입니다.
 
 
사진 2는 MAX라는 함수를 실행시키기 전까지 (위에 push를 모두 실행하기까지) 디버깅을 진행한 사진입니다.
현재 0x60fe38이후 0x60fe30에 rax값이, 0x60fe28에 rbx, 0x60fe38에 5, 0x60fe38에 1이 잘 들어가 있는 것을 확인했습니다.
 
사진 3입니다.
 
 
문제의 사진 3입니다. 방금의 상황에서 f11키를 눌러 step into 해보았습니다.
그랬더니 rsp가 0x60fe18에서 0x60fe10으로 바뀌며 0x60fe10에 이상한 값이 들어있는것을 확인했습니다.
 
질문2 왜 rsp가 0x60fe18에서 0x60fe10으로 바뀐 건가요? (왜 stack이 한단계 더 쌓인건가요?)
 
질문3 사진 3에서 0x60fe10에 들어있는 값은 뭔가요?
 
질문4 사진으론 없지만 함수에서 빠져나가니 rsp가 0x60fe10에서 다시 0x60fe18로 바뀐것을 확인했습니다. 왜인가요..?
 
이해력이 부족하여 질문이 많습니다.. ㅠㅠ 죄송합니다.
 
 

답변 1

0

Rookiss님의 프로필 이미지
Rookiss
지식공유자

2021. 10. 14. 14:37

질문1. 현재 0x60fe38에 들어있는 값은 의미가 있는 값인가요?

큰 의미 없고 그냥 스택 주소입니다. 프로그램이 실행될 때마다 달라집니다.

질문2 왜 rsp가 0x60fe18에서 0x60fe10으로 바뀐 건가요? (왜 stack이 한단계 더 쌓인건가요?)
질문3 사진 3에서 0x60fe10에 들어있는 값은 뭔가요?

CALL 명령어는
- 함수 호출이 완료되면, 그 다음으로 실행할 코드의 주소를 스택에다 push하고
- 호출하는 함수 주소로 jump

하는 2가지 기능을 동시에 합니다.
그렇기 때문에 Call을 호출한 순간 사실상 push를 간접적으로 1번 해준 것이라
rsp가 -8이 되는 것이죠. (스택은 높은주소->낮은 주소 순서로 사용)
안에 들어가 있는 값은 쓰레기 값이 아니고 매우 중요한 값인데
헨젤과그레텔의 빵 부스러기처럼 돌아갈 곳을 스택에 기입하게 됩니다.

질문4 사진으론 없지만 함수에서 빠져나가니 rsp가 0x60fe10에서 다시 0x60fe18로 바뀐것을 확인했습니다. 왜인가요..?

call과 대칭적으로 ret를 하게 되면
현재 스택 rsp에 있는 (함수 호출이 복원되면 돌아갈 코드 주소)를 pop해서 rip 레지스터에 복원하고,
함수에 빠져나가면 rip를 이용해 다음 호출할 주소 코드를 실행하게 됩니다.
따라서 자연스럽게 rsp+8이 된 것입니다.