Главная страница
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.01 c
2-1283177453
Fr
2010-08-30 18:10
2010.11.28
Остановка потока


2-1283333735
istok
2010-09-01 13:35
2010.11.28
как лучше сделать Dashboard...


15-1282556497
vajo
2010-08-23 13:41
2010.11.28
Блок питания.


2-1283663438
Делфиец
2010-09-05 09:10
2010.11.28
Kак преобразовать путь программы


15-1282194037
php
2010-08-19 09:00
2010.11.28
php, странности с именем файла