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

 
 
3 страниц V   1 2 3 >  
Reply to this topicStart new topic
> STM32 USB Device example, не могу запустить
ADA007
сообщение Sep 1 2013, 12:47
Сообщение #1


Местный
***

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



[indent][/indent]Приветствую всех!
Разбираюсь с аппаратным USB на stm32f103vct6. Не получается запустить пример проекта работы с usb wacko.gif.

Аппаратная платформа своя...собственно сам контроллер подключенный к 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. И по-моему я ни в одну из них не попадаю по ходу работы...

Подскажите, кто как боролся в стандартной библиотеке с данным примером? У всех работало сходу? sad.gif

ЗЫ: Управление usb_disconnect пином организовано так (в отличие от схемы, приведенной в архиве китайского автора для fure bull) из-за разных схем - пробовал управлять disconnect-ом в инверсии - результат тот же. Свой проект прилагаю.

Прикрепленные файлы
Прикрепленный файл  USB_MS.tar.gz ( 5.37 мегабайт ) Кол-во скачиваний: 16
 
Go to the top of the page
 
+Quote Post
kovigor
сообщение Sep 1 2013, 16:55
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 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 проекта, думаю, можно гарантировать ...
Go to the top of the page
 
+Quote Post
ADA007
сообщение Sep 1 2013, 17:34
Сообщение #3


Местный
***

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



Цитата(kovigor @ Sep 1 2013, 19:55) *
Схема дисконнекта у вас странная, очень...

Я её тоже не сам придумывал - содрал с оф. платы olimex .
И на easyelectronix.ru тоже ее в пример приводили.
С прогой буду дальше мучатся...жду ваших советов, куда копать?
Go to the top of the page
 
+Quote Post
kovigor
сообщение Sep 1 2013, 18:09
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(ADA007 @ Sep 1 2013, 20:34) *
С прогой буду дальше мучатся...жду ваших советов, куда копать?

D+ и D- не перепутаны ?
Go to the top of the page
 
+Quote Post
Flexz
сообщение Sep 1 2013, 18:24
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797



Цитата
Подключите коллектор Q4 не к 3.3В, а к пяти, идущим от USB - хоста, т.е., к линии USB_Power.

А так можно? Получится 5 вольт на DP же. А по спекам там ЕМНИП 3.6 максимум допустимо.
Go to the top of the page
 
+Quote Post
kovigor
сообщение Sep 1 2013, 18:26
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(Flexz @ Sep 1 2013, 21:24) *
А так можно? Получится 5 вольт на DP же. А по спекам там ЕМНИП 3.6 максимум допустимо.

Посмотрел Гука. Да, надо к 3.3В, а не к 5В. Но вообще, там написано, что приемник обязан выдерживать не менее 3.8В. Вы правы, прошу прощения.
Go to the top of the page
 
+Quote Post
ADA007
сообщение Sep 1 2013, 18:46
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 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?
Go to the top of the page
 
+Quote Post
kovigor
сообщение Sep 1 2013, 19:02
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(ADA007 @ Sep 1 2013, 21:46) *
И все-таки не могу понять когда переменной bDeviceState должно быть присвоено значение CONFIGURED?

Я в этих примерах разбирался давно, деталей не помню. К тому же, USB в STM сложный, как космический корабль.
Вы не с того конца к проблеме подошли. Configured, надо полагать, присваивается тогда, когда устройству назначена конфигурация (хостом). А для этого оно должно чуть ли не полностью пройти энумерацию. Поставьте BusHound и посмотрите, чем ваше устройство обменивается с хостом на этапе энумерации, и обменивается ли вообще. Запустите USBView и посмотрите, есть ли ваше устройство в системе и как именно оно там распознано ...
Go to the top of the page
 
+Quote Post
ADA007
сообщение Sep 2 2013, 14:38
Сообщение #9


Местный
***

Группа: Свой
Сообщений: 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 не работает ? ЧЯДНТ?
Go to the top of the page
 
+Quote Post
controller_m30
сообщение Sep 2 2013, 15:57
Сообщение #10


Местный
***

Группа: Участник
Сообщений: 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-модуля в начальное положение. Но не отключать резистор.
Go to the top of the page
 
+Quote Post
Alex11
сообщение Sep 2 2013, 19:25
Сообщение #11


Гуру
******

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



Проверьте, все-таки, работает ли у Вас подключение подтяжки. И еще один момент. Есть там в библиотеке такая строчка: gusbcfg.b.usbtrdtim = 5;
В файле usb_dcd_int.c. Так вот, пяти может не хватить в некоторых случаях. Там, по хорошему, должно быть число, зависящее от тактов шины и скорости USB. На попробовать можно увеличить до предела (15).
Go to the top of the page
 
+Quote Post
ADA007
сообщение Sep 3 2013, 12:15
Сообщение #12


Местный
***

Группа: Свой
Сообщений: 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; = результата не дало (
Помогите, кто чем может! crying.gif
Go to the top of the page
 
+Quote Post
kovigor
сообщение Sep 3 2013, 12:29
Сообщение #13


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(ADA007 @ Sep 3 2013, 15:15) *
Помогите, кто чем может !

Ненавижу использовать чужие проекты без глубокого вникания в суть происходящих в них процессов.
С кварцем вы ничего не напутали ? И D+ вы не имеете права этим светодиодом к земле тянуть (тянуть линии данных к земле - дело хоста, но никак не устройства) ...
Повторюсь, там что-то элементарное, и косяк почти наверняка ваш. Не может тот проект с сайта не работать. Не видел я такого. Если бы это было так, их бы давно засыпали письмами с описанием проблемы, и они бы быстро исправили ошибку .
Go to the top of the page
 
+Quote Post
ADA007
сообщение Sep 3 2013, 12:57
Сообщение #14


Местный
***

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



Цитата(kovigor @ Sep 3 2013, 15:29) *
Повторюсь, там что-то элементарное, и косяк почти наверняка ваш.

Я с этим вполне согласен. Но ума не приложу где это я мог накосячить и как это найти... конечно пытаюсь найти..но пока что безрезультатно, вот и пишу суда...может кто подскажет куда посмотреть, что попробовать, как проверить...
ЗЫ: а по поводу схемы...это один в одни схема из архива в первом посте... поскольку исходники брал из этого архива, то и схему решил в итоге повторить, потому, что так которая на рисунке в первом посте - та более правильная, но не из этого стартеркита.
Go to the top of the page
 
+Quote Post
kovigor
сообщение Sep 3 2013, 13:05
Сообщение #15


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(ADA007 @ Sep 3 2013, 15:57) *
может кто подскажет куда посмотреть, что попробовать, как проверить...

Подскажу. Я, когда свои USB - дивайсы делал, до тонкостей вникал в стандартные примеры, до дыр зачитал спецификацию на шину, разработал и изготовил прибор на FPGA, захватывающий транзакции на шине, написал для него ПО, показывающее транзакции на экране персоналки, и только тогда получил достойный вложенного труда, вменяемый и предсказуемый результат. А вы хотите с наскока. Вот и получаете. Чудес не бывает. И примеры от ST, поверьте, далеки от совершенства ...
Go to the top of the page
 
+Quote Post

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

 


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


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