• 카테고리

    질문 & 답변
  • 세부 분야

    게임 프로그래밍

  • 해결 여부

    미해결

23분 23초에 main함수내에서 크래시가 나는 부분에서 질문있습니다

22.09.18 13:10 작성 조회수 158

0

제가 이해한바로는

push 1

push 2

call MAX 를 하고

MAX 함수에서 pop rbp를 하기 전까지를 다음과 같다고 생각했습니다

여기서 pop이 막히는데요

22분 29초에 설명을 보면 pop을 하게 되면 이전 rbp로 돌아간다고 하셨는데 rsp는 RET을 가르키게 되고 rbp는 이전 bp값을 가르키는 걸로 말씀하셨더라구요 이게 그냥 pop이라는 instruction이 그렇게 하는걸로 이해하면 될까요?

그렇다면 pop은 무조건 rbp는 이전 bp값으로 돌아가고 rsp는 RET로 돌아가게 하는 것인가요?

 

답변 1

답변을 작성해보세요.

1

그건 아니고요.
pop XXX은 말 그대로 현재 esp가 가리키는 위치에 있는 데이터를
XXX에다 넣은 후, esp를 위로 올리는 (32비트:4 or 64비트:8) 역할을 합니다
.

image그런데 딱 마침 pop ebp를 하는 순간에
esp가 가리키는 위치에 있는 데이터가 [이전 ebp]이기 때문에,
ebp 레지스터에 [이전 ebp 값]이 들어가는 것이죠.

참고로 32비트 고전 환경에서는 push 1 push 2를 실행하지만
64비트 환경에서는 대부분 인자가 몇 없으면 그냥 rax 같은 레지스터에 넘기는 경우가 많습니다.
(but 인자가 많아지면 다시 push를 이용해 스택을 이용해야 합니다)