|
STM32 USB Device example, не могу запустить |
|
|
|
Sep 1 2013, 12:47
|

Местный
  
Группа: Свой
Сообщений: 218
Регистрация: 2-02-09
Из: Харьков
Пользователь №: 44 266

|
[indent][/indent]Приветствую всех! Разбираюсь с аппаратным USB на stm32f103vct6. Не получается запустить пример проекта работы с usb  . Аппаратная платформа своя...собственно сам контроллер подключенный к usb и стабилизатор питания, больше ничего нет. Софт брал отсуда ТЫЦ (USB-Mass_Storage-MCU Flash). Просматривая код, я понял что это просто обрезанная версия Mass_Storage из STM32_USB-FS-Device_Lib_V3.3.0. Я так понимаю я должен был на выходе получить стандартное устройсво mass storage с объмом памяти flash контроллера? Переконфигурировал пины под себя - залил...и застрял на строке main.c => while (bDeviceState != CONFIGURED); Далее просматривая код, я нашел всего 2-е функции, где этой переменной присваивается значение CONFIGURED. И по-моему я ни в одну из них не попадаю по ходу работы... Подскажите, кто как боролся в стандартной библиотеке с данным примером? У всех работало сходу? ЗЫ: Управление usb_disconnect пином организовано так (в отличие от схемы, приведенной в архиве китайского автора для fure bull) из-за разных схем - пробовал управлять disconnect-ом в инверсии - результат тот же. Свой проект прилагаю.
|
|
|
|
|
Sep 1 2013, 16:55
|
Гуру
     
Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295

|
Цитата(ADA007 @ Sep 1 2013, 15:47)  Свой проект прилагаю. Схема дисконнекта у вас странная, очень. Q4 включен как эмиттерный повторитель, но база у него положительнее, чем коллектор, а с эмиттера вы пытаетесь снять сигнал, по уровню превышающий имеющиеся на коллекторе 3.3В. Зачем так делать ? Подключите коллектор Q4 не к 3.3В, а к пяти, идущим от USB - хоста, т.е., к линии USB_Power. P.S. Пример от STM должен работать, по идее. Не вы первый его используете. Я запускал их пример на STM32F207, подправив ножки в соответствии с тем, что пример был рассчитан на корпус "X", а у меня был МК в корпусе "Y". В итоге все заработало. Минимальную работоспособность выложенного на сайте ST проекта, думаю, можно гарантировать ...
|
|
|
|
|
Sep 1 2013, 17:34
|

Местный
  
Группа: Свой
Сообщений: 218
Регистрация: 2-02-09
Из: Харьков
Пользователь №: 44 266

|
Цитата(kovigor @ Sep 1 2013, 19:55)  Схема дисконнекта у вас странная, очень... Я её тоже не сам придумывал - содрал с оф. платы olimex . И на easyelectronix.ru тоже ее в пример приводили. С прогой буду дальше мучатся...жду ваших советов, куда копать?
|
|
|
|
|
Sep 1 2013, 18:24
|
Местный
  
Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797

|
Цитата Подключите коллектор Q4 не к 3.3В, а к пяти, идущим от USB - хоста, т.е., к линии USB_Power. А так можно? Получится 5 вольт на DP же. А по спекам там ЕМНИП 3.6 максимум допустимо.
|
|
|
|
|
Sep 1 2013, 18:46
|

Местный
  
Группа: Свой
Сообщений: 218
Регистрация: 2-02-09
Из: Харьков
Пользователь №: 44 266

|
Цитата(kovigor @ Sep 1 2013, 21:09)  D+ и D- не перепутаны ? Тоже по началу так думал....но нет...несколько раз проверил, DM - 70 pin, DP - 71 pin + подтяжка 1,5к через схему disconnect. И все-таки не могу понять когда переменной bDeviceState должно быть присвоено значение CONFIGURED?
|
|
|
|
|
Sep 1 2013, 19:02
|
Гуру
     
Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295

|
Цитата(ADA007 @ Sep 1 2013, 21:46)  И все-таки не могу понять когда переменной bDeviceState должно быть присвоено значение CONFIGURED? Я в этих примерах разбирался давно, деталей не помню. К тому же, USB в STM сложный, как космический корабль. Вы не с того конца к проблеме подошли. Configured, надо полагать, присваивается тогда, когда устройству назначена конфигурация (хостом). А для этого оно должно чуть ли не полностью пройти энумерацию. Поставьте BusHound и посмотрите, чем ваше устройство обменивается с хостом на этапе энумерации, и обменивается ли вообще. Запустите USBView и посмотрите, есть ли ваше устройство в системе и как именно оно там распознано ...
|
|
|
|
|
Sep 2 2013, 14:38
|

Местный
  
Группа: Свой
Сообщений: 218
Регистрация: 2-02-09
Из: Харьков
Пользователь №: 44 266

|
Цитата(kovigor @ Sep 1 2013, 22:02)  Поставьте BusHound и посмотрите... Поставил, посмотрел - при подключении устройства windows пишет, что найдено неизвестное устройство, в bushound - ни одного события по данному устройству не было. Что-то меня дернуло коротнуть линию DP на gnd несколько раз - имитируя подключение устройства - и в системе определилось mass storage, в budhound - появились события. Подумал, что дело в схеме disconnect. Переделал как у китайского автора на одном pnp транзисторе = результат тот же...устройство тупо висит на линии и никакой активности, определяется как неизвестное. Попробовал тупо 1,5к которое на DP висит на vcc посадить - эффект тот же. На сколько я помню устройство должно подключиться к usb и подтяжкой 1,5к система определяет, что появилось новое устройство и посылает ему reset. После этого устройство должно снять подтяжку 1,5к с DP и потом снова подключить. Далее начинается инициализация... Не пойму.Почему я делаю disconnect вручную - все работает, а программно disconnect не работает ? ЧЯДНТ?
|
|
|
|
|
Sep 2 2013, 15:57
|
Местный
  
Группа: Участник
Сообщений: 356
Регистрация: 24-02-09
Пользователь №: 45 309

|
Цитата(ADA007 @ Sep 2 2013, 17:38)  На сколько я помню устройство должно подключиться к usb и подтяжкой 1,5к система определяет, что появилось новое устройство и посылает ему reset. После этого устройство должно снять подтяжку 1,5к с DP и потом снова подключить. Далее начинается инициализация... Не пойму.Почему я делаю disconnect вручную - все работает, а программно disconnect не работает ? ЧЯДНТ? Не должно устройство отсоединять резистор 1,5к. Отсоединение резистора равнозначно извлечению устройства из разъёма USB (кстати можете пользоваться программным отключением резистора для имитации физического переподключения). Обмен с хостом происходит при подключенном резисторе. А состояние RESET лишь сигнализирует устройству, что оно должно сбросить все свои программные переменные, и некоторые регистры USB-модуля в начальное положение. Но не отключать резистор.
|
|
|
|
|
Sep 3 2013, 12:15
|

Местный
  
Группа: Свой
Сообщений: 218
Регистрация: 2-02-09
Из: Харьков
Пользователь №: 44 266

|
Цитата(Alex11 @ Sep 2 2013, 22:25)  Проверьте, все-таки, работает ли у Вас подключение подтяжки. И еще один момент. Есть там в библиотеке такая строчка: gusbcfg.b.usbtrdtim = 5; В файле usb_dcd_int.c. Так вот, пяти может не хватить в некоторых случаях. Там, по хорошему, должно быть число, зависящее от тактов шины и скорости USB. На попробовать можно увеличить до предела (15). Подключение подтяжки проверил...в отладчике дергаю портом контроллера - светодиод соответственно включается и выключается (вроде как транзистор работает). Схема disconnect у меня теперь такая (только светодиод подключил через 8к, а не через 470, как на картинке)  Попутно еще вопрос...сопротивление на DP 1,5к сигнализирует о том, что устройство готово принимать данные от хоста. Похоже, что у меня устройство не готово принимать данные? или как? Может в отладчике бряки поставить где-то, чтоб выловить момент приема данных от хоста? Пробовал увеличивать gusbcfg.b.usbtrdtim = 15; = результата не дало ( Помогите, кто чем может!
|
|
|
|
|
Sep 3 2013, 12:57
|

Местный
  
Группа: Свой
Сообщений: 218
Регистрация: 2-02-09
Из: Харьков
Пользователь №: 44 266

|
Цитата(kovigor @ Sep 3 2013, 15:29)  Повторюсь, там что-то элементарное, и косяк почти наверняка ваш. Я с этим вполне согласен. Но ума не приложу где это я мог накосячить и как это найти... конечно пытаюсь найти..но пока что безрезультатно, вот и пишу суда...может кто подскажет куда посмотреть, что попробовать, как проверить... ЗЫ: а по поводу схемы...это один в одни схема из архива в первом посте... поскольку исходники брал из этого архива, то и схему решил в итоге повторить, потому, что так которая на рисунке в первом посте - та более правильная, но не из этого стартеркита.
|
|
|
|
|
Sep 3 2013, 13:05
|
Гуру
     
Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295

|
Цитата(ADA007 @ Sep 3 2013, 15:57)  может кто подскажет куда посмотреть, что попробовать, как проверить... Подскажу. Я, когда свои USB - дивайсы делал, до тонкостей вникал в стандартные примеры, до дыр зачитал спецификацию на шину, разработал и изготовил прибор на FPGA, захватывающий транзакции на шине, написал для него ПО, показывающее транзакции на экране персоналки, и только тогда получил достойный вложенного труда, вменяемый и предсказуемый результат. А вы хотите с наскока. Вот и получаете. Чудес не бывает. И примеры от ST, поверьте, далеки от совершенства ...
|
|
|
|
3 чел. читают эту тему (гостей: 3, скрытых пользователей: 0)
Пользователей: 0
|
|
|