Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Потрепаться";
Текущий архив: 2003.05.05;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.009 c
11-12684
tanddt
2002-07-18 15:54
2003.05.05
ComboBox - помогите начинающему


11-12680
Schummi
2002-07-21 07:12
2003.05.05
Опять про аналоги...


14-12869
Карлсон
2003-04-16 17:25
2003.05.05
экология


14-12893
Soft
2003-04-16 19:01
2003.05.05
Использование несколько цветов в тексте


1-12697
Zergling
2003-04-23 06:26
2003.05.05
Копия динамического массива





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский