|
STM32F103 виртуальный СОМ-порт (USB CDC) и сообщение WM_DEVICECHANGE, В сообщениях "WM_DEVICECHANGE" STM32 USB CDC не определяется к |
|
|
|
Feb 10 2017, 08:42
|
Участник

Группа: Участник
Сообщений: 17
Регистрация: 23-11-05
Пользователь №: 11 270

|
На STM32F103 поднят виртуальный СОМ-порт (USB CDC). Используется стандартная библиотека от STM. Все работает. Байты летают туда-сюда. Однако, при отлаживании устройства, наверно многие обратили внимание, что после перезагрузки/перепрошивки контроллера, виртуальный порт «отваливается». Однако во всех доступных мне терминальных программах он так и остается открытым. Данные при этом естественно никакие не идут. Если в терминальной программе закрыть порт, то открыть его не получится. Нужно опять перезагрузить микроконтроллер и только тогда снова открыть порт. Т.е. правильная последовательность действий должна быть такая: 1. Закрыть порт в терминальной программе. 2. Перезагрузить/препрошить и т.д. 3. Открыть порт в терминальной программе. Обычно про эту последовательность вспоминаешь, когда уже успел загрузить новую прошивку, контроллер перезагрузился и виртуальный порт «отвалился».
В самописной терминальной программе решил оптимизировать этот процесс. Реализовал получение от Windows системных сообщений WM_DEVICECHANGE указывающих на изменения в устройствах. Из этого сообщения нужны события DBT_DEVICEARRIVAL и DBT_DEVICEREMOVECOMPLETE – подключение и удаление устройства соответственно. Далее можно проанализировать Тип устройства которое подключилось или было удалено из системы. Наиболее интересен тип DBT_DEVTYP_PORT, который как раз и является указывающим на Последовательный или Параллельный порт. И вот тут с устройством на STM32 возникла неприятность. При подключении или отключении STM32 событие с типом устройства DBT_DEVTYP_PORT не присылается! Помимо типа DBT_DEVTYP_PORT есть общий тип DBT_DEVTYP_DEVICEINTERFACE указывающий вообще на любое устройство. Вот приходит только событие с этим типом и все. Я проверил имеющиеся у меня переходники USB<->COM на FT232, CPxxx, PL2303 и китайской CH340. При их подключении/отключении помимо событий с общим типом DBT_DEVTYP_DEVICEINTERFACE всегда приходит событие с типом DBT_DEVTYP_PORT по которому легко определить, что конфигурация портов изменилась, а получив из возвращаемой структуры поле Name, можно сразу определить какой порт подключился/удалился. Собственно вопросы к знатокам: В какую сторону стоит копнуть, чтоб и при подключение/удалении STM32 получать сообщение DBT_DEVTYP_PORT? Кто отвечает за рассылку этих сообщений? Я подозреваю, что драйвер, а он используется стандартный виндовый usbser.sys. В файле stmcdc.inf используемом при установке драйвера виртуального COM-порта прописан GUID класса портов. Так, что эта часть кажется правильной. В системе, в диспетчере устройств STM32 USB CDC присутствует в классе портов. WinAPI’шная функция SetupDiEnumDeviceInfo() возвращает среди прочих портов и STM32. Т.е. Винда знает, что это последовательный порт, но сообщения об этом не приходят.
|
|
|
|
|
 |
Ответов
|
Feb 10 2017, 11:28
|
Участник

Группа: Участник
Сообщений: 36
Регистрация: 18-10-06
Из: Москва
Пользователь №: 21 459

|
Проблема в драйвере usbser.sys, он не регистрирует отправку событий PnP. Можно обкостылить добавив в .inf файл драйвер фильтр serenum.sys. Но возникнут другие проблемы: потеряется цифровая подпись от ST и этот драйвер предназначен для обнаружения PnP устройств на COM порту. При добавлении serenum.sys, Windows при некоторых последовательностей байт может находить мышки, трекболы и.т.д. Проблема в usbser.sys решена в Windows 10, там уведомления о подключении и отключении присылаются.
Переходники от FTDI и Prolific используют свои драйверы, за место usbser.sys. Они даже не USBCDC класс.
При использовании serenum.sys уведомления будут приходить только при регистрации класса GUID_DEVINTERFACE_SERENUM_BUS_ENUMERATOR. Номер COM порта можно узнать из реестра, открыв ключ реестра с помощью SetupDiOpenDevRegKey.
|
|
|
|
|
Feb 10 2017, 12:13
|
Участник

Группа: Участник
Сообщений: 17
Регистрация: 23-11-05
Пользователь №: 11 270

|
Цитата(DeNi @ Feb 10 2017, 14:28)  Проблема в драйвере usbser.sys, он не регистрирует отправку событий PnP. Да, видимо вы правы. Нашел в закромах плату с атмеловским AT91SAM7 и тоже включенным CDC - ситуация аналогична с STM32. Драйвер используется все тот-же usbser.sys и в событиях DBT_DEVICEARRIVAL и DBT_DEVICEREMOVECOMPLETE приходит только в виде "USB Raw Device" {a5dcbf10-6530-11d2-901f-00c04fb951ed}. По умолчанию, в отличии от портов, эти сообщения не приходят и нужно или подписываться на них, или "включать" все сообщения (DEVICE_NOTIFY_ALL_INTERFACE_CLASSES). Видимо придется при получении событий об добавлении/удалении устройств перезапрашивать у Винды список портов. Причем замечена одна особенность с китайским переходником USB<->COM CH340. Если порт открыт в терминалке и выдернуть переходник, то сообщение об удалении Порта приходит. Но в реестре он остается в списке имеющихся портов и можно писать в него не получая ошибки. Удаляется он из списка портов только после того, как его закрыли. Поэтому по приходу событий DBT_DEVICEARRIVAL и DBT_DEVICEREMOVECOMPLETE просто перечитать реестр не помогает. Порт еще будет присутствовать. Надо или разбирать тип DBT_DEVTYP_PORT для извлечения Имени, или получать список портов функцией SetupDiEnumDeviceInfo().
|
|
|
|
Сообщений в этой теме
Mazay STM32F103 виртуальный СОМ-порт (USB CDC) и сообщение WM_DEVICECHANGE Feb 10 2017, 08:42 aiwa Цитата(Mazay @ Feb 10 2017, 10:42) Собств... Feb 10 2017, 11:00 Genadi Zawidowski Тут
http://stackoverflow.com/questions/2899862...l... Feb 10 2017, 11:03  Alechek Цитата(Mazay @ Feb 10 2017, 17:13) Поэтом... Feb 10 2017, 17:09 Genadi Zawidowski СТранно...
USB CDC на десятке такое дает:
Цитата... Feb 10 2017, 12:49 DeNi класс Ports для USB CDC ACM начал поддерживаться т... Feb 10 2017, 13:45 Mazay Цитата(DeNi @ Feb 10 2017, 16:45) lParam ... Feb 13 2017, 12:10 johnshadow Если нет стойкой ненависти к паскалю - ниже прилаг... Feb 10 2017, 15:32 prottoss Всем доброго времени суток.
Я тоже сталкивался с ... Feb 10 2017, 17:16 hd44780 Mazay, у Вас pull-up на D+ отключаемый или нет? Ес... Feb 11 2017, 18:47 Genadi Zawidowski Если в операционной системе кто-то держит открытым... Feb 11 2017, 18:54 DeNi Цитата(prottoss @ Feb 10 2017, 20:16) Все... Feb 12 2017, 10:32 Mazay Цитата(DeNi @ Feb 12 2017, 13:32) Как раз... Feb 13 2017, 07:05 aiwa Согласно документации: "When this structure i... Jul 14 2017, 10:00
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|