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

 
 
> Своя программная обёртка USB stm32, Создание своего драйвера USB для STM32
linuxbergi
сообщение Aug 4 2017, 06:59
Сообщение #1





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



Работаю над собственным драйвером для USB в STM32 , что-то мало материала. 99 % как скомпилировать готовый пример. Кто занимался аналогичной задачей? В принципе значительная часть уже сделана.
Go to the top of the page
 
+Quote Post
4 страниц V  < 1 2 3 4 >  
Start new topic
Ответов (15 - 29)
Эдди
сообщение Aug 4 2017, 21:39
Сообщение #16


Знающий
****

Группа: Участник
Сообщений: 825
Регистрация: 16-04-15
Из: КЧР, Нижний Архыз
Пользователь №: 86 250



Вообще дурацкое это слово — "драйвер". Я только драйверы шаговых двигателей могу вспомнить. Где еще в природе это слово употребляется? На компе с железяками работают модули ядра (если их сразу в ядро не вмонолитили). На железяках крутятся прошивки. Где драйвера-то?
Go to the top of the page
 
+Quote Post
ViKo
сообщение Aug 5 2017, 06:01
Сообщение #17


Универсальный солдатик
******

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



Эдди, вы когда-нибудь ставили Виндовс на голый комп?
https://ru.m.wikipedia.org/wiki/Драйвер
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Aug 5 2017, 06:34
Сообщение #18


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



QUOTE (Эдди @ Aug 5 2017, 00:39) *
Где драйвера-то?
Может, здесь?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Эдди
сообщение Aug 5 2017, 06:41
Сообщение #19


Знающий
****

Группа: Участник
Сообщений: 825
Регистрация: 16-04-15
Из: КЧР, Нижний Архыз
Пользователь №: 86 250



Цитата(ViKo @ Aug 5 2017, 09:01) *
Эдди, вы когда-нибудь ставили Виндовс на голый комп?

Тьфу-тьфу, с этим говном дела не имею!
Цитата(Сергей Борщ @ Aug 5 2017, 09:34) *
Может, здесь?

Просто какой-то осел модуль ядра драйвером назвал.
Бывает. До сих пор встречаются ослы, которые директории/каталоги/справочники называют "папками". А мамок им не завезли случайно?

Сообщение отредактировал Эдди - Aug 5 2017, 06:42
Go to the top of the page
 
+Quote Post
mantech
сообщение Aug 5 2017, 06:46
Сообщение #20


Гуру
******

Группа: Участник
Сообщений: 2 219
Регистрация: 16-08-12
Из: Киров
Пользователь №: 73 143



Цитата(ViKo @ Aug 5 2017, 09:01) *
Эдди, вы когда-нибудь ставили Виндовс на голый комп?


Это ортодоксальный фанатик, какая винда? О чем вы... Спросите еще, как диск С отформатировать biggrin.gif

Драйвер - всегда была программа, являющаяся мостом между аппаратным устр-вом уровня ядра и программой уровня пользователя. В МК таких уровней, как правило, нет, поэтому название "драйвер", как-то не совсем корректно.

Сообщение отредактировал mantech - Aug 5 2017, 06:52
Go to the top of the page
 
+Quote Post
ViKo
сообщение Aug 5 2017, 07:12
Сообщение #21


Универсальный солдатик
******

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



Цитата(mantech @ Aug 5 2017, 09:46) *
Драйвер - всегда была программа, являющаяся мостом между аппаратным устр-вом уровня ядра и программой уровня пользователя. В МК таких уровней, как правило, нет, поэтому название "драйвер", как-то не совсем корректно.

ОС часто есть. И приложение, использующее ОС. Вполне допустимо назвать "прокладку" между приложением и аппаратным ресурсом - драйвером. Можно и как-то иначе, не возражаю.
Go to the top of the page
 
+Quote Post
Шаманъ
сообщение Aug 5 2017, 11:05
Сообщение #22


Знающий
****

Группа: Участник
Сообщений: 758
Регистрация: 27-08-08
Пользователь №: 39 839



Цитата(linuxbergi @ Aug 4 2017, 09:59) *
Работаю над собственным драйвером для USB в STM32 , что-то мало материала. 99 % как скомпилировать готовый пример. Кто занимался аналогичной задачей? В принципе значительная часть уже сделана.

Если под драйвером понимать то, что в МК обеспечивает работу USB интерфейса, то у меня написано свое под STM32 (назовем USB стек+некая HAL прослойка, хотя с платформонезависимостью я особо не заморачивался). А в чем собственно вопрос?
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Aug 5 2017, 12:40
Сообщение #23


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



QUOTE (Эдди @ Aug 5 2017, 09:41) *
Я, конечно, понимаю, что есть два мнения - ваше и неправильное Но давайте вы будете придерживаться культуры общения на форуме и ограничите свои сообщения литературным языком.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
AlexandrY
сообщение Aug 5 2017, 13:01
Сообщение #24


Ally
******

Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050



Цитата(Шаманъ @ Aug 5 2017, 14:05) *
Если под драйвером понимать то, что в МК обеспечивает работу USB интерфейса, то у меня написано свое под STM32 (назовем USB стек+некая HAL прослойка, хотя с платформонезависимостью я особо не заморачивался). А в чем собственно вопрос?

Ну так автор наверно хочет узнать что же входит или должно входить в состав "своего"
Расскажите что у вас там "своё".
Хост или дивайс вы сделали, или может OTG?
Покажите список вызовов вашего API между аппаратурой и фреймворком. Это ж не секретно?
А также между фреймворком и классами.
Или если нет у вас такого деления на уровни, то расскажите почему.
Покажите список классов которые вы реализовали.
Покажите как сделан адаптер к RTOS, как реентерабельность обеспечена и т.д. и т.п.


Go to the top of the page
 
+Quote Post
prottoss
сообщение Aug 5 2017, 13:18
Сообщение #25


Гуру
******

Группа: Свой
Сообщений: 2 720
Регистрация: 24-03-05
Пользователь №: 3 659



Цитата(AlexandrY @ Aug 5 2017, 19:01) *
Покажите...

Нате, глумитесь.

Прикрепленные файлы
Прикрепленный файл  stm32_usbd.rar ( 1.29 килобайт ) Кол-во скачиваний: 79
 


--------------------
Go to the top of the page
 
+Quote Post
Шаманъ
сообщение Aug 6 2017, 09:21
Сообщение #26


Знающий
****

Группа: Участник
Сообщений: 758
Регистрация: 27-08-08
Пользователь №: 39 839



Цитата(AlexandrY @ Aug 5 2017, 16:01) *
Ну так автор наверно хочет узнать что же входит или должно входить в состав "своего"
Расскажите что у вас там "своё".
Хост или дивайс вы сделали, или может OTG?

У меня свое все sm.gif, включая RTOS, графику, математику и т.д. Касательно USB реализован USB device, host/OTG мне не интересен, потому не реализовывался.

Цитата
Покажите список вызовов вашего API между аппаратурой и фреймворком. Это ж не секретно?
А также между фреймворком и классами.
Или если нет у вас такого деления на уровни, то расскажите почему.
Покажите список классов которые вы реализовали.

Реализованы CDC и аудио устройство, может быть сделаю еще Mass Storage. Деление на уровни есть - нижний уровень общается непосредственно с аппаратурой, ядро реализует обработку базовых запросов и обеспечивает обработку запросов классами, классы взаимодействуют с первыми двумя уровнями, полная изоляция не делалась. Ставилась задача сделать не универсального монстра (таких хватает), а маленький модуль под конкретные задачи. В итоге три VCP и аудио устройство (стерео in/out) у меня занимают:
- базовый модуль (HAL+ядро) 5.2кбайт флеша
- CDC класс (виртуальный ком порт) - 1119байт
- Аудио класс - 456байт флеша

API между классами и стеком несколько нетрадиционен по части стандартных запросов, они реализованы через "карты" обработчиков (по типу того, как сделана обработка событий в MFC/ATL/WTL). Поэтому у меня нет аццких switchей sm.gif Также все дескрипторы сделаны через макросы, так что нет необходимости подсчитывать их длины, порядок байт и прочую ерунду. Например строковые дескрипторы:
Код
STRINGS_TABLE(Strings)
{
   LANGUAGES(0x409),
   STRING(u"Oleg xxxxxxxxx"),  /* 1 = MANUFACTURER */
   STRING(u"xxxxt"),    /* 2 = PRODUCT */
   STRING(u"0001"),        /* 3 = SERIAL */
   STRING(u"xxxx RX A CAT Port"),  /* 4 = INTERFACE_0*/
   STRING(u"xxxx RX B CAT Port"),  /* 5 = INTERFACE_2*/
   STRING(u"xxxx OTRSP Port"),      /* 6 = INTERFACE_4*/
   STRING(u"xxxx Audio"),           /* 7 = */
   STRING(u"xxxx RX Audio"),        /* 8 = RX Audio Terminal */
   STRING(u"xxxx TX Audio")         /* 9 = TX Audio Terminal */
};


И их обработка:
Код
//Standard Request Map
BEGIN_REQUEST_MAP(StandardRequestMap)
   .................
   ON_GET_STRING_DESCRIPTOR(Strings)                
   .................
END_REQUEST_MAP()


Разные языки поддерживаются в таком же стиле sm.gif

Также и с другими запросами (типа выбора интерфейса, параметров CDC, параметров аудиодевайса и т.д., а также стандартные запросы дискрипторов устройства, конфига и т.п.).

Цитата
Покажите как сделан адаптер к RTOS, как реентерабельность обеспечена и т.д. и т.п.

Стек изначально рассчитан работу с моей RTOS, потому никаких никаких адаптеров не делалось. Реентабельность обеспечена обычными средствами RTOS - критическими секциями, семафорами и т.д. Без RTOS он не работает, почему так я уже объяснил выше.

P.S. Странный у Вас стиль общения - хотя бы слово волшебное добавили wink.gif, а то "покажите"... а Вы заплатите, а я покажу wink.gif. Если есть конкретный вопрос, ну что-то там не едет или что-то конкретное интересует, то спрашивайте - чем смогу - помогу, а просто так время тратить желания нет.

Сообщение отредактировал Шаманъ - Aug 6 2017, 09:57
Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 7 2017, 08:03
Сообщение #27


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(Шаманъ @ Aug 6 2017, 12:21) *
У меня свое все sm.gif, включая RTOS, графику, математику и т.д. Касательно USB реализован USB device, host/OTG мне не интересен, потому не реализовывался.

У меня тоже - почти всё своё rolleyes.gif Кроме RTOS разве что. Хотя и к ней тоже порт - свой, ну ещё кой-какие её корректировки.
А так и USB-device (когда нужен) - свой, и TCP-стек - свой, и графические библиотеки - тоже свои, о математике и прочих фильтрах и не говорю... laughing.gif

Цитата(Шаманъ @ Aug 6 2017, 12:21) *
API между классами и стеком несколько нетрадиционен по части стандартных запросов, они реализованы через "карты" обработчиков (по типу того, как сделана обработка событий в MFC/ATL/WTL).

Это как я понимаю - массивы указателей на обработчики? Они у Вас во флешь или интерактивно в runtime-е в ОЗУ создаются?

Цитата(Шаманъ @ Aug 6 2017, 12:21) *
Поэтому у меня нет аццких switchей sm.gif

"Аццкие" switch-и если они действительно аццкие, компилятор как правило превращает в эти же самые массивы указателей. Если возможно.

Цитата(Шаманъ @ Aug 6 2017, 12:21) *
Также все дескрипторы сделаны через макросы, так что нет необходимости подсчитывать их длины, порядок байт и прочую ерунду. Например строковые дескрипторы:

У меня тоже так же сделано. Только имена макросов другие rolleyes.gif

Цитата(Шаманъ @ Aug 6 2017, 12:21) *
Реентабельность обеспечена обычными средствами RTOS - критическими секциями, семафорами и т.д. Без RTOS он не работает, почему так я уже объяснил выше.

Я иногда делаю на callback-ах такое взаимодействие. Например: в TCP-стеке так сделан вызов обработчиков протоколов, обработчиков событий для сокетов и т.п.
Поэтому оно никак не привязано к ОС (или к её отсутствию вовсе).
Go to the top of the page
 
+Quote Post
AlexandrY
сообщение Aug 7 2017, 10:11
Сообщение #28


Ally
******

Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050



Цитата(Шаманъ @ Aug 6 2017, 12:21) *
У меня свое все sm.gif, включая RTOS, графику, математику и т.д. Касательно USB реализован USB device, host/OTG мне не интересен, потому не реализовывался.

P.S. Странный у Вас стиль общения - хотя бы слово волшебное добавили wink.gif, а то "покажите"... а Вы заплатите, а я покажу wink.gif.

Видите, вы даже толком не можете описать "своё"
Потому что документацию на него не делали, а API ваше фрагментарное и архаичное. Небось и полного тестирования не делали, и даже профайлинга.
Такого недокументированного всеми забытого добра на гитхабе тоннами лежит.

Я бы TC предложил не делать "своё", а отрефакторить в пределах разумного какой-либо хорошо документированный USB фреймворк.
Вот допустим в MQX есть отличная документация и полные исходники USB стека для Device, Host(EHCI, KHCI), OTG. Имеет реализации всех востребованных классов HID, CDC, MSD, Audio, Video, Composite, RNDIS
Десятки примеров законченных приложений. Полная интеграция в RTOS, файловую систему, TCP стек и т.д.

А все что "полностью своё" это будет как правило очень примитивно с урезанной функциональностью, не документировано и непереносимо даже на уровне компиляторов.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 7 2017, 10:56
Сообщение #29


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(AlexandrY @ Aug 7 2017, 13:11) *
Я бы TC предложил не делать "своё", а отрефакторить в пределах разумного какой-либо хорошо документированный USB фреймворк.

Ага - вон тут в соседних темах товарищ на букву Д (не будем показывать пальцем wink.gif "рефакторит" всё и "рефакторит" чьи-то шедевры.
Да и так полно тут "рефакторщиков" которые только говнокодом из тырнета живут.
Чем больше смотришь всякие "примеры" тем меньше хочется их рефакторить или вообще как-то использовать. laughing.gif
Go to the top of the page
 
+Quote Post
Kabdim
сообщение Aug 7 2017, 12:34
Сообщение #30


Знающий
****

Группа: Свой
Сообщений: 558
Регистрация: 26-11-14
Из: Зеленоград
Пользователь №: 83 842



Цитата(AlexandrY @ Aug 7 2017, 13:11) *
Вот допустим в MQX

есть лицензия, которая запрещает использовать MQX где-то кроме фрискейловских процов.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 10:15
Рейтинг@Mail.ru


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