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

Вниз

Отладка   Найти похожие ветки 

 
alex134 ©   (2003-04-10 22:26) [0]

Доброго дня всем. Вопрос такой:
я пишу простой отладчик под Win (стандартные средства) для собственных нужд. Как реализовать механизм установки breakpointа на выполнение команды с определенным адресом "X" ? Некоторые говорят поставить в отлаживаемой программе, int 3 перед командой с адресом X. Но возможно ли такое прокрутить, и при этом не затереть другую команду? Как в таких случаях поступают?


 
Мимоходович   (2003-04-10 22:41) [1]

...в таких случаях, как минимум, дизассемблируют...


 
Alex134 ©   (2003-04-10 22:52) [2]

...говорят, что дизассемблированый годится только для анализа - заново его скомпилировать не получится (


 
Мимоходович   (2003-04-10 23:02) [3]

...ну и что, дык вы же отладчик пишете, или всё-таки вирь?...


 
uw ©   (2003-04-10 23:13) [4]

На место первого байта команды, перед выполнением которой тебе надо остановиться (адрес X), пишешь однобайтную команду int. То, что было в X и сам адрес X, запоминаешь (таких X может быть и много). Когда программа достигнет этого адреса, управление будет передано соответствующему обработчику прерывания. В обработчике исследуешь адрес возврата, который находится на вершине стека. Он должен быть на 1 больше одного из твоих X. Исследуешь регистры, переменные и т. д. Восстанавливаешь содержимое X. Пускаешь дальше. Как сдвинуться с точки останова – не трудно сообразить, если подумать.



 
Alex134 ©   (2003-04-13 23:56) [5]

Адрес возврата после команды int указывает на следующую команду. Т.е. он будет x+1. Следовательно, чтобы попасть на команду с адресом x возвращатся надо на байт раньше? Переписать в стеке IP на адрес x (или декрементировать на 1), я правильно понял?


 
Alex134 ©   (2003-04-15 17:55) [6]

up


 
uw ©   (2003-04-17 15:27) [7]

Правильно!



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

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

Наверх




Память: 0.48 MB
Время: 0.018 c
14-12911
KAA
2003-04-16 18:58
2003.05.05
Более быстрая формулы вычисления квадратного корня


14-12942
Neo
2003-04-09 18:42
2003.05.05
Как написать взломщик энетрнета?


1-12696
salvo
2003-04-22 18:25
2003.05.05
StrToFloat


14-12919
lipskiy
2003-04-17 00:19
2003.05.05
32-битные иконки в стиле WinXP


9-12598
OlegL
2002-11-28 16:05
2003.05.05
Как отрезать кусок изображения