Как реализован __RTC_CheckEsp? - PullRequest
       2

Как реализован __RTC_CheckEsp?

7 голосов
/ 12 октября 2010

__RTC_CheckEsp - это вызов, который проверяет правильность esp, стек, регистр. Он вызывается для гарантии того, что значение esp было сохранено при вызове функции.

Кто-нибудь знает, как это реализовано?

Ответы [ 2 ]

7 голосов
/ 12 октября 2010

Ну, немного осмотра ассемблера выдает

0044EE35  mov         esi,esp 
0044EE37  push        3039h 
0044EE3C  mov         ecx,dword ptr [ebp-18h] 
0044EE3F  add         ecx,70h 
0044EE42  mov         eax,dword ptr [ebp-18h] 
0044EE45  mov         edx,dword ptr [eax+70h] 
0044EE48  mov         eax,dword ptr [edx+0Ch] 
0044EE4B  call        eax  
0044EE4D  cmp         esi,esp 
0044EE4F  call        @ILT+6745(__RTC_CheckEsp) (42BA5Eh) 

На это нужно обратить внимание на две строки. Первое примечание в 0x44ee35 хранит текущее значение esp в esi.

Затем, после завершения вызова функции, он делает cmp между esp и esi. Теперь они оба должны быть одинаковыми. Если нет, то кто-то либо размотал стек дважды, либо не размотал его.

Функция _RTC_CheckEsp выглядит следующим образом:

_RTC_CheckEsp:
00475A60  jne         esperror (475A63h) 
00475A62  ret              
esperror:
00475A63  push        ebp  
00475A64  mov         ebp,esp 
00475A66  sub         esp,0 
00475A69  push        eax  
00475A6A  push        edx  
00475A6B  push        ebx  
00475A6C  push        esi  
00475A6D  push        edi  
00475A6E  mov         eax,dword ptr [ebp+4] 
00475A71  push        0    
00475A73  push        eax  
00475A74  call        _RTC_Failure (42C34Bh) 
00475A79  add         esp,8 
00475A7C  pop         edi  
00475A7D  pop         esi  
00475A7E  pop         ebx  
00475A7F  pop         edx  
00475A80  pop         eax  
00475A81  mov         esp,ebp 
00475A83  pop         ebp  
00475A84  ret              

Как видите, первое, что он проверяет, было ли результат предыдущего сравнения "не равным", то есть esi! = Esp. Если это так, то он переходит к коду ошибки. Если они одинаковы, то функция просто возвращает.

2 голосов
/ 12 октября 2010

Если вы хорошо разбираетесь в asm, возможно, это поможет:

jne (Прыжок, если не равно) - прыгает, если флаг ZERO равен NZ (NotZero)

_RTC_CheckEsp:
004C8690  jne         esperror (4C8693h) 
004C8692  ret              
esperror:
004C8693  push        ebp  
004C8694  mov         ebp,esp 
004C8696  sub         esp,0 
004C8699  push        eax  
004C869A  push        edx  
004C869B  push        ebx  
004C869C  push        esi  
004C869D  push        edi  
004C869E  mov         eax,dword ptr [ebp+4] 
004C86A1  push        0    
004C86A3  push        eax  
004C86A4  call        _RTC_Failure (4550F8h) 
004C86A9  add         esp,8 
004C86AC  pop         edi  
004C86AD  pop         esi  
004C86AE  pop         ebx  
004C86AF  pop         edx  
004C86B0  pop         eax  
004C86B1  mov         esp,ebp 
004C86B3  pop         ebp  
004C86B4  ret              
004C86B5  int         3    
004C86B6  int         3    
004C86B7  int         3    
004C86B8  int         3    
004C86B9  int         3    
004C86BA  int         3    
004C86BB  int         3    
004C86BC  int         3    
004C86BD  int         3    
004C86BE  int         3    
004C86BF  int         3   
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...