Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Еще раз про синхронизацию и про корректную выгрузку драйвера  (Прочитано 5833 раз)
0 Пользователей и 1 Гость смотрят эту тему.
Noname
Гость
« : 27-06-2004 19:50 » 

Есть драйвер А.
Есть его драйвер фильтр F, который получается, что он на вершине стека.
Есть драйвер B, который присоединяется к стеку драйвера A, то есть он находится на вершине стека, то есть над драйвером F (при условии, конечно, что драйвер А уже загружен и на вершине стека) .
Все драйвера не являются драйверами файловой системы.
Приложение обращается к драйверу A, то есть отправлется IRP драйверу A.
Так как есть еще два драйвера на верху ( драйвер b, драйвер f и только потом
драйвер A) , то IRP сначала проходит "через" драйвер B, потом через драйвер A и только потом попадает к драйверу A.

Как корректно выгрузить драйвер F, чтобы не было разрыва цепочки, то есть чтобы после выгрузки драйвера F, стек драйверов состоял из драйвера B (который на верху) и драйвера A, то есть чтобы IRP идущий к драйверу A проходил через драйвер B и доходил до драйвера A ?

как-то же самое сделать, когда в стеке всего два драйвера, драйвер A, и над ним драйвер F ? Драйвера B нет.
Записан
SlavaI
Главный специалист

ru
Offline Offline

« Ответ #1 : 28-06-2004 07:33 » 

Цитата

Как корректно выгрузить драйвер F, чтобы не было разрыва цепочки, то есть чтобы после выгрузки драйвера F, стек драйверов состоял из драйвера B (который на верху) и драйвера A, то есть чтобы IRP идущий к драйверу A проходил через драйвер B и доходил до драйвера A ?


Корректно нельзя,
1)система при присоединении  DEVICE_OBJECT
 сохраняет указатель на нижележащий в закрытых структурах DEVICE_OBJECT, то есть указывать указатель там будет на отсутствующий объект.
2) Также надо будет править указатель AttachedDevice у нижележащего DEVICE_OBJECT.
3) Надо будет изменить StackCount у верних DEVICE_OBJECT(драйвер B), вычесть 1.
4)Надо убедится, что все запросы к F от B и из F к A завершены. Ни одного незавершенного запроса не должно быть на стеке, то есть B должен пендить все запросы в очередь и надо ждать завершения всех предыдущих запросов(не забывай про IoCompletion- там есть следы от драйвера F).

Все пункты, кроме 1 осуществимы, хотя и опасны так как желательно захватывать спин блокировки при изменении стека девайсов, а эти спин блокировки не экспортируются из ядра. Для осуществления пункта 1 надо или отсоединить девайс, а потом присоединить(небезопасная операция, если нет поддержки системы), или менять недокументированную структуру.
Записан
Anonymous
Гость
« Ответ #2 : 28-06-2004 12:14 » 

Цитата

4)Надо убедится, что все запросы к F от B и из F к A завершены. Ни одного незавершенного запроса не должно быть на стеке, то есть B должен пендить все запросы в очередь и надо ждать завершения всех предыдущих запросов(не забывай про IoCompletion- там есть следы от драйвера F).


Есть примеры этого ?
Цитата


или менять недокументированную структуру


О какой структуре речь ?
Записан
mad
Гость
« Ответ #3 : 28-06-2004 15:09 » 

DEVICE_OBJECT я думаю
Записан
SlavaI
Главный специалист

ru
Offline Offline

« Ответ #4 : 29-06-2004 09:28 » new

Цитата

Есть примеры этого ?


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

Цитата

О какой структуре речь ?


О DEVOBJ_EXTENSION на которую указывает поле DeviceObjectExtension у DEVICE_OBJECT, там находится указатель AttachedTo, указывающий на объект к которому присоединен данный DEVICE_OBJECT.
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines