SERVICE_SYSTEM_START (1) – после начальной загрузки ОС. Применяется для драйверов, которые самостоятельно осуществляют поиск оборудования, но не используются загрузчиком системы (нумераторы).
SERVICE_AUTO_START (2) – автоматическая загрузка с помощью диспетчера управления сервисами (Service Control Manager). Применяется для драйверов, не поддерживающих Plug and Play.
SERVICE_DEMAND_START (3) – загрузка «по требованию» либо диспетчера Plug and Play при обнаружении устройства, либо диспетчера управления сервисами при поступлении от пользователя команды на загрузку.
SERVICE_DISABLED (4) – драйвер не загружается.
ErrorControl типа двойное слово
Определяет уровень контроля ошибок. Может принимать значения:
SERVICE_ERROR_IGNORE (0). В случае сбоя при загрузке драйвера игнорировать его и продолжить работу.
SERVICE_ERROR_NORMAL (1). В случае сбоя при загрузке драйвера продолжить работу, но выдать при этом соответствующее предупреждение.
SERVICE_ERROR_SEVERE (2). В случае сбоя при загрузке драйвера переключиться на последнюю конфигурацию, при которой работа системы происходила без ошибок.
SERVICE_ERROR_CRITICAL (3). Аналогично (2), но в случае повторного сбоя выдать «синий экран».
DisplayName типа строка ASCII
Экранное имя, отображаемое служебными приложениями на экране. Этот параметр не обязателен. При его отсутствии экранным именем считается имя подраздела.
ImagePath типа строка Unicode
Полный путь к файлу с драйвером на диске. Обычно это поле устанавливается в значение %windir%\system32\Drivers\DriverName.sys, где %windir% — папка, в которую установлена Windows, а DriverName — имя файла.
Для разрабатываемого драйвера создаётся раздел с именем kbd_filter с переменными ErrorControl (равна 1), Start (равна 3), Type (равна 1). Т.к. не указывается, где расположен исполняемый файл драйвера, этот файл должен быть скопирован в директорию \%SystemRoot%\System32\Drivers.
В разделе фильтров клавиатуры необходимо внести в переменную UpperFilters имя драйвера-фильтра.
После перезагрузки изменения вступят в силу и драйвер-фильтр начнет работу.
Функции установки и удаления драйвера реализованы в модуле installer, который входит в состав управляющего приложения.
3.3 Сборка программного обеспечения
Для сборки разработанного программного обеспечения необходима ОС Windows NT 5, установленная на компьютере звуковая карта Sound Blaster. Все разработанные компоненты разработанного программного обеспечения находятся в папке DriverControl.
Компиляция
Для того, чтобы скомпилировать драйвер, необходим установленный DDK для Windows NT 5. С помощью консольной утилиты build, входящей в состав DDK, необходимо войти в папку DriverControl\driver и ввести команду build. Произойдёт компиляция драйвера. Драйвер kbd_filter.sys окажется в папке DriverControl\driver\objchk_wnet_x86\i386.
Для того, чтобы скомпилировать управляющую программу, необходимо чтобы был установлен пакет разработки Microsoft Visual Studio .Net. Результатом компиляции является файл DriverControl.exe в папке DriverControl/Release.
Сборка проекта
Чтобы собрать проект (драйвер и управляющая программа) необходимо скопировать в любую папку файл DriverControl.exe, создать в этой папке другую папку driver и поместить в неё файл kbd_filter.sys.
Установка программного обеспечения
Для того, чтобы установить разработанное программное обеспечение на компьютере, необходимо запустить приложение DriverControl.exe. На вкладке «Установка драйвера» нажать на кнопку «Установить». Для того, чтобы изменения в системе вступили в силу, необходимо перезагрузить компьютер.
Установленный драйвер можно увидеть с помощью утилиты devicetree, входящей в состав DDK.
3.4 Использование библиотеки DirectKS
Библиотека DirectKS предоставляет функциональность для работы с интерфейсом Kernel Streaming в режиме пользователя. В исходном варианте DirectKS работает с устройствами, поддерживающими формат WAVE-данных. Задачей данной курсовой работы является работа с MIDI-устройствами. Поэтому в библиотеку были внесены изменения. Библиотека находится в файле DriverControl/directks. Все внесённые изменения описаны в Приложении (см пункт 6.2).
Библиотека DirectKS используется следующим образом:
CKsAudRenPin * OpenMidiPin()
{HRESULT hr;
CKsAudRenFilter * pFilter = NULL;
CKsAudRenPin * pPin = NULL;
CKsEnumFilters * pEnumerator = new CKsEnumFilters(&hr);
GUID aguidEnumCats[] = {STATIC_KSCATEGORY_AUDIO};
// Найти все фильтры категории STATIC_KSCATEGORY_AUDIO
// Создаст списки всех пинов этих фильтров
hr = pEnumerator->EnumFilters(eAudRen, aguidEnumCats, 1, TRUE, FALSE, TRUE);
if(SUCCEEDED(hr))
{// Перечислить все фильтры и пины, пока не будет найден
// пин нужного формата данных - формата MIDI
LISTPOS listPos = pEnumerator->m_listFilters.GetHeadPosition();
while(!pPin && pEnumerator->m_listFilters.GetNext(listPos, (CKsFilter**)&pFilter))
{pPin = pFilter->CreateRenderPin(FALSE);}}
delete pFilter;
return pPin;}
Если пин с нужным форматом данных обнаружен, то функция возвращает указатель на класс для работы с пином.
Для того чтобы получить HANDLE пина, нужно использовать свойство:
Pin->GetHandle()
3.5 Отправление запросов из приложения в драйвер
key_midi - модуль отправления запросов из приложения в драйвер, находится в папке driverio.
Этот модуль содержит таблицу соответствий позиции клавиши к паре (скан-код, флаг).
#define KEY_MIDI_FILE "C:\KeyMidi.dat"
В этом файле дублируется информация о музыкальных параметрах, назначенных для клавиш.
HRESULT KeyGetScanCode(OUT PUCHAR ScanCode, OUT PUCHAR Flag,
IN UCHAR Position);
По позиции клавиши определяется её скан-код и флаг.
HRESULT KeySaveNote(IN LPCTSTR FileName, IN UCHAR ScanCode,
IN UCHAR Flag, IN UCHAR Position,
IN UCHAR Channel, IN UCHAR Instrument, IN UCHAR Note,
IN UCHAR Used);
Сохраняет в файле FileName музыкальную информацию о клавише.
HRESULT KeyGetNote(IN LPCTSTR FileName,
OUT PUCHAR ScanCode, OUT PUCHAR Flag, IN UCHAR Position,
OUT PUCHAR Channel, OUT PUCHAR Instrument,
OUT PUCHAR Note);
По позиции клавиши получает из файла FileName её музыкальную информацию.
HRESULT KeyDriverSendNote(IN UCHAR ScanCode, IN UCHAR Flag,
IN UCHAR Position, IN UCHAR Channel,
IN UCHAR Instrument, IN UCHAR Note,
IN UCHAR Used);
Сохраняет в драйвере музыкальную информацию о клавише.
HRESULT KeyDriverSendAllNotes(IN LPCTSTR FileName);
Сохраняет в драйвере музыкальную информацию обо всех клавишах, музыкальная информация о которых сохранена в файле FileName.
HRESULT SharePinWithDriver(IN HANDLE Pin);
Отправляет в драйвер HANDLE открытого пина.
3.6 Описание интерфейса пользователя
Установка
Для того чтобы установить или удалить драйвер необходимо открыть программу DriverControl.exe. Выбрать вкладку «Установка драйвера». Кнопки «Установить» и «Удалить» означают установку или удаление драйвера из системы (рис. 3.1). Для того, чтобы изменения вступали в силу, необходимо перезагружать компьютер.
В случае, если на компьютере не найдены нужные аудиоустройства, будет выведено сообщение «Невозможно открыть MIDI-пин». В этом случае драйвер установить можно будет, но назначить ноты для клавиши будет нельзя.
Рис.3.1. Установка драйвер
Управление
Для того чтобы можно было управлять драйвером, нужно выбрать в программе DrivcrControl.exe вкладку «Назначение звука». Выбирая кнопку, которая соответствует клавиши клавиатуры, можно для неё назначить канал, инструмент и ноту. Можно предварительно проверить звучание ноты, а потом сохранить музыкальную информацию в драйвере. Информация будет продублирована в файле C:\KeyMidi.dat.
Рис.3.2. Управление драйвером
Автозагрузка
Во время перезагрузки операционной системы все значения переменных, сохранённых в памяти драйвера, теряются. Т.е. драйверу необходимо ждать пользовательское приложение, которое отправит ему объект пина и заново назначит ноты для клавиш.
Для этого было создано простое приложение, которое открывает пин, отправляет его в драйвер, отправляет в драйвер информацию обо всех музыкальных параметрах, созранённых в файле C:\KeyMidi.dat.
Проект этого приложения находится в папке DriverControl под названием DriverAutoloader. Скомпилированную программу DriverAutoloader.exe можно найти в папке DriverControl/Release. Эту программу по желанию можно сохранить в папке Startup, приложения из которой загружаются во время загрузки ОС Windows.
3.7 Тестирование программного обеспечения
Драйвер был протестирован с использованием стандартной тестирующей утилиты DriverVerifier пакета DDK. С его помощью были проведены следующие тесты:
Операции с пулами памяти
Корректность уровней IRQL, на которых выполняется код драйвера
Обнаружение взаимоблокировок
Нехватка ресурсов
Нетипичные запросы к драйверу
Все тесты прошли успешно. Память в системе распределялась правильно, ошибок с ней не возникало. На нехватку ресурсов драйвер реагировал корректно. Нетипичные запросы к драйверу не обрабатывались им.
После установки драйвера и назначения музыкальных параметров для клавиш работа драйвера продолжается без «синего экрана».
На компьютерах, где не установлены звуковые карты Sound Blaster клавиши не издают звуков, т.к. встроенные звуковые карты не поддерживают тех IOCTL-запросов, которые используются во время работы с объектом пина.
Тестирование происходило на ОС Windows XP и Windows Server 2003.
4. Заключение
Исследована структура драйверов Windows
Определено место драйвера в стеке драйверов и выбрана структура программного обеспечения, состоящего из двух частей:
- верхнего драйвера-фильтра клавиатуры
- программы, которая осуществляет настройку параметров музыкального озвучивания клавиш и управляет работой драйвера посредством IOCTL-запросов
Изучены механизмы:
- встраивания драйвера-фильтра в стек драйверов