МЕНЮ


Фестивали и конкурсы
Семинары
Издания
О МОДНТ
Приглашения
Поздравляем

НАУЧНЫЕ РАБОТЫ


  • Инновационный менеджмент
  • Инвестиции
  • ИГП
  • Земельное право
  • Журналистика
  • Жилищное право
  • Радиоэлектроника
  • Психология
  • Программирование и комп-ры
  • Предпринимательство
  • Право
  • Политология
  • Полиграфия
  • Педагогика
  • Оккультизм и уфология
  • Начертательная геометрия
  • Бухучет управленчучет
  • Биология
  • Бизнес-план
  • Безопасность жизнедеятельности
  • Банковское дело
  • АХД экпред финансы предприятий
  • Аудит
  • Ветеринария
  • Валютные отношения
  • Бухгалтерский учет и аудит
  • Ботаника и сельское хозяйство
  • Биржевое дело
  • Банковское дело
  • Астрономия
  • Архитектура
  • Арбитражный процесс
  • Безопасность жизнедеятельности
  • Административное право
  • Авиация и космонавтика
  • Кулинария
  • Наука и техника
  • Криминология
  • Криминалистика
  • Косметология
  • Коммуникации и связь
  • Кибернетика
  • Исторические личности
  • Информатика
  • Инвестиции
  • по Зоология
  • Журналистика
  • Карта сайта
  • Резидентный обработчик клавиатуры (перехват нажатий клавиш и запись в файл)

    "снаружи", из другой программы, так как нет никаких способов определить,

    где именно его спрятала резидентная программа в процессе инициализации.

    Поэтому выгрузку резидентной программы легче осуществить из нее самой, чем

    из другой программы. Во-вторых, даже если выгрузку осуществляет сама

    резидентная программа, она может правильно восстановить старое содержимое

    вектора лишь в том случае, если этот вектор не был позже перехвачен другой

    резидентной программой. Если же это произошло, в таблице векторов находится

    уже адрес не выгружаемой, а следующей резидентной программы, и если

    восстановить старое содержимое вектора, эта следующая программа "повиснет",

    лишившись средств своего запуска. Поэтому надежно можно выгрузить только

    последнюю из загруженных резидентных программ.

    В нашей программе подфункция 00h прерывания 2Fh служит для проверки на

    повторную установку, а подфункция 01h - для выгрузки. В секцию

    инициализации добавлены строки сохранения старого содержимого вектора 09h.

    Это выполняется точно так же, как и для вектора 2Fh - с помощью функции DOS

    35h. Старый вектор сохраняется в ячейке old_09h, размещаемой в резидентной

    части программы. Поскольку выгрузка программы выполняется с помощью

    прерывания 2Fh, текст обработчика этого прерывания усложняется.

    Резидентный обработчик прерывания 2Fh прежде всего проверяет номер

    функции, поступивший в регистре АН, Если этот номер отличается от F1h,

    управление передается следующему обработчику по цепочке. Далее

    анализируется содержимое регистра AL. Если AL=00h, выполняются действия по

    защите от повторной загрузки. Если AL=01h, осуществляется переход на метку

    uninstall для выполнения действий по выгрузке программы. При любом другом

    номере подфункции управление передается следующему обработчику по цепочке.

    По метке uninstall осуществляется сохранение используемых далее регистров

    (что делается скорее для красоты, чем по необходимости) и функцией DOS 25h

    восстанавливается из ячеек old_09h и old_2Fh исходное содержимое

    соответствующих векторов. Далее из ячейки со смещением 2Ch относительно

    начала PSP в регистр ES загружается адрес окружения программы. Сегментный

    адрес освобождаемого блока памяти - единственный параметр, требуемый для

    выполнения функции DOS 49h. Размер освобождаемого блока DOS известен, он

    хранится в блоке управления памятью (МСВ). Далее освобождается блок памяти

    с самой программой. Сегментный адрес этого блока (адрес PSP) находится в

    регистре CS. Наконец, командой iret управление передастся в программу,

    вызвавшую прерывание 2Fh.

    Функция 49h оповещает DOS о том, что данный блок памяти свободен и может

    впредь использоваться DOS. Это, однако, не мешает выполняться завершающим

    строкам программы (в данном случае – команде iret), поскольку освобождение

    памяти не разрушает ее содержимого. Наша резидентная программа физически

    сотрется лишь после того, как в память будет загружена очередная

    выполняемая программа.

    Если программа запускается с клавиатуры с указанием каких-либо параметров

    (имен файлов, ключей, определяющих режим работы программы и проч.), то DOS,

    загрузив программу в память, помещает все символы, введенные после имени

    программы (так называемый хвост команды) в префикс программного сегмента

    программы, начиная с относительного адреса 80h. Хвост команды помещается в

    PSP во вполне определенном формате. В байт по адресу 80h DOS заносят число

    символов в хвосте команды (включая пробел, разделяющий на командной строке

    саму команду и ее хвост). Далее (начиная с байта по адресу 81h) следуют все

    символы, введенные с клавиатуры до нажатия клавиши . Завершается

    хвост колом возврата каретки (13).

    К данным секции инициализации добавилась строка с ожидаемым хвостом

    команды и байтовый флаг запроса на выгрузку.

    Поскольку действия программы при её запуске зависят от того, введена ли

    команда запуска с параметром или нет, наличие хвоста в PSP анализируется в

    самом начале секции инициализации. При запуске программы типа СОМ все

    сегментные регистры указывают на начало PSP. Байт с длиной хвоста

    (возможно, нулевой) помещается в регистр CL и сравнивается с нулем. Если в

    нем 0, команда запуска была введена без параметров и инициализация

    программы продолжается обычным образом. Если хвост имеет ненулевую длину,

    начинается его анализ.

    Обнулением регистра СН длина хвоста "расширяется" на весь регистр СХ, что

    нужно для организации цикла. Регистр DI настраивается на первый байт

    хвоста, а регистр SI – на начало поля tail с ожидаемой формой параметра.

    Регистр AL подготавливается для выполнения команды сканирования строки.

    Команда scasb сравнивает в цикле байты хвоста с содержимым AL (кодом

    пробела). Сравнение ведется до тех пор, пока не будет найден первый символ,

    отличный от пробела. Эта операция необходима из-за того, что оператор при

    вводе команды выгрузки может отделить параметр команды от самой команды

    любым числом пробелов, которые попадут в хвост команды в PSP и помешают

    анализировать введенный параметр.

    Выход из цикла выполнения команды scasb осуществляется, когда команда

    проанализировала первый после пробела символ. После этого регистр DI

    указывает на второй символ параметра. Команда dec DI корректирует указатель

    DI, направляя его на первый значащий символ введенного параметра. Далее

    командой сравнения строк cmpsb осуществляется сравнение трех оставшихся

    символов хвоста. Если символы совпадают с параметром 'off', записанным в

    программе, устанавливается флаг запроса на выгрузку. Если результат

    сравнения оказался отрицательным, флаг запроса не устанавливается (и,

    следовательно, неправильный параметр просто не воспринимается). В любой

    случае осуществляется переход на продолжение программы, начинающей

    проверять, не установлена ли уже эта программа в памяти. Если программа еще

    не установлена, введенный параметр не имеет смысла. Инициализация

    осуществляется обычным образом: сохраняются и устанавливаются векторы и

    программа завершается с оставлением в памяти.

    При наличии в памяти резидентной копии этой программы осуществляется

    переход на метку installed, где прежде всего проверяется, установлен ли

    флаг запроса на выгрузку. Если флаг сброшен, выводится сообщение о

    невозможности повторной загрузки и программа завершается с кодом возврата

    1. Если флаг запроса установлен, выполняется выгрузка программы, которая

    заключается в вызове мультиплексного прерывания 2Fh с функцией F1h и

    подфункцией 01h. Резидентный обработчик этого прерывания, включенный в

    состав нашей резидентной программы, отработает эту подфункцию, восстановит

    векторы и освободит занятые программой блоки памяти. После возврата

    управления из обработчика в текущую программу будет выведено сообщение об

    успешной выгрузке и программа будет завершена функцией 4Ch с нулевым кодом

    возврата.

    Составленная нами программа не избавлена от недостатков. Так, в ней

    анализируются всегда только 3 значащих символа хвоста. Таким образом,

    программа будет выгружена и при вводе команды (имя).com onset. Другой

    недостаток заключается в том, что результат сравнения записанного в

    программе хвоста с введенным с клавиатуры параметром будет положительным,

    только если с клавиатуры введены строчные буквы. Команда (имя) OFF не

    приведет к выгрузке программы. По-настоящему следовало включить в программу

    перед анализом хвоста преобразование символов параметра в прописные буквы.

    2.4. Перехват прерываний

    В архитектуре процессоров 80х86 предусмотрены особые случаи, когда

    процессор прекращает (прерывает) выполнение текущей программы и немедленно

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

    обработки подобной ситуации. Такие особые ситуации делятся на два тина:

    прерывания и исключения, в зависимости от того, вызвало ли эту ситуацию

    какое-нибудь внешнее устройство или выполняемая процессором команда.

    Исключения делятся далее на три типа: ошибки, ловушки и остановы, в

    зависимости от того, когда по отношению к вызвавшей их команде они

    происходят. Ошибки появляются перед выполнением команды, поэтому обработчик

    такого исключения получит в качестве адреса возврата адрес ошибочной

    команды (начиная с процессоров 80286). Ловушки происходят сразу после

    выполнения команды, так что обработчик получает в качестве адреса возврата

    адрес следующей команды. И наконец, остановы могут возникать в любой момент

    и вообще не предусматривать средств возврата управления в программу.

    Команда INT (а также INTO и INT3) используется в программах как раз для

    того, чтобы вызывать обработчики прерываний (или исключений). Фактически

    они являются исключениями ловушки, поскольку адрес возврата, который

    передастся обработчику, указывает на следующую команду, но так как эти

    команды были введены до разделения особых ситуаций на прерывания и

    исключения, их практически всегда называют командами вызова прерываний.

    Ввиду того, что обработчики прерываний и исключений в DOS обычно не

    различают механизм вызова, с помощью команды INT можно передавать

    управление, как на обработчики прерываний, так и исключений. Как показано в

    главе 4, программные прерывания, то есть передача управления при помощи

    команды INT, являются основным средством вызова процедур DOS и BIOS, потому

    что в отличие от вызова через команду CALL здесь не нужно знать адреса

    вызываемой процедуры - достаточно только номера. С другой стороны

    интерфейса рассмотрим, как строится обработчик программного прерывания.

    2.5. Обработчики прерываний

    Когда в реальном режиме выполняется команда INT, управление передается по

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

    прерываний, начинающегося в памяти по адресу 0000h:0000h. Каждый элемент

    такого массива представляет собой дальний адрес обработчика прерывания в

    формате сегмент:смещение или 4 нулевых байта, если обработчик не

    установлен. Команда INT помещает в стек регистр флагов и дальний адрес

    возврата, поэтому, чтобы завершить обработчик, надо выполнить команды popf

    и retf или одну команду iret, которая в реальном режиме полностью им

    аналогична.

    После того как обработчик написан, следующий шаг - привязка его к

    выбранному номеру прерывания. Это можно сделать, прямо записав его адрес в

    таблицу векторов прерываний.

    Хотя прямое изменение таблицы векторов прерываний и кажется достаточно

    удобным, все-таки это не лучший подход к установке обработчика прерывания,

    и пользоваться им следует только в исключительных случаях, например, внутри

    обработчиков прерываний. Для обычных программ DOS предоставляет две

    системные функции: 25h и 35h - установить и считать адрес обработчика

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

    Обычно обработчики прерываний применяют с целью обработки прерывания от

    внешних устройств или с целью обслуживания запросов других программ.

    2.6. Прерывания от внешних устройств

    Прерывания от внешних устройств или аппаратные прерывания, - это то, что

    понимается под термином «прерывание». Внешние устройства (клавиатура,

    дисковод, таймер, звуковая карта и т. д.) подают сигнал, по которому

    процессор прерывает выполнение программы и передает управление на

    обработчик прерывания. Всего на персональных компьютерах используется 15

    аппаратных прерываний, хотя теоретически возможности архитектуры позволяют

    довести их число до 64.

    - IRQ1 (INT 9) - прерывание клавиатуры, вызывается при каждом нажатии и

    отпускании клавиши на клавиатуре. Стандартный обработчик этого прерывания

    выполняет довольно много функций, начиная с перезагрузки по Ctrl-Alt-Del

    и заканчивая помещением кода клавиши в буфер клавиатуры BIOS.

    Самые полезные для программ аппаратные прерывания — прерывания системного

    таймера и клавиатуры. Так как стандартные обработчики этих прерываний

    выполняют множество функций, от которых зависит работа системы, их нельзя

    заменять полностью.

    прерванной программе. Этот способ применяют, если нужно, чтобы сначала

    отработал новый обработчик, а потом он передал управление старому

    Резидентные программы, перехватывающие аппаратные прерывания, обладают

    свойством выполнятся одновременно с какой-либо другой программой. Именно

    для этого и применяется механизм аппаратных прерываний - они позволяют

    процессору выполнять одну программу, в то время как отдельные программы

    следят за временем, считывают символы из клавиатуры и помещают их в буфер,

    получают и передают данные через последовательные и параллельные порты и

    даже обеспечивают многозадачность, переключая процессор между разными

    задачами по прерыванию системного таймера.

    Разумеется, обработка прерываний не должна занимать много времени: если

    прерывание происходит достаточно часто (например, прерывание

    последовательного порта может происходить 28 800 раз в секунду), его

    обработчик обязательно должен выполняться за более короткое время. Если,

    например, обработчик прерывания таймера будет выполняться 1/32,4 секунды,

    то есть половину времени между прерываниями, вся система станет работать в

    два раза медленнее. А если еще одна программа с таким же долгим

    обработчиком перехватит это прерывание, система остановится совсем. Именно

    поэтому обработчики прерываний принято писать исключительно на ассемблере.

    2.7. Резидентный обработчик прерываний от клавиатуры с подключением до

    системного обработчика

    Практически любая программа, в которой предусмотрено управление ходом ее

    выполнения с помощью команд, подаваемых с клавиатуры, имеет в своем составе

    обработчик прерываний от клавиатуры. В зависимости от стоящих перед ним

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

    кодов нажимаемых клавиш, или после системною, работая в этом случае с

    кодами ASCII. возникающими на выходе системного обработчика. Нередки

    случаи, когда прикладной обработчик выполняет часть своих функций до

    системного, а часть - после. Настоящая и несколько последующих статей

    посвящены этому важному для прикладного программиста вопросу.

    Для того чтобы написать, обработчик прерываний от клавиатуры, необходимо

    хорошо представлять, каким образом вводятся, куда попадают и как

    обрабатываются символы, вводимые с клавиатуры. Процесс взаимодействия

    системы с клавиатурой показан на рис. 2.3.

    IRQ INT

    Адрес системного

    Аппаратное Контроллер Микро-

    обработчика int09h

    прерывание прерываний Вектор09 процессор из вектора

    09

    на IRQ1

    IRQ7 Запуск систем

    Нажатие или обработчика int09h

    отпускание Байт флагов

    любой клавиши Системный

    клавиатуры

    Контроллер Порт 60h обработчик

    [40h:17h]

    клавиатуры Скэн-код int09h | 7 | 6| 5| 4|

    3| 2| 1| 0|

    Клавиатура

    Ins

    Скэн-код Код Caps Lock

    Кольцевой буфер ASCII Num

    Lock

    40h:1Eh ввода Scroll Lock

    40h:1Ah

    Alt

    Адрес головного Скэн ASCII Ctrl

    символа Скэн ASCII Shift левый

    Скэн ASCII Shift правый

    Программа Скэн ASCII

    пользователя Адрес хвостового

    ((( символа

    Запрос на ввод 40h:3Ch

    с клавиатуры Ввод самого

    “старого” символа

    Рис. 2.3. Процесс взаимодействия системы с клавиатурой.

    Работой клавиатуры управляет специальная электронная схема - контроллер

    клавиатуры. В его функции входит распознавание нажатой клавиши и помещение

    закрепленного за ней кода в свой выходной регистр (порт) с номером 60h. Код

    клавиши, поступающий в порт, называется скэн-кодом и является, по существу,

    порядковым номером кла-

    виши. При этом каждой клавише присвоены два скэн-кода, отличающиеся друг от

    друга на 80h. Один скэн-код (меньший, код нажатия) засылается контроллером

    в порт 60h при нажатии клавиши, другой (больший, код отпускания) - при ее

    отпускании.

    Скэн-код однозначно указывает на нажатую клавишу, однако, по нему нельзя

    определить, работает ли пользователь на нижнем или верхнем регистре. С

    другой стороны, скэн-коды присвоены всем клавишам клавиатуры, в том числе

    управляющим клавишам , , , и др. Таким

    образом, очевидно, что определение введенного символа должно включать в

    себя не только считывание скэн-кода нажатой клавиши, но и выяснение того,

    не были ли перед этим нажаты, например, клавиши (верхний регистр)

    или (фиксация верхнего регистра). Всем этим анализом занимается

    программа обработки прерываний от клавиатуры.

    Как нажатие, так и отпускание любой клавиши вызывает сигнал аппаратного

    Страницы: 1, 2, 3, 4


    Приглашения

    09.12.2013 - 16.12.2013

    Международный конкурс хореографического искусства в рамках Международного фестиваля искусств «РОЖДЕСТВЕНСКАЯ АНДОРРА»

    09.12.2013 - 16.12.2013

    Международный конкурс хорового искусства в АНДОРРЕ «РОЖДЕСТВЕНСКАЯ АНДОРРА»




    Copyright © 2012 г.
    При использовании материалов - ссылка на сайт обязательна.