Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Кому-нибудь удалось запустить на AT91sam7sxxx пример usb-device-composite-cdchid-project?
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
Genadi Zawidowski
Кому-нибудь удалось запустить на AT91sam7sxxx пример usb-device-composite-cdchid-project? У меня даже прекомпилированный из пакета с примерами не опознаётся... (cdc в одиночестве нормально видится).
После некоторгого колчестав возни сделал общее дерево исходников для конфигураций

Код
#CHIP  = at91sam9xe512
#BOARD = at91sam9xe-ek

CHIP  = at91sam7s64
BOARD = at91sam7s-ek


на evaluation board с at91sam9xe512 оба устройства опознаются нормально, на плате с at91sam7s64 процесс не доходит до конца - и USB composite device висит с вопросиком.

Это у меня криво или играет роль та самая ошибка в usb framework про недосылку нулевого пакета после кратного длине допустимого для EP пакета?
Есть ли поправленный вариант usb framework?
Одиночное устройство CDC, композитное usb-device-audio-looprec-project работают нормально.

Да, уточняю - используется AT91LIB version 1.9 (11 MB, revision 1.9, updated 12/08) из файла at91lib_20100901_softpack_1_9_v_1_0_svn_v15011
С версией 1.5 не отличается.
kovigor
Я бы скачал Bushound и посмотрел, где именно сбивается энумерация. Вообще, от бесплатных примеров трудно ожидать корректной работы. Их всегда приходится разбирать до винтика и исправлять по ходу кучу разных мелких и не совсем мелких недоработок ...
Genadi Zawidowski
Цитата(kovigor @ Nov 28 2010, 14:42) *
Я бы скачал Bushound и посмотрел, где именно сбивается энумерация. Вообще, от бесплатных примеров трудно ожидать корректной работы. Их всегда приходится разбирать до винтика и исправлять по ходу кучу разных мелких и не совсем мелких недоработок ...

USBlyzer в своём логе сообщает о неудачном завершении вызовов SelectConfiguration. На плате с AT91SAM9XE512 нормально.
kovigor
Цитата(Genadi Zawidowski @ Nov 28 2010, 15:02) *
USBlyzer в своём логе сообщает о неудачном завершении вызовов SelectConfiguration. На плате с AT91SAM9XE512 нормально.


Лог - это хорошо. Но этого мало. Bushound показывает содержимое пакетов, а не просто лог ...
Genadi Zawidowski
Цитата(kovigor @ Nov 28 2010, 15:18) *
Лог - это хорошо. Но этого мало. Bushound показывает содержимое пакетов, а не просто лог ...

у SelectConfiguration содержимое пакета? Это же не ответ на GetDescriptor... Для последней можно посмотреть хоть raw, хоть интерпретированное.

У кого-нибудбь с родной (atmel) evaluation board с AT91SAM7Sxxx этот пример заработал нормально? Чтобы знать - это аппаратура или программа?

В ответ на запрос от хоста setconfig устройство удивляется - ещё не закончилась передача сегментированного блока (состояние в программе UDP_ENDPOINT_SENDINGM).
Genadi Zawidowski
Посмотрите, правильно ли я понял - при наличии в контроллере USB четырёх endpoint не может быть значение bEndpointAddress
больше 3?

"в наглую" поменяв все номера ендпоинтов, превышавшие 3 на то число дало нормально опознающийся (и, даже, функционирующий в части CDC) комплект устройств...
Попутно, было вычищено пара мест (использование неинициализированого массива указателей в SetConfiguration (USBDDriver.c) - там же авторы пердусмотрели "запасной" элемент, но не предусмотрели контрль индексов при адресации к массиву endpoints. Контроль выявил место ошибки.
Filipok
QUOTE (Genadi Zawidowski @ Nov 29 2010, 22:52) *
Посмотрите, правильно ли я понял - при наличии в контроллере USB четырёх endpoint не может быть значение bEndpointAddress
больше 3?

"в наглую" поменяв все номера ендпоинтов, превышавшие 3 на то число дало нормально опознающийся (и, даже, функционирующий в части CDC) комплект устройств...
Попутно, было вычищено пара мест (использование неинициализированого массива указателей в SetConfiguration (USBDDriver.c) - там же авторы пердусмотрели "запасной" элемент, но не предусмотрели контрль индексов при адресации к массиву endpoints. Контроль выявил место ошибки.


Хорошо хоть у вас в наличие есть другие МК, т.к. на этом (SAM7S) вы обречены на неудачу получить из представленных примеров работающий Composit(Compound) устройство [CENSORED]! Вы абсолютно правы, беда с EP (end point), их просто физически МАЛО, всего-то 4 (включая 0-ой) [CENSORED]!!! Как так можно было поиздеваться над пользователями sad.gif Для нормальной работы CDC+HID надо 6 (включая 0-ой)! Я тоже, наткнулся на эту проблему, когда понадобилось композитное устройство (только в моем случае CDC+MSD), потратил пару часов пока со всем разобрался... Просто код они попытались написать универсальный (в частности для конфигурации EP), но допустили ошибку для SAM7S, даже каким-нить #define-ом не учли (хотя такой и есть в board.h) сколько EP есть а сколько надо (и могли бы выдать хотя бы ошибку компиляции)!

Физически, по идее, получить композитное устройство не получиться для SAM7S! Но, можно получить "комбинированное" smile.gif)) Правда все зависит от требований к проекту... Т.е. можно сначала проинициализировать одно, скажем MSD (чтобы, к примеру, взять из него inf файлик для CDC устройства и еще какой нужный софт или данные), затем его остановить + сбросить шину (для этого надо транзистор на подтягивающем резисторе, ну или хотя бы переключатель smile.gif), а в конечном итоге проинициализировать второе, скажем CDC (для рассматриваемого примера) - И СЕ, работаем!!! (вот так вот пару месяцев назад мне и пришлось выходить из "положения"! аллах ахбар там хоть не требовалась постоянная работа Флэшки(MSD)) smile.gif))
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.