Справочник функций

Ваш аккаунт

Войти через: 
Забыли пароль?
Регистрация
Информацию о новых материалах можно получать и без регистрации:

Почтовая рассылка

Подписчиков: -1
Последний выпуск: 19.06.2015

Глюки Usb

4.7K
16 марта 2006 года
kelz
42 / / 21.06.2004
Доброе Вам утро/день/вечер/пиво...
Проблема следующая: есть USB уcтройство, есть драйвер. есть кусок кода:

 
Код:
...
pIrp = BuildDeviceIoControlRequest(...., Event,&IoStatusBlock);
ntStatus = IoCallDriver(pExt->pTarget,pIrp);
if (ntStatus == STATUS_PENDING)
    KeWaitForSingleObject(&Event,Executive,KernelMode,FALSE,NULL);
...
... и все бы хорошо, если бы KeWaitForSingleObject в один прекрасный момент не начинал ожидать вечно. Т.е. работаем, работаем, работаем (от нескольких секунд до нескольких минут), данные передаются, принимаются, а потом бац - и "вечный вэйт". Вывести из ступора можно только выдернув шнурок из устройства. Почему так происходит? Кто виноват и что делать? Код выполняется на уровне IRQL равным PASSIVE_LEVEL, ОС - WinXP sp1 (на Win2k - работает подольше на пару-тройку минут, но результат тот-же). Передача идет в режиме Interrupt.
И еще, MSDN писал(а)(о):
Цитата:
KeWaitForSingleObject
...
If a NULL pointer is supplied for Timeout, the calling thread remains in a wait state until the Object is signaled.
A Timeout value of zero allows the testing of a set of wait conditions and for the conditional performance of any side effects if the wait can be immediately satisfied, as in the acquisition of a mutex.
Callers of KeWaitForSingleObject must be running at IRQL <= DISPATCH_LEVEL. However, if Timeout <> 0, the caller must be running at IRQL <= APC_LEVEL and in a nonarbitrary thread context.

Когда я указываю таймаут:

 
Код:
Timeout.QuadPart = -500000; // 50 ms
ntStatus = KeWaitForSingleObject(&Event,Executive,KerneMode, FALSE,&Timeout);
... то при его истечении я наблюдаю синий экран IRQL_NOT_LESS_OR_EQUAL. (В Win2k - DRIVER_IRQL_NOT_LESS_OR_EQUAL и ругань в адрес usbehci.sys) при этом сообщает, что была попытка чтения по адресу 0x00000008. У меня все указатели валидные, проверено не один десяток раз, да и какие здесь могут быть указатели в этих двух строчках. Страничную память не использую. Уровень IRQL всегда PASSIVE_LEVEL.
Если кто сталкивался, помогите плиз.
Заранее спасибо.
14K
16 марта 2006 года
DVA
16 / / 05.01.2006
Задай вопрос на
http://www.wasm.ru/forum
14K
16 марта 2006 года
DVA
16 / / 05.01.2006
Цитата:
Originally posted by DVA
Задай вопрос на
http://www.wasm.ru/forum



Sorry за рекламму...

Реклама на сайте | Обмен ссылками | Ссылки | Экспорт (RSS) | Контакты
Добавить статью | Добавить исходник | Добавить хостинг-провайдера | Добавить сайт в каталог