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

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Текущий IRP и запуск драйвера-фильтра  (Прочитано 10595 раз)
0 Пользователей и 4 Гостей смотрят эту тему.
sukhinin
Гость
« : 13-05-2008 07:36 » 

Написал драйвер-фильтр для клавиатуры (Windows). Возникла следующая проблема. После запуска драйвера первое событие клавиатуры проходит мимо. Как я понимаю, текущий IRP сидит где-то в IO Manager и ждет события, при этом ссылки на мой драйвер в его стеке просто нет.
Вопрос: Как можно удалить этот IRP? Никак не могу получить на него указатель. Может не там ищу и есть возможность включить мой драйвер в стек текущего IRP?
Помогите, пожалуйста.
Записан
Ochkarik
Модератор

ru
Offline Offline
Пол: Мужской

« Ответ #1 : 13-05-2008 07:41 » 

доброго!
сомневаюсь я что IRP может долго где то сидеть. - зачем ему?
хм... может IRP_MJ_FLUSH_BUFFERS  попробовать?

Записан

RTFM уже хоть раз наконец!  RTFM :[ ну или хотя бы STFW...
sukhinin
Гость
« Ответ #2 : 13-05-2008 08:08 » 

IRP именно сидит и ждет нажатия/отжатия кнопки. Система дает запрос на ввод. Формируется IRP, пробегает по всей цепочке драйверов. Каждый драйвет выставляет в IRP свой адрес Completion Routine. А моего драйвера в этот момент в цепочке еще нет. И событие IRP_MJ_FLUSH_BUFFERS просто пройдет мимо... Жаль
Непонятным является то, что при проходе всей цепочки драйверов до самого низа все DEVICE_OBJECT.CurrentIrp равны нулю. Из чего я и сделал вывод, что IRP околачивается где-то внутри IO Manager.
Это мой первый драйвер, поэтому не судите строго, если я, мягко говоря, чушь несу. Улыбаюсь
Записан
Ochkarik
Модератор

ru
Offline Offline
Пол: Мужской

« Ответ #3 : 13-05-2008 08:13 » 

минуточку... да  не может такого быть, помоему!?
IRP по идее формироваться должен ПОСЛЕ нажатия.
зачем его до нажатия незавершенным держать?
Записан

RTFM уже хоть раз наконец!  RTFM :[ ну или хотя бы STFW...
Ochkarik
Модератор

ru
Offline Offline
Пол: Мужской

« Ответ #4 : 13-05-2008 08:22 » 

аа... попробую сообразить. в драйвере клавиатуры есть буефер. драйвер, по прерываниям от клавы читает коды нажатых/отжатых клавишь и скидывает все это в свой буфер.
далее кто то, по MJ_READ из этого буфера все выгребает.
я правильно все представляю? /судя по kbdclass/

кстати вы к нему приатачились?

Записан

RTFM уже хоть раз наконец!  RTFM :[ ну или хотя бы STFW...
sukhinin
Гость
« Ответ #5 : 13-05-2008 08:27 » 

Все правильно. Вот только IRP_MJ_READ отправляется с опережением. И ждет когда появится что-либо для выгребания. А меня в момент отправки это IRP_MJ_READ еще нет. Соответственно в стеке IRP нет моей Completion Routine.
Со вторым событием уже все в порядке. Но для меня очень важно не пропустить ни ОДНОГО нажатия.
Записан
sukhinin
Гость
« Ответ #6 : 13-05-2008 08:37 » 

Извите, забыл про атач:
// ... //
NTSTATUS status = IoCreateDevice(pDriverObject,
              sizeof(DEVICE_EXTENSION),
              NULL,
              FILE_DEVICE_KEYBOARD,
              0,
              FALSE,
              &pHookDevice);
// ... //
NTSTATUS status = IoAttachDevice(pDeviceObject,
                                 &globals.deviceKeyboardUnicodeString,
                                 &pExtension->pKbdDevice);
То есть, атачусь к тому, что система считает драйвером клавиатуры верхнего уровни. Передо мной в цепочке находятся еще три драйвера.

Записан
sukhinin
Гость
« Ответ #7 : 13-05-2008 08:41 » new

Да, и вот еще имя устройства:
#define KEYBOARD_DEVICE_NAME L"\\Device\\KeyboardClass0"
Записан
Ochkarik
Модератор

ru
Offline Offline
Пол: Мужской

« Ответ #8 : 13-05-2008 09:21 » 

да, действительно, пардон, не дочитал)
"The IRP_MJ_READ request transfers zero or more KEYBOARD_INPUT_DATA structures from Kbdclass's internal data queue to the Win32 subsystem buffer. If there is no data in the data queue, a read request remains pending until it is completed or canceled." - последнее предложение.

значит надо его отменить: почему IRP_MJ_FLUSH_BUFFERS пройдет мимо?
он же по описанию как раз "IRP_MJ_FLUSH_BUFFER request flushes the Kbdclass input data queue" должен сбросить, соответственно и незавершенный IRP отменить?
и зависший IRP MJ_READ выйдет со статусом  "STATUS_CANCELLED - The request was canceled before the transfer actually took place. "
помоему так.
потому что? имено из этой очереди: "IRP_MJ_READ request transfers zero or more KEYBOARD_INPUT_DATA structures from Kbdclass's internal data _queue_"
« Последнее редактирование: 13-05-2008 09:23 от Ochkarik » Записан

RTFM уже хоть раз наконец!  RTFM :[ ну или хотя бы STFW...
sukhinin
Гость
« Ответ #9 : 13-05-2008 16:24 » 

Да, звучит убедительно. Полезу разбираться с параметрами для CcFlushCache. Но мне кажется, что все будет в порядке.
Большое спасибо за помощь!
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines