реклама на сайте
подробности

 
 
> Лишняя задержка перед каждой USB Bulk тразакцией
ValeraVi
сообщение Oct 14 2009, 13:27
Сообщение #1


Участник
*

Группа: Свой
Сообщений: 44
Регистрация: 30-07-05
Из: Kyiv, Ukraine
Пользователь №: 7 211



Может кто встречался с проблемой:
Есть USB full speed девайс с двумя bulk ендпоинтами (один на вход, другой на выход). Написана фирмвара, драйвера под линух и винду, все работает.
Для проверки работоспособности имеется простейшая апликуха, которая пишет 30 байт (это меньше wMaxPacketSize = 32) в девайс и сразу же вичитывает оттуда. Все это в цикле до бесконечности.
Но по хардварному анализатору видно, что виндовский драйвер перед каждой транзакцией делает задержки в 1 мс, т.е. булк пакет посылается (принимается) только в каждом 2-м микрофрейме, т.е. перед каждой транзакцией я в логе анализатора вижу 2 SOF.
При этом линуховый драйвер работает четко - задержек нет, перед каждой транзакцией по одному SOF, а в некоторых случаях умудряется даже в одном фрейме влепить по 2 транзакции (IN, потом OUT).
Девайс и к линуху и к винде подключается один и тот же. Компы с виндой и линухом - разные, но другой периферии кроме этого девайса не подключено. Испытывали на нескольких виндовых компах - все одно и тоже - видна шлет булк пакет только в каждом 2-м фрейме (не первом, не 3-м, не 4-м...).
Это какая-то особенность винды? Глюк моего драйвера виндовского? Писал его на базе примера из ДДК bulkusb. Может нужны какие-то хитрые настройки Дескрипторов usb девайса, которые для линуха подходят а для винды приводят к задержкам?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 12)
Alex11
сообщение Oct 14 2009, 19:17
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 106
Регистрация: 23-10-04
Из: С-Петербург
Пользователь №: 965



Давным давно мы боролись с подобным эффектом. Зависело только от железа на PC. Лучше всего себя вели родные интеловские чипсеты. Вообще, виндюки такой режим не любят совсем. Им бы в одну сторону кучу сразу - тогда получается более-менее быстро.
Go to the top of the page
 
+Quote Post
GetSmart
сообщение Oct 14 2009, 19:31
Сообщение #3


.
******

Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753



Скорее всего это опция в виндовом драйвере - отсылка пустого фрейма для индикации завершения данных. Встречал такую же опцию в функциях TMS320VC5509, работающих с USB. Там при инициализации транзакции нужно было передавать флаг USB_IOFLAG_NOSHORT и тогда фрейм с нулевой длиной не отсылался.


--------------------
Заблуждаться - Ваше законное право :-)
Go to the top of the page
 
+Quote Post
ValeraVi
сообщение Oct 15 2009, 11:09
Сообщение #4


Участник
*

Группа: Свой
Сообщений: 44
Регистрация: 30-07-05
Из: Kyiv, Ukraine
Пользователь №: 7 211



Спасибо за советы, буду что-то пробовать.
У меня сейчс фреймы с нулевой длиной не отправляются. Отправляются фреймы с меньшей чем wMaxPacketSize длиной чего по идее достаточно чтобы стек определил что данных больше не будет. У меня просто пустой фрейм получается перед каждым фреймом с булк пакетом.
Go to the top of the page
 
+Quote Post
Седой
сообщение Oct 16 2009, 15:04
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 244
Регистрация: 21-02-05
Из: Урал
Пользователь №: 2 806



Драйвер для Win на чистом DDK?
Go to the top of the page
 
+Quote Post
Alex11
сообщение Oct 16 2009, 17:41
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 2 106
Регистрация: 23-10-04
Из: С-Петербург
Пользователь №: 965



От этого ничего не зависит. Нижним уровнем и фреймами все равно занимается микрософтовский драйвер и обойти его правильно практически невозможно.
Go to the top of the page
 
+Quote Post
Седой
сообщение Oct 17 2009, 09:50
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 244
Регистрация: 21-02-05
Из: Урал
Пользователь №: 2 806



Цитата(Alex11 @ Oct 16 2009, 23:41) *
От этого ничего не зависит. Нижним уровнем и фреймами все равно занимается микрософтовский драйвер и обойти его правильно практически невозможно.

А зачем его обходить? И как?
А от формы отправки запросов к нему зависит очень многое.
Go to the top of the page
 
+Quote Post
ValeraVi
сообщение Oct 20 2009, 07:27
Сообщение #8


Участник
*

Группа: Свой
Сообщений: 44
Регистрация: 30-07-05
Из: Kyiv, Ukraine
Пользователь №: 7 211



да, драйвер на чистом DDK, за основу взят пример bulkusb (просто добавил свой код туда). Правда компилируется не make файлом от DDK а в vs2005 как проект (как описано тут)
Go to the top of the page
 
+Quote Post
Седой
сообщение Oct 23 2009, 16:24
Сообщение #9


Местный
***

Группа: Свой
Сообщений: 244
Регистрация: 21-02-05
Из: Урал
Пользователь №: 2 806



Цитата(ValeraVi @ Oct 20 2009, 13:27) *
да, драйвер на чистом DDK, за основу взят пример bulkusb (просто добавил свой код туда). ...


Если вы полностью повторили код, то могли заметить, что вывод в endpoint буферизован, и если количество байт данных превышает MAX transfer size , то из функции завершения вызывается запрос для отправки оставшихся данных и т.д.. Если вы из приложения вызовете Write c количеством данных больше, чем Max transfer size, то сможете посмотреть, есть ли "дыра" в передаче и каков ее размер. После этого можно будет сделать некоторые выводы.
Go to the top of the page
 
+Quote Post
galjoen
сообщение Oct 23 2009, 17:11
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 841
Регистрация: 10-05-07
Из: Чебоксары (Россия)
Пользователь №: 27 640



Я столкнулся с тем, что у HID обмен через контрольный канал может работать поразному. По описанию д.б. так: в случает посылки HID устройством NAK хосту, следующая попытка будет предпринята только в следующем кадре, т.е. через милисекунду. В реальности на некоторых мамках хабы работают не так. Они сразу же после получения NAK передачу(или приём) повторяют. Причём это явно не зависит от программы. Т.к. на ОДНОМ компьютере USB, установленные на матери, и в PCI (2 щт.) работают по разному. И возможны любые варианты. Причём замечено, что те, которые на чипсете VIA, как правило, стандарту не соответствуют.
Так я это к тому, что и у вас м.б. такая ситуация. Не в программе дело, а в аппаратуре.
Go to the top of the page
 
+Quote Post
misyachniy
сообщение Oct 26 2009, 15:13
Сообщение #11


Знающий
****

Группа: Свой
Сообщений: 716
Регистрация: 27-05-05
Из: Kyiv
Пользователь №: 5 454



Цитата(ValeraVi @ Oct 14 2009, 15:27) *
Но по хардварному анализатору видно, что виндовский драйвер перед каждой транзакцией делает задержки в 1 мс, т.е. булк пакет посылается (принимается) только в каждом 2-м микрофрейме, т.е. перед каждой транзакцией я в логе анализатора вижу 2 SOF.


USB хост обслуживается драйвером Windows.

Стандартно для FS секунда разбивается на 1000 фреймов.
Драйвер windows подстраивается под такое деление.
Раз в 1 миллисекунду, драйвер хоста (точнее планировщик задач для хоста) делит полосу пропускания USB между устройствами.
Таким образом в 1 фрейм планируется одна передача для устройства.
После передачи, планировщик получает задание на прием 30 байт и в следующий фрейм ставит задачу хосту получить 30 байт.
Таким образом, меньше чем в 2 фрейма ping-pong не получится.

Так что, по моему никакой проблемы в драйвере и устройстве нет.
Go to the top of the page
 
+Quote Post
Седой
сообщение Nov 9 2009, 18:57
Сообщение #12


Местный
***

Группа: Свой
Сообщений: 244
Регистрация: 21-02-05
Из: Урал
Пользователь №: 2 806



Цитата(misyachniy @ Oct 26 2009, 20:13) *
....
Таким образом в 1 фрейм планируется одна передача для устройства.
После передачи, планировщик получает задание на прием 30 байт и в следующий фрейм ставит задачу хосту получить 30 байт.
Таким образом, меньше чем в 2 фрейма ping-pong не получится.

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


Вы немного ошиблись - правильнее будет так: Таким образом в 1 фрейм планируется одна транзакция для 1-го endpoint.
Таким образом, если запрошено несколько endpoints для одного устройства, то транзакции могут идти и в одном фрейме.
Я уже здесь в форуме писал, как получить запрос - ответ в одном фрейме.
Go to the top of the page
 
+Quote Post
alex33
сообщение Feb 24 2012, 19:01
Сообщение #13





Группа: Участник
Сообщений: 11
Регистрация: 22-09-11
Пользователь №: 67 332



Если я правильно понял то одна транзакция (в интервале 1 мс) для одой конечной точки. Это соотвествует всем типам передач (bulk, изохорные, управление и прерывания) ?
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 20th July 2025 - 07:58
Рейтинг@Mail.ru


Страница сгенерированна за 0.01448 секунд с 7
ELECTRONIX ©2004-2016