|
|
  |
USB HID из STM32F1xx_DFP, Помогите начать и кончить |
|
|
|
Apr 18 2014, 11:11
|

Универсальный солдатик
     
Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362

|
Пример из последнего Keil из пакета ARM\Pack\Keil\STM32F1xx_DFP\1.0.5\Boards\Keil\MCBSTM32E\Middleware\USB\Device\HID\ пытаюсь приспособить под плату MCBSTM32. Есть отличия в схемах, поправил, как смог. Собственно, мне и нужно только светодиоды включать да кнопки опрашивать. С помощью HIDClient, оттуда же, из Keil. Но пока что компьютер выдает "Устройство USB не опознано". Прилагаю лог, собранный с помощью USBTrace. Что это значит? Такое впечатление, что дескрипторы неправильные, если они вообще есть. В проекте найти их пока не смог, и не создавал. После сброса на USB секунд 5 что-то болтается, потом - тишина.
Эскизы прикрепленных изображений
|
|
|
|
|
Apr 21 2014, 19:34
|

Универсальный солдатик
     
Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362

|
Копаю дальше. Смотрю осциллографом сигналы D+ D-, декодирую сам. Вижу после сброса на шине регулярно через 1 ms идут пакеты SOF, за ними IN к uLink-ME, намного реже идут PRE low_speed и IN к мышке. Найти обращения к нулевому адресу так не получается. Зато заметил, что несколько раз на шине появляется сброс (оба сигнала в низком уровне, длительностью около 10,5 ms). Вот по этому сигналу засинхронизировался. Последнее, что передается к нулевому адресу, это SETUP и DATA1 (Get_Descriptor устройства, который предполагает 0x40 байтов данных). Но вместо данных идет пакет DATA0 вроде как без данных, но с CRC16. И такой набор пакетов повторяется 3 раза, затем через несколько кадров хост отключает этот сегмент шины, и уже ничего нет (Idle). Пытаюсь увязать то, что вижу я, с тем, что видят USBtrace и USBlyzer. Каждый видит своё.  upd. Посмотрел еще раз, пакета DATA0 не увидел.
|
|
|
|
|
Apr 22 2014, 12:34
|

Универсальный солдатик
     
Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362

|
Да... попался я. Имею в начале программы 2 библиотечных функции. Что они делают, не видно. Код USBD_Initialize(0); /* USB Device 0 Initialization */ USBD_Connect(0); /* USB Device 0 Connect */ После второй программа улетает в HardFault с симптомом: Цитата Bit possible Causes INVSTATE (bit 1) 1. Loading branch target address to PC with LSB equals 0. Stacked PC should show the branch target. 2. LSB of vector address in vector table is 0. Stacked PC should show the starting of exception handler. 3. Stacked PSR corrupted during exception handling, so after the exception the core tries to return to the interrupted code in ARM state.
|
|
|
|
|
Apr 25 2014, 12:47
|

Универсальный солдатик
     
Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362

|
Попытался аналогичным образом создать VirtualCOM, и снова имею те же проблемы - секунд 5 на шине бегают сигналы, после останавливается, компьютер пишет "Устройство USB не опознано". Что-то я разочарован Keil-овским USB Component. Попрятали все функции в библиотеки, еще и RTX свою приплели. Вообще, дурдом. Шина начинает "шевелиться" еще до выполнения функций USBD_Initialize(0); /* USB Device 0 Initialization */ USBD_Connect(0); /* USB Device 0 Connect */ Вижу, ходя по функциям. upd. Заработало и это. Переместил галочки в примере на F107 в RTE_Device.h USB OTG ... на USB Device, для F103.  Как побежало по шине, сплошным потоком! Что передают? Я пока ничего не пересылаю.
|
|
|
|
|
Apr 25 2014, 20:05
|

Универсальный солдатик
     
Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362

|
Теперь такой вопрос - каким образом задаются параметры COM порта? Вижу в USBD_User_CDC_0.c функцию Код // Called upon USB request to Set Line Coding. // \param[in] line_coding pointer to \ref CDC_LINE_CODING structure. // \return true set line coding request processed. // \return false set line coding request not supported or not processed. bool USBD_CDC0_ACM_SetLineCoding (CDC_LINE_CODING *line_coding) {
if (Driver_UART1.Configure ( line_coding->dwDTERate, line_coding->bDataBits, (ARM_UART_PARITY) line_coding->bParityType, (ARM_UART_STOP_BITS) line_coding->bCharFormat, ARM_UART_FLOW_CONTROL_NONE) == ARM_UART_OK) {
LineCoding.dwDTERate = line_coding->dwDTERate; LineCoding.bDataBits = line_coding->bDataBits; LineCoding.bParityType = line_coding->bParityType; LineCoding.bCharFormat = line_coding->bCharFormat; } return true; } Похоже, нужно послать по USB запрос на установку режимов, они одинаковые и для VirtualCOM, и для COM (символы передаются с одного порта на другой, и наоборот, в данном примере). Но что-то я не нахожу, где и когда создается такой запрос. В настройках COM (VirtualCOM) порта в Windows?
|
|
|
|
|
Apr 26 2014, 19:29
|

Профессионал
    
Группа: Свой
Сообщений: 1 333
Регистрация: 27-10-08
Из: Планета Земля
Пользователь №: 41 226

|
А примеры готовые посмотреть - на крайний случай можно гуглом. Я вот когда-то делал HID (CMSIS-DAP debugger) и CDC для всякой фигни отладочной - всё на F103 Проблем особых нет - особенно когда есть дебаггер (любой) можно просто скачать - поменять обратотку hid пакетов если надо https://github.com/x893/CMSIS-DAPcdc он и в африке cdc P.S. При наличии отладчика 99% вопросов должны отпадать сами собой
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|