Семантический анализ структуры EXE файла и дисассемблер (с примерами и исходниками), вирусология
Категория реферата: Рефераты по информатике, программированию
Теги реферата: бесплатные рефераты скачать бесплатно, товар реферат
Добавил(а) на сайт: Gorev.
Предыдущая страница реферата | 7 8 9 10 11 12 13 14 15 16 17 | Следующая страница реферата
ASCII-коррекция после сложения
|Схема команды: |shr операнд,кол-во_сдвигов |
Назначение: логический сдвиг операнда вправо.
Алгоритм работы:
. сдвиг всех битов операнда вправо на один разряд; при этом выдвигаемый справа бит становится значением флага переноса cf;
. одновременно слева в операнд вдвигается нулевой бит;
. указанные выше два действия повторяются количество раз, равное значению второго операнда.
Состояние флагов после выполнения команды:
Назначение: операция логического исключающего ИЛИ над двумя операндами
размерностью байт, слово или двойное слово.
Алгоритм работы:
. выполнить операцию логического исключающего ИЛИ над операндами: бит результата равен 1, если значения соответствующих битов операндов различны, в остальных случаях бит результата равен 0;
. записать результат сложения в приемник;
. установить флаги.
Состояние флагов после выполнения команды:
|00-01 |4D5A - подпись | Компоновщик устанавливает этот код |
| |компоновщика |для идентификации правильного |
| |(признак EXE |EXE-файла |
| |файла) | |
|02-03 |Длина последнего |Число байтов в последнем блоке |
| |блока |EXE-файла |
|04-05 |Длина файла в |Число 512 байтовых блоков EXE-файла, |
| |блоках по 512 байт|включая заголовок |
|06-07 |Количество |Число настраиваемых элементов |
| |элементов таблицы | |
| |настройки адресов | |
| |(Relocation table)| |
|08-09 |Длина заголовка в |Число 16-тибайтовых блоков |
| |параграфах |(параграфов) в заголовке, (необходимо |
| | |для локализации начала выполняемого |
| | |модуля, следующего после заголовка) |
|0A-0B |Минимальный объем |Минимальное число параграфов, которые |
| |памяти который |должны находится после загруженной |
| |надо выделить |программы |
| |после конца | |
| |программы ( в | |
| |параграфах) | |
|0C-0D |Максимальный объем|Переключатель загрузки в младшие или |
| |памяти... |старшие адреса. При компоновке |
| | |программист должен решить, должна ли |
| | |его программа загружаться для |
| | |выполнения в младшие адреса памяти или|
| | |в старшие. Обычным является загрузка в|
| | |младшие адреса. Значение шест.0000 |
| | |указывает на загрузку в старшие |
| | |адреса, а шест. FFFF - в младшие. Иные|
| | |значения определяют максимальное число|
| | |параграфов, которые должны находиться |
| | |после загруженной программы |
|0E-0F |Сегментный адрес |Относительный адрес сегмента стека в |
| |стека относительно|выполняемом модуле |
| |начала программы | |
| |(SS) | |
|10-11 |Значение SP при |Адрес, который загрузчик должен |
| |запуске |поместить в регистр SP перед передачей|
| | |управления в выполнимый модуль |
|12-13 |Контрольная сумма |Контрольная сумма - сумма всех слов в |
| |- результат |файле (без учета переполнений) |
| |сложения без |используется для проверки потери |
| |переноса всех слов|данных |
| |файла | |
|14-15 |Значение IP |Относительный адрес, который загрузчик|
| | |должен поместить в регистр IP до |
| | |передачи управления в выполняемый |
| | |модуль |
|16-17 |Значение CS |Относительный адрес кодового сегмента |
| | |в выполняемом модуле. Этот адрес |
| | |загрузчик заносит в регистр CS |
|18-19 |Адрес первого |Смещение первого настраиваемого |
| |элемента ТHА |элемента в файле. |
|1A-1B |Номер сегмента |Номер оверлейного фрагмента: нуль |
| |перекрытия |обозначает, что заго ловок относится к|
| | |резидентной части EXE-файла |
|1С |Номер сегмента |Таблица настройки, содержащая |
| |перекрытия |переменное число настраиваемых |
| | |элементов, соответствующее значению по|
| | |смещению 06 |
Конец формы
Заголовок имеет минимальный размер 512 байтов и может быть больше, если программа содержит большое число настраиваемых элементов. Позиция 06 в заголовке указывает число элементов в выполняемом модуле, нуждающихся в настройке. Каждый элемент настройки в таблице, начинающейся в позиции 1C заголовка, состоит из двухбайтовых величин смещений и двухбайтовых сегментных значений.
Система строит префикс программного сегмента следом за резидентной частью
COMMAND.COM (DOS), которая выполняет операцию загрузки. Затем COMMAND.COM
выполняет следующие действия:
- Считывает форматированную часть заголовка в память.
- Вычисляет размер выполнимого модуля (общий размер файла в позиции 04
минус размер заголовка в позиции 08) и загружает модуль в память с
начала сегмента.
- Считывает элементы таблицы настройки в рабочую область и прибавляет значения каждого элемента таблицы к началу сегмента (позиция OE).
- Устанавливает в регистрах SS и SP значения из заголовка и прибавляет адрес начала сегмента.
- Устанавливает в регистрах DS и ES сегментный адрес префикса программного сегмента.
- Устанавливает в регистре CS адрес PSP и прибавляет вели чину смещения в заголовке (позиция 16) к регистру CS.
Если сегмент кода непосредственно следует за PSP, то смещение в заголовке равно 256 (шест.100). Регистровая пара CS:IP содержит стартовый адрес в кодовом сегменте, т.е. начальный адрес программы.
После инициализации регистры CS и SS содержат правильные адреса, а регистр DS (и ES) должны быть установлены в программе для их собственных сегментов данных:
1. PUSH DS ;Занести адрес PSP в стек
2. SUB AX,AX ;Занести нулевое значение в стек
3. PUSH AX ; для обеспечения выхода из программы
4. MOV AX,datasegname ;Установка в регистре DX
5. MOV DS,AX ; адреса сегмента данных
При завершении программы команда RET заносит в регистр IP нулевое значение, которое было помещено в стек в начале выполнения программы. В регистровой паре CS:IP в этом случае получается адрес, который является адресом первого байта PSP, где расположена команда INT 20H. Когда эта команда будет выполнена, управление перейдет в DOS.
ПРИМЕР EXE-ПРОГРАММЫ
|Рассмотрим следующую таблицу компоновки|программы: |
|(MAP) | |
|Start Stop Length Name 00000H 0003AH |Class |
|003BH CSEG 00040H 0005AH 001BH DSEG |CODE |
|00060H 0007FH 0020H STACK |DATA |
|Program entry point at 0000:0000 |STACK |
Таблица MAP содержит относительные (не действительные) адреса каждого из трех сегментов. Символ H после каждого значения указывает на шестнадцатеричный формат. Заметим, что компоновщик может организовать эти сегменты в последовательности отличного от того, как они были закодированы в программе.
В соответствии с таблицей MAP кодовый сегмент CSEG находится по адресу
00000 - этот относительный адрес является началом выполняемого модуля.
Длина кодового сегмента составляет шест.003B байтов. Следующий сегмент по
имени DSEG начинается по адресу шест.00040 и имеет длину шест.001B. Адрес
шест.00040 является первым после CSEG адресом, выровненным на границу
параграфа (т.е. это значение кратно шест.10). Последний сегмент, STACK, начинается по адресу шест.00060 - первому после DSEG, адресу выровненному
на границу параграфа.
С помощью отладчика DEBUG нельзя проверить содержимое заголовка, так как
при загрузке программы для выполнения DOS замещает заголовок префиксом
программного сегмента. Однако, на рынке программного обеспечения имеются
различные сервисные утилиты (или можно написать собственную), которые
позволяют просматривать содержимое любого дискового сектора в
шестнадцатеричном формате. Заголовок для рассматриваемого примера программы
содержит следующую информацию (содержимое слов представлено в обратной
последовательности байтов).
00 Шест.4D5A.
02 Число байтов в последнем блоке: 5B00.
04 Число 512 байтовых блоков в файле, включая заголовок: 0200
Рекомендуем скачать другие рефераты по теме: реферат менеджмент, вопросы и ответы.
Предыдущая страница реферата | 7 8 9 10 11 12 13 14 15 16 17 | Следующая страница реферата