Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2010.11.28;
Скачать: CL | DM;

Вниз

Отладка процесса с точками останова   Найти похожие ветки 

 
Unknown user ©   (2009-05-08 12:46) [0]

Подскажите, пожалуйста как продолжить выполнение отлаживаемого потока после события EXCEPTION_BREAKPOINT. Пишу отладчик, вот код:


 BrkCnt := 0;
 //запоминаем инструкцию
 StartAddr := $401000 + FndLin.Offset;
 ReadProcessMemory(ProcInfo.hProcess, Pointer(StartAddr),
                             @OrigOp, SizeOf(OrigOp), BR);

 //записываем точку останова
 BrkPnt := $CC;
 WriteProcessMemory(ProcInfo.hProcess, Pointer(StartAddr),
                             @BrkPnt, SizeOf(BrkPnt), BW);

 repeat
   WaitForDebugEvent(Event, INFINITE);

   if (Event.dwDebugEventCode = EXCEPTION_DEBUG_EVENT) and
      (Event.Exception.ExceptionRecord.ExceptionCode = EXCEPTION_BREAKPOINT) then
begin
 Inc(BrkCnt);
 //пропускаем останов на первой исполняемой инструкции
 if BrkCnt > 1 then
 begin
   //останавливаемся в нужном месте
  ...
  //восстанавливаем инструкцию в точке останова
  WriteProcessMemory(ProcInfo.hProcess, Pointer(StartAddr),
                    @OrigOp, SizeOf(OrigOp), BW);
  //для надежности
  FlushInstructionCache(ProcInfo.hProcess, nil, 0);
 end;
end;

  //продолжаем выполнение
  ContinueDebugEvent(Event.dwProcessId, Event.dwThreadId, DBG_CONTINUE);

until False;


Останов происходит в нужном месте. Однако после восстановления измененной инструкции и запуска на дальнейшее выполнение сыпятся исключения (уже не EXCEPTION_BREAKPOINT).

Понимаю, что наверное, не выполнил всех необходимых действий после срабатывания breakpoint. Нужно ли изменять значения регистров процессора для запуска после breakpoint?


 
Rouse_ ©   (2009-05-08 13:59) [1]

EIP сдвинь на единицу назад, т.к. EXCEPTION_BREAKPOINT поднимается уже после выполнения INT 3


 
Unknown user ©   (2009-05-08 15:52) [2]

Большое спасибо, действительно EIP.



Страницы: 1 вся ветка

Текущий архив: 2010.11.28;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.009 c
2-1283843667
Илья К.
2010-09-07 11:14
2010.11.28
AV при использовании IBUpdateSQLW


2-1283783053
Hapastiks
2010-09-06 18:24
2010.11.28
ini файлы


15-1281994189
Юрий
2010-08-17 01:29
2010.11.28
С днем рождения ! 17 августа 2010 вторник


2-1284058496
set
2010-09-09 22:54
2010.11.28
клякса


2-1283687760
rrr888
2010-09-05 15:56
2010.11.28
TWebBrowser. Как извлечь массив из кода страницы