본문 바로가기

쓰기

원문:http://lab.aralgood.com/?mid=board_lecture&page=4&document_srl=2228

여기서 보면

함수 시작점에서는 [ESP+4] 로 얻어올 수 있는 인자였지만, 저 세 번의 푸쉬로 인해 [ESP + 10] 위치가 되었습니다.

이렇게 적혀있는데요 흠...
왜 함수 시작점에서는 ESP+4로 얻을 수 있었던거죠? 그리고 세번의 푸쉬로 인해 +10이 되는 이유가 잘 이해가 안되네요 이리 저리 찾아 봤는데 push같은경우에는 esp의 값이 4만큼 줄어들고 새로운 값이 들어간다고 했는데
10이 나오는 이유가 이해가 안되네요... 도와주세요~

그럼 즐거운 밤 보내시길...^^

ps2.2번째 강의에서 "이제 이 상태에서 대사 메모리에 다시 브포를 겁시다(브포: 브레이크 포인트 ㅡ,.ㅡ;;;)
이건 어느 대사에 브포를 거는건가요...?리턴에 브포 걸어두고 이것저것 건드려도 계속해서 리턴에만 머무르네요 강의로 보면 저 밑에있는 주소가 잡혀야하는데....

조회 수 :
3148
등록일 :
2010.01.05
00:12:53
엮인글 :
https://arallab.hided.net/31573/fb8/trackback
게시글 주소 :
https://arallab.hided.net/board_qna/31573

루시퍼

2010.01.05
16:40:30
어쩌다보니 ps2는 이해했습니다 .ㅎㅎ 저 첫번째 esp+4는 왜,,, 저렇게 나오는지가 이해가 안되네요.. ;;
흠... 그래도 순서대로 따라가니까 한글로 나오는거 보고 깜짝놀랬어요 ㅎㅎ

whoami

2010.01.05
16:56:31
네. 일단 ESP 는 Extended Stack Pointer 의 약자입니다. Extended 는 생각하실 것 없고..
Stack 이라는 것은 꼭 상자 쌓아놓는 것처럼 1,2,3번 상자를 쌓으면 3,2,1번 순으로 다시 찾아올
수 있는 구조를 말합니다 (3번 상자가 가장 위에 있으니 당연히 3번이 먼저 나오겠죠?)
이 때 쌓아놓는 명령어가 PUSH, 찾아오는 명령어가 POP 입니다. ESP 는 항상 가장 위의 상자를
가리키고(Point) 있는 표시입니다.

어쨌든. 어떤 함수를 호출 할 때 프로그램은 함수의 인자 (전해주는 값) 를 쭉 쌓아놓고
마지막으로 자기가 돌아갈 곳의 위치를 쌓아놓습니다. 그러니까..
[돌아갈 곳] - ESP+0
[인자 1] - ESP+4
[인자 2] - ESP+8

이런 식입니다. 그런데 위에 세개를 더 쌓았다는 말이니.. 당연히 ESP 에서부터 세어넣을 위치도
달라졌겠지요.

[ESI] - ESP+0
[EBX] - ESP+4
[ECX] - ESP+8
[돌아갈 곳] - ESP+C
[인자 1] - ESP+10
[인자 2] - ESP+14

왜 ESP+16 이 아니라 ESP+10 이냐면.. 보시다시피 저게 10진수가 아니라 16진수라서 그렇습니다.
(추천 수: 1 / 0)

루시퍼

2010.01.06
00:20:35
좋은 설명 감사합니다^^ 많은 도움이 되었어요~
List of Articles
주제 최종 글 댓글sort 조회 수
공지 아랄트랜스가 정상 동작하지 않는다면 꼭 읽어주세요. by Hide_D file 2020-05-14 14:28 ppqq 177 291716
AIR SE 관련질문 by 블카이다 file 2017-02-27 12:42 미래도 5 525
상대주소는 어떻게 하나요? by 안녕히히히후 2017-03-17 21:53 미래도 5 646
창각의 아테리얼 아랄트랜스 팅김현상 질문드립니다.. by 페이아 file 2017-04-14 22:44 미래도 5 1045
아랄트랜스 사용하면 가끔식 몇몇 받침 있는 문자들이 깨져 나오던게 원래 그런가요? by Karasu file 2018-01-29 21:56 Karasu 5 1595
프린세스 러버 글자겹침 해결 방법좀요... ㅜ by lllllllllll file 2021-01-10 01:27 lllllllllll 5 588
번역이 안됩니다. 머엉... by 쿄우키 file 2013-03-13 14:00 다크짱 6 26529
"J2KEngine.dll을 로드할 수 없습니다."라고 창이 띄네요.......빨리 해결해 주세요.. by 야채라면 file 2011-07-19 07:33 Office 2010 6 37458
바로가기 만들때 오류가 떠요; by J.A. file 2009-11-22 21:43 J.C 6 16091
아랄 트랜스 질문이요~~~ by 스노하라 2009-08-25 15:26 스노하라 6 10152
아랄 트랜스 0.3 가 안되요 도와주세요~ by 쿠리미유나 file 2009-12-24 16:36 쿠리미유나 6 9688
타유타마하는데 아랄 사용시 글자 꺠짐 by shellshocker file 2010-01-05 14:49 shellshocker 6 9800
으으 아랄이 안 먹힙니다. by NGW file 2012-10-26 20:45 NGW 6 1569
커스텀딕 버그... ( + 덤프텍스트 버그) by 프군 file 2012-11-25 13:38 EroGame 6 1104
카미도리 아랄 실행이 안됩니다 by 혼돈의신 file 2013-04-05 19:28 혼돈의신 6 997
바이너리패치 설정 바로가기로는 저장 안되나요? by NightSky 2013-05-04 20:23 대학 6 999
마도교각 ATS실행시 런타임에러와 스크립트에러 가뜹니다. by 마이블루머 file 2013-04-30 13:10 영웅의길 6 3215
란스 퀘스트 런타임 에러 문제.. by 아캉키 file 2013-06-05 19:10 토르 6 1000
올리디버거 질문 by 아이다 2013-07-27 05:37 아이다 6 1471
올리디버거 도움 바랍니다!! by 사라닝 file 2013-08-21 16:52 사라닝 6 275
디버깅으로 걸어볼려고 노력은했는데 by 옭옭 file 2013-09-11 17:10 비밀을준수하는자 6 186