Перейти к содержанию
    

Наконец-то нашла пример для stm32f107 от ст.Там идет как раз прошивка с флэшки. Контроллер настраивается в режим хоста. Прошиваю примером плату sk-mstm32f107. В примере закоментированы настройки ЖКИ. Оставила только инициализацию юсб и обработку. Подключаю флэшку - не работает. Почему-то всегдафункция USBH_Process входит в состояния то host_idle, то host_usr_input. С первым состоянием понятно, а вот почему обрабатывается второе и проскакиваются остальные-непонятно. В приложении прикрепленный пример.

STM32F105_107_IAP_USBHost.rar

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Наконец-то нашла пример для stm32f107 от ст.Там идет как раз прошивка с флэшки. Контроллер настраивается в режим хоста. Прошиваю примером плату sk-mstm32f107. В примере закоментированы настройки ЖКИ. Оставила только инициализацию юсб и обработку. Подключаю флэшку - не работает. Почему-то всегдафункция USBH_Process входит в состояния то host_idle, то host_usr_input. С первым состоянием понятно, а вот почему обрабатывается второе и проскакиваются остальные-непонятно. В приложении прикрепленный пример.

 

При вызове ф-ции пользовательского ввода в состоянии host_usr_input необходимо вернуть значение, что-то типа USBH_OK (уточните)

Даже , если у Вас нет ввода с клавиатуры!

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

При вызове ф-ции пользовательского ввода в состоянии host_usr_input необходимо вернуть значение, что-то типа USBH_OK (уточните)

Даже , если у Вас нет ввода с клавиатуры!

Непонятно. Причем сдесь клавиатура?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Непонятно. Причем сдесь клавиатура?

А еще этот пример может быть рассчитан на МК в другом корпусе, в результате линии, используемые USB, попадают на совсем другие линии GPIO. Это нужно проверить и исправить. Почти наверняка ваш проект не работает именно из-за этого. И еще. Ничего из проекта пока не выбрасывайте, закомментируйте только работу с ЖКИ ...

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

А еще этот пример может быть рассчитан на МК в другом корпусе, в результате линии, используемые USB, попадают на совсем другие линии GPIO. Это нужно проверить и исправить. Почти наверняка ваш проект не работает именно из-за этого. И еще. Ничего из проекта пока не выбрасывайте, закомментируйте только работу с ЖКИ ...

проблемма была в отладочной плате, нужно было переставить перемычки... добилась связи с юсб, разбираю работу с файловой системой.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

 

Разбираюсь с файловой ситемой efsl, представленной в примере stm32f105_107_usb_fw. Насколько я понимаю, эта библиотека поддерживает fat12,fat16, fat32, но имена только 8.3 символьные. Подлючаю флэшку на 16 гб - флэшка инициализируется, а файловая система нет (функция fs_verifySanity возвращает 0, количество байт в секторе не равно 512). Подлючаю телефон через юсб, на нем сд карта на 2 гб, на ней пример работает. Разбиваю обычную флэшки на разделы, один из которых делаю 2 гб, форматирую в fat(16). Опять не инициализируется файловая система (на этот раз количество секторов на кластер равно 128, а поддерживаются только 1,2,4,8,16,32,64). Еще раз переразбила флэшку на этот раз размером на 1 гб и отформатировала в fat, и на этот раз все работает.

Теперь вопрос, как сделать так, чтобы можно было работать с флэшки любого размера. Дело в файловой системе? Или в библиотеке?

Изменено пользователем batisto4ka

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Видимо так никто и не подсказал...

 

В Reference Manual, глава 27.

Уточню, глава 28. Но лично мне так и не ясно, если я хочу подключать обычную флешку обязательно ли мне ставить микросхему STMPS2141STR.

Шина Vbus получаеться ничего не выдаёт?

 

проблемма была в отладочной плате, нужно было переставить перемычки... добилась связи с юсб, разбираю работу с файловой системой.

 

А если быть точнее перемыка J1 не была установлена и на флешку не шло питание 5 вольт?? Не подскажите а если нет у меня 5 вольт в схеме, могу ли от трёх вольт запитать USB флешку и будет ли работать? Полагаю вот схема вашей отладочной платы http://www.starterkit.ru/html/doc/SK_MSTM32F107.pdf ?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Продолжаю разбираться.

Нашёл два противоречия, может растолкует кто:

На плате sk-mstm32f107 когда подключаем USB-флешку она запитываеться блока питания. Линия Vbus МК и Vbus USB флешки не соеденены.

Хотя в RM0008 на схеме 304 указано что Vbus МК как хоста, и USB-флешки как девайса, должны быть соеденены, также сказано:

VBUS valid

The VBUS input ensures that valid VBUS levels are supplied by the charge pump during USB

operations.

Any unforeseen VBUS voltage drop below the VBUS valid threshold (4.25 V) leads to an OTG

interrupt triggered by the session end detected bit (SEDET bit in OTG_FS_GOTGINT). The

application is then required to remove the VBUS power and clear the port power bit. The

charge pump overcurrent flag can also be used to prevent electrical damage. Connect the

overcurrent flag output from the charge pump to any GPIO input and configure it to generate

a port interrupt on the active level. The overcurrent ISR must promptly disable the VBUS

generation and clear the port power bit.

Т.е. Vbus МК в режиме хоста мониторит состояние на линии Vbus, и если оно ниже 4.25 он генерит прерывание.

Получаеться что на плате sk-mstm32f107 просто обошли боком этот момент.

 

2) Определение факта подключения USB-флешки:

Сказано

Host detection of a peripheral connection

Even if USB peripherals or B-devices can be attached at any time, the OTG_FS will not detect any bus connection until the end of the VBUS sensing (VBUS over 4.75 V).

When VBUS is at a valid level and a remote B-device is attached, the OTG_FS core issues a host port interrupt triggered by the device connected bit in the host port control and status register (PCDET bit in OTG_FS_HPRT).

 

Я правильно понял при подключении USB-флешки напряжение на линии Vbus МК должно опуститься ниже 4.75 чтобы сгенерировалось прерывание на Хосте? Или я читаю не так...

 

 

Господа истолкуйте кто ведает истину!

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Продолжаю разбираться.

Нашёл два противоречия, может растолкует кто:

 

2) Определение факта подключения USB-флешки:

Сказано

Host detection of a peripheral connection

Even if USB peripherals or B-devices can be attached at any time, the OTG_FS will not detect any bus connection until the end of the VBUS sensing (VBUS over 4.75 V).

When VBUS is at a valid level and a remote B-device is attached, the OTG_FS core issues a host port interrupt triggered by the device connected bit in the host port control and status register (PCDET bit in OTG_FS_HPRT).

 

Смысл простой: детекция подключения переферии не сработает, если напряжение Vbus <=4,75V

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...