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

 
 
> USB Host STM32F4, Как правильно принимать пакеты длиннее размера endpoint
uriy
сообщение Feb 15 2017, 08:31
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 429
Регистрация: 30-11-05
Из: Ижевск
Пользователь №: 11 606



Пишу USB хост для работы с чистымии булками.
Решил делать на HAL, без CubeMX у меня бы ушло на хост очень много времени.
Устройство USB клиент имеет по одному IN и OUT endpoint по 64 байта.
Обмен уже налажен но есть нюансы.
Многие пакеты верхнего протокола имеют длину больше 64 байт.
Функция передачи из хоста к клиенту USBH_DMR_Transmit дробит посылку как надо на пакеты размером не более 64 байт.

Функция приема USBH_DMR_Receive никогда не возращает массив более 64 байт.
Если я вызываю USBH_DMR_Receive несколько раз то корректно получаю весь длинный пакет сформированный из пачек по 64 байта.
В первом пакете в протоколе верхнего уровня есть длина посылки. Анализируя ее я могу посчитать сколько раз вызывать USBH_DMR_Receive. И раньше я не встречал упоминаний о том что по USB передается длина посылки.
На сколько знаю признаком конца посылки является пакет длиной менее размера endpoint.

Есть ли способ узнать сколько байт послал клиент? USB хост пишу впервые. Еще многое не понятно.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
controller_m30
сообщение Feb 15 2017, 18:30
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 356
Регистрация: 24-02-09
Пользователь №: 45 309



1. По USB такая информация не передаётся. Контроллер знает только длину принимаемых пакетов в пределах длины endpoint.
2. Есть буфер endpoint-a (например 64 байт), и регистр, из которого при завершении приёма данных можно прочитать, сколько байт было только что принято (0-64 байта).

Для сопровождения пакетов более подробной информацией, используются протоколы верхнего уровня.
Например для Mass Storage Device (флешки, HDD, CD-ROM и проч.), через endpoint-ы 1-7 (IN и OUT) - "гоняется" протокол SCSI. С помощью этого протокола пересылаются блоки данных, каждый из которых "обрамлён" вначале и в конце специальными полями CBW и CSW, по которым можно заранее узнать длину каждого такого блока, и достоверно определить завершение его приёма-передачи.
Пример, "Mass Storage Class, Bulk-Only Transport" USB MSC Bulk
Но и в этом случае, из заголовков CBW можно узнать только длину отдельных блоков, но не общую длину файла, которая известна только операционной системе.

Например из флешки читается тело MP3 файла, размер которого 10 Мбайт, но делается это блоками по 4096 байт каждый. В заголовках CBW будет сообщаться что блоки по 4096 байт. Но сколько таких блоков, и какова общая длина файла - знает только операционная система, которая заранее прочитала заголовок файла в корневом каталоге флешки laughing.gif
Go to the top of the page
 
+Quote Post



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

 


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


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