strlen 어셈블리 설명좀 부탁해요
아래와는 strlen 함수가 호출되는부분이 inline 으로 치환된것으로 예상되는 부분인데요
아래에서 cld 과 repnz scas 부분을 잘 모르겠습니다
구글링해보니 cld 를 하면 string 을 쓰는 주소증감방향이 바뀌는것이고
repnz 이건 scas 명령에 대해서 ecx 와 관련해서 반복을 하기위한것이고
scas 는 문자열을 스캔하는것이라는거까지 아는데
%es: 이게 왜 들어가야하는것이며
아래의 코드에 의해 어떻게 strlen 결과가 나오는것이고
cld 가 왜있어야하는지(주소 증감방향 지정이 왜필요한건지??)
모르겠네요
설명 부탁드립니다
일단 ebp-0x38 번지의 주소값이 어찌어찌해서 edi 로 들어가고
이게 구하고자하는 문자열의 시작주소 같습니다.
al 에 0 을 세팅한것은 널문자가 나타날때까지 길이를 구하려는것일까요?
근데 한가지 흥미로운게 strlen 함수가 널문자가 나타날때까지를
문자열의 길이로 하는줄 알았는데 널문자 뿐만아니라 0x0A 가 나타나도
거기까지를 길이로 세는거같더군요...
누가 자세한 설명좀 해주세요 ㅠㅠ
0x08048493 : lea -0x38(%ebp),%eax ; strlen inline 인듯
0x08048496 : mov $0xffffffff,%ecx
0x0804849b : mov %eax,-0x50(%ebp)
0x0804849e : mov $0x0,%al
0x080484a0 : cld
0x080484a1 : mov -0x50(%ebp),%edi
0x080484a4 : repnz scas %es:(%edi),%al
0x080484a6 : mov %ecx,%eax
0x080484a8 : not %eax
0x080484aa : dec %eax
0x080484ab : movzwl %ax,%eax ; 제로 익스텐션 4바이트로...
0x080484ae : dec %eax
여기 보면 설명이 잘
여기 보면 설명이 잘 나와있네요.
http://www.hackerschool.org/Sub_Html/HS_University/REVERSING/asem.html
고작 블로킹 하나, 고작 25점 중에 1점, 고작 부활동
"만약 그 순간이 온다면 그때가 네가 배구에 빠지는 순간이야"
댓글 달기