STM32 + FreeRTOS или Почему использование операционной системы оправдано даже в небольших проектах.

  Рет қаралды 65,082

Vladimir Medintsev

Vladimir Medintsev

4 жыл бұрын

В ролике рассказывается о различных подходах к программированию и реализации переключения задач на примере операционной системы FreeRTOS. Ролик является компиляцией из лекций прочитанных за последний год и рассказывает о том, как использование операционной системы упрощает устаревший подход к программированию.
Вышла книга по операционной системе FreeRTOS.
Видео о книге "FreeRTOS. Операционные системы микроконтроллеров" - • Книга "FreeRTOS. Опера...
Бумажная версия книги - electronics-krd.ru/magazin/pr...
Электронная версия книги - electronics-krd.ru/magazin/pr...
Оглавление книги - disk.yandex.ru/i/3ZKwKQTgQnlHoQ
Пример страниц - disk.yandex.ru/i/WCeD_CA3aMbiOQ
Группа в телеграмм - t.me/vladimir_medintsev
Код примеров из книги - disk.yandex.ru/d/Bqa2adpEZ3Mo6w
По вопросам сотрудничества - vmedintsev@yandex.ru

Пікірлер: 456
@alekseywolf5405
@alekseywolf5405 4 жыл бұрын
Как раз сейчас и решаем схожую задачу, используя RTOS: нужно быстро и часто опрашивать акселерометр, анализировать полученные данные, при этом управлять контроллером электропитания, что-то периодически (хотя бы 4 раза в секунду) обновлять на экранчике и при этом обмениваться с сервером информацией через очень медленную LoRa. Задачи слишком разного масштаба времени. Можно, конечно, самому городить семафоры, очереди и т.п., но если это уже всё сделано во FreeRTOS, то зачем изобретать велосипед?
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
Тем более, что прерывания тоже никто не отменял. Например, под опрос акселерометра сделать задачу с семафором, а открывать семафор -- в прерывании по окончании чтения.
@klondike2009
@klondike2009 4 жыл бұрын
Наконец-то доступно объяснили для чего нужен freertos😁 Спасибо за видео!
@iotmanager
@iotmanager 4 жыл бұрын
Спасибо большое за обзор! Очень многое стало яснее...
@jsonslim
@jsonslim 3 жыл бұрын
Десять благодарностей вам :)
@Techn0man1ac
@Techn0man1ac 4 жыл бұрын
Спасибо, да действительно удобный инструмент
@user-qe2ii8hv8k
@user-qe2ii8hv8k 3 жыл бұрын
Первые 3 минуты изучал пол часа.... магия раскрыта, БлагоДаря Вам!
@Nidvoraich
@Nidvoraich 4 жыл бұрын
Спасибо! Наипонятнейшее обоснование пользы использования ОС
@user-tz2zg3so2v
@user-tz2zg3so2v 4 жыл бұрын
Спасибо за доступную подачу информации. Пока сижу на AVR, делаю хобби-проекты. Крайний проект, после реализации на AVR, с помощью вашего канала планирую перевести на STM32. Еще раз спасибо и надеюсь что терпения на развитие канала Вам хватит, а в том что сумеете подать актуальную информацию в доступном ключе-у меня сомнений нет.
@sovchem1275
@sovchem1275 4 жыл бұрын
Хватай на али "stm32f103c8t6 board" + прогер-отлдачик "STLink2" за 100р. Качай CubeMX + Keil5, 2копиасты кода, 5 кликов мышки и проект готов :) А не заработает, врубай пошаговую отладку как белый человек и смотри где ступор
@user-bi4ve1id8y
@user-bi4ve1id8y 3 жыл бұрын
Спасибо! Это то что надо!
@stenzoautomatic
@stenzoautomatic 2 жыл бұрын
Спасибо, подчерпнул многое для себя, потихоньку отстраняюсь от ардуины
@lutsiuk5
@lutsiuk5 4 жыл бұрын
Спасибо вам , открыл для себя ОС - Ртосс !!
@chipunit
@chipunit 3 жыл бұрын
Спасибо, полезная информация
@user-np6lo3oh2i
@user-np6lo3oh2i 3 жыл бұрын
Ну я прямо не знаю сколько тонн лайков надо ставить))) Сам с FreeRTOS уже 5 лет работаю в коммерческих проекта и глубоко убежден, что что-то серьёзное сделать без оной можно но ОЧЕНЬ сложно.... А Вы так доходчиво народу объяснили что да как и по чём)))
@Wo_Wang
@Wo_Wang 3 жыл бұрын
Пожалуйста поподробнее: 2 таймера с выводом ШИМ и ввод-вывод по USB можно ли считать настолько сложной задачей, что без FreeRTOS не обойтись? :)
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
@@Wo_Wang есть разница между "не обойтись" и "некомфортно работать". Проще - с операционкой, как минимум протокол общения (поверх стека USB) я бы выделил в отдельный процесс.
@user-pc9wg4jt8l
@user-pc9wg4jt8l 4 жыл бұрын
"... код становится не сильно легко читаемым..." - Класс!!!!!
@user-tn3bw1wg8w
@user-tn3bw1wg8w 3 жыл бұрын
Классно 👍👍 спасибо вам за данное видео... Я когда кодил под Ардуино, пытался реализовать что-то подобное. Пытался написать ОС для микропроцессоров, но мои навыки программирования на чистом C не позволили сделать подобную ось (более 3 лет разрабатываю программы на C++/C#), а тут есть готовый велик, как говорится "садись и едь!".
@user-ei5sx6bo1z
@user-ei5sx6bo1z 4 жыл бұрын
Посыл конечно понятен. Не понятно только, почему по мнению автора есть только 2 альтернативы: последовательный код и freeRTOS(или любая другая RTOS). Для 99% задач которые делают на стмках, хватит банальной event-driven системы, в отдельных случаях вкупе со стейт машиной. И первое и второе пишется за 30 минут и занимает минимум места. RTOS это хорошо, но это чаще всего стрельба из пушки по воробьям. Не надо так.
@user-qe2ii8hv8k
@user-qe2ii8hv8k 3 жыл бұрын
Я новичок с 12-ти летним стажем...и половину слов не умею реализовывать"event-driven системы, в отдельных случаях вкупе со стейт"... в дальнейшем научусь, но ОС доступный инструмент int_32t, забивать гвозди в int_8t!
@vladimirshumilov7846
@vladimirshumilov7846 4 жыл бұрын
Владимир, спасибо огромное за ваши видео и цикл о freeRTOS особенно. А что ж Вы запись лекций по МК не публикуете?!
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
это же будет скука скучная. То, что хорошо на лекции для видео полный ужас. Представляете час про одно и то же. Я стараюсь делать видео не утомительными по длине.
@vladimirshumilov7846
@vladimirshumilov7846 4 жыл бұрын
Ну не знаю... Отдельным плейлистом... Воду отрезать или другой канал организовать...
@ImSashOk1977
@ImSashOk1977 4 жыл бұрын
Поддерживаю, очень хотелось бы посмотреть лекции по контроллерам
@parennasubaru
@parennasubaru 4 жыл бұрын
Отличный обзор. Прошу рассказать особенности работы виртуализации с dma , какие существую подходы для качественной работы
@user-qk1vf9cg9i
@user-qk1vf9cg9i 4 жыл бұрын
Кстати, Владимир, Ваше видео дало мне повод задуматься, что возможно нижеописанную мною проблему можно реализовать с помощью FreeRTOS. Вы мне дали повод для размышлений и изучения FREERTOS.
@user-tl8gk3dy3r
@user-tl8gk3dy3r 2 жыл бұрын
Спасибо за обзор.
@cezis666
@cezis666 3 жыл бұрын
Priviet Vladimir, I would say that your videos should be in everyone's who is interested in electronics's playlist. For me, you saved tons of hours with my personal projects. Recently I started working on FreeRTOS. I think you should keep on this topic more because there is a lot of applications where it can be used. Also logic behind RTOS is really suitable for industrial automation field where applications is more time critical. Keep on doing this! It's really helpful! Greeting's from Lithuania.
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
It’s a surprise for me that someone is watching these videos in Europe. Good luck to you.
@cezis666
@cezis666 3 жыл бұрын
@@VladimirMedintsev in my opinion all the most informative tutorials are made by Russians. I know Russian language too as we were the part of Russia so for me it is easier to understand. Anyway keep on doing these videos and maybe if you can more on freeRTOS :)
@user-mb1vl6qt1o
@user-mb1vl6qt1o 3 жыл бұрын
Братан! Пиши на русском языке, а то скоро вы его совсем забудете!
@wsws7939
@wsws7939 Жыл бұрын
Спасибо, я с первого раза понял преимущества ос. Тут получается хороший мултитрединг, каждый таск получает своё время. На интерапты хорошо и сразу можно отреагировать. Заказал себе микро контроллер, попробую...
@tvirkutsk5830
@tvirkutsk5830 2 жыл бұрын
Огромное спасибо!
@Ruslan-kk4pf
@Ruslan-kk4pf Жыл бұрын
В общем как многопоточное программирование в каком-нибудь дотнете, ясненько, спасибо👍
@user-gb6ok4vn4k
@user-gb6ok4vn4k Жыл бұрын
Контроллер это устройство состоящее из процессора, ОЗУ, Флеш памяти и прочее. Автор совершенно прав.
@alextiga8166
@alextiga8166 4 жыл бұрын
Процессор - это часть микроконтроллера, какой тут может быть спор вообще? никто же не спорит как правильно: компьютер или процессор, если процессор - это часть компьютера. микроконтроллер, помимо процессора, включает в себя постоянную память, оперативную память и прочую периферию, если бы он её не включал - был бы просто процессором, а так микроконтроллер. если речь про работу процессора - можно сказать и процессор и микроконтроллер, т.к. он этот самый процессор содержит. а вообще если человек спорит о таком - это говорит о его полной ограниченности, ведь важно не выбранное слово, а суть за ним стоящая, можно хоть хуёвиной его называть - лишь бы было понятно о чём речь!
@Vlad_4572
@Vlad_4572 4 жыл бұрын
Ты знаки препинания нахера ставишь? Спорим, что и без них все понятно?!
@alextiga8166
@alextiga8166 4 жыл бұрын
@@Vlad_4572 вот нет, без них далеко не всегда понятно. Казнить нельзя помиловать.
@Vlad_4572
@Vlad_4572 4 жыл бұрын
@@alextiga8166 , конечно, не всегда понятно, потому, и желательно следовать правилам и договорённостям, что бы не было неразберихи, а не называть всё вокруг хуёвинами. Его право называть микроконтроллер как он хочет, моё право, его поправить.
@alextiga8166
@alextiga8166 4 жыл бұрын
@@Vlad_4572 можно сказать "компьютер выполняет программу", а можно сказать то же самое про процессор. Можно сказать "автомобиль потребляет топливо", а можно сказать то же самое про двигатель. Так в чём проблема с "микроконтроллер/процессор выполняет инструкцию"? И то и то правда, процессор - часть контроллера. Никто не называет микроконтроллер процессором, но когда речь про часть микроконтроллера которая является arm процессором - и так и так правильно. Или я в чём-то ошибаюсь?
@Vlad_4572
@Vlad_4572 4 жыл бұрын
@@alextiga8166 , его дело, как и что называть, но автор не очень хорошо отозвался о тех кто его поправляет и привел пример комментария, типа: вот, смотрите написано же, что это процессор! Так никто и не спорит, что ЭТО(cortex-m) процессор/ядро. Но он упоминая устройство, говорит - процессор. Ты разницу понимаешь? В мануале всё чётко написано, что есть что, не пойму, в чём прикол подменять понятия?
@kardanium
@kardanium 4 жыл бұрын
Не понимаю тех, кто не хочет использовать FREERTOS, даже тогда, когда ситуация позволяет. Например, очередь - это очень крутая вещь. Можно в обработчике прерываний заталкивать туда данные и когда у задачи появится время, она их обработает, извлекая из очереди. Данные можно даже получить из неё не извлекая их из неё. Такое очень даже пригодится, когда на одни и те же данные нужно реагировать нескольким задачам. Еще круче получается с несколькими источниками данных для очереди. Например, одна задача окрашивает кнопки и помещает коды нажатых кнопок в очередь. Задача, отвечающая за работу с GUI получает их и обрабатывает. А теперь нам захотелось управлять GUI с помощью пакетов, приходящих с UART. Создаём задачу, которая принимает эти пакеты, извлекает из них команды и помещает их в эту же очередь. Так вот, сильно не напрягаясь и не затрагивая кода GUI, мы добавили еще один "пульт управления". И таких вот фишек там масса.
@sovchem1275
@sovchem1275 4 жыл бұрын
Я не хочу :) т.к. нашел куда круче RTOS2 RTX5 - родная ARM ось, ХАЛЯВНО включена в CMSIS2 !!! НЕ ОБРЕЗАННАЯ как все GNU "халявные" как FreeRTOS или ChibiOS хочешь полную и надежную ПЛАТИ! Открытый код!. портирована в IAR и GCC, работает не только в платном Keil5 в CMSIS2 есть шаблоны под потоки, таймера итп, подключается быстрее чем фриртос из куба. И к ней есть EventRecorder классная GUI консоль для отладки в Keil5 (галочки не забудь расставить, а то будет пустой график) Попробуй!
@leharuso
@leharuso 4 жыл бұрын
И я не хочу. Хватает TNeo. На код freertos как ни посмотрю, напоминает древние версии php...
@evgenevgen3011
@evgenevgen3011 4 жыл бұрын
И я не хочу. Дорог каждый байт памяти и каждый такт не лишний.
@user-bc7tm8vw9g
@user-bc7tm8vw9g 4 жыл бұрын
Андрей Батищев, говорят кольцевой буфер с этим отлично справляется))
@kardanium
@kardanium 4 жыл бұрын
@@user-bc7tm8vw9g Говорят много чего, но более мерзкого (в плане реализации), чем кольцевой буфер, я больше ничего не видел.
@cnjzyjdheckfy
@cnjzyjdheckfy 3 жыл бұрын
А ещё по прерыванию можно разбудить процесс,выполнить что то и усыпить ) Вообще более правильный вариант использования ос будет в комбинации всех доступных возможностей - ос+прерывания+дма
@user-tn3bw1wg8w
@user-tn3bw1wg8w 3 жыл бұрын
Без условно, использование операционной системы это грамотный подход👍
@user-dq2ci5ln5g
@user-dq2ci5ln5g 4 жыл бұрын
Примерно к такой же структуре программы я и пришел лет 20 назад, с таймерами и флажками, после 2-х летних изысканий. Задача: упаковочный автомат с 2-3-4 весовыми головками(CAS). Контроллер: fastwel CPU188-5. Правда, RTOS-ов тогда ещё не было... ☹ Гы: зато, ещё был MS-DOS 6.22, на этой плате! 🙂
@MrCrossRaccoon
@MrCrossRaccoon 4 жыл бұрын
спасибо
@user-xh3mk8fh6m
@user-xh3mk8fh6m 3 жыл бұрын
FreeRtos ОСРВ? В новой упаковке? Простите, с 90-х этим не занимался. Опять пришлось. Очень полезный канал.
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
RTOS и переводится как ОСРВ
@JingoBo
@JingoBo 4 жыл бұрын
Хах, всё то у вас просто получается, как в примерах аля "помигать светодиодом". А не забыли ли вы упомянуть про тонкости синхронизации данных (в которых нужно в принципе иметь хорошие скилы в многопоточном программировании), трудно отлавливаемые дедлоки, тонкости вызова функций ос в контексте прерываний? В небольших проектах freertos никак не оправдан, всегда можно сделать систему событий, софтовые таймеры и практически всегда работать в контексте главного цикла и не заботиться о синхронизации. Вот реально freertos может быть оправдан там где куча долгих синхронный операций, например работа с bsd сокетам (интерфейс которых эмулируется через lwip) - да тут код будет куда короче и стройнее чем работа асинхронно.
@VitaliyRu
@VitaliyRu 4 жыл бұрын
Золотые слова, вот и я о том же. Автор видимо никогда многоточечных приложений не писал. А дедлоки это еще и меньшая из бед(ее изобразить сложнее), хоть и очень противная. А вот логика работы, не так как задумал - легко. И не обязательно гонки переменных, просто выполнилось не в той последовательности или данные разрушила, или обратилась к полупустому указателю и так далее. Тут занимался оптимизации одного своего проекта. Нашел ошибку, а суммарный аптайм десятки лет(всех экземпляров), не проявлялось только потому, что ошибка четная, т.е. их 2, вторая маскирует первую... А критическую секцию туда нельзя, слишком "тяжелая" даже для сервачных процов, а тут МК, хи-хи. Весь рак мозга начинается когда нельзя сильно обкладывать в кретические секции, да если все ими обложить - нахрена козе баян(вообще многопоточность)
@user-bc7tm8vw9g
@user-bc7tm8vw9g 4 жыл бұрын
Виталий Алпатов, особенно пример с клавой доставил, да и уарт не лучше. А ведь так хорошо начиналось видео, все в одной задаче))
@user-cc9sn3bx4l
@user-cc9sn3bx4l 3 жыл бұрын
У меня в usart по дма иногда пропадает посылка на прием при использовании freertos, точно такой самый код, но без операционки, за ночь при тесте модбаса дал всего лишь две ошибки при 256000 кб/с, не знаю, плюс для реализации canopen нужно прерывание 1мс и проц stm32f407vet6 не может обслужить программу где одновременно используется 5 интерфесов и 200 кбайт кода...принял решение отказатся от операционки
@MikeNugget
@MikeNugget 4 жыл бұрын
Хорошее видео и объяснение доступное. А есть что-нибудь по работе с видео камерой?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Абсолютно непонятно что такое работа с видеокамерой.
@aleksandrzakutnyy4450
@aleksandrzakutnyy4450 4 жыл бұрын
актуально. нужно на практике показать сколько сьедает ОС ресурсов. считаю по умолчанию ОС много сьест. для меня актуальным примером будет приложение электропривода на 4-5 задач на 1-10 кГц. а так конечно ОС будет удобно использовать. а у тена с бочкой воды постоянная времени 20 минут или 1 час. с теном можно и виндос использовать ;)
@maksimlepel9594
@maksimlepel9594 3 жыл бұрын
Спасибо
@statstopfinish
@statstopfinish 4 жыл бұрын
С freertos вроде все удобней , но вот появилась задача управления шаговыми двигателями и обработкой энкодеров и тут столкнулся с затруднениями генерации импульсов для ШД и обработкой прерываний от энкодеров.
@vadimnikolaevich2886
@vadimnikolaevich2886 2 жыл бұрын
Здравствуйте! Интересует возможность адаптации примеров из CubeMX по работе с USB (CDC, CDC+MSD) под FreeRtos. Есть ли такие примеры в принципе? Или для примеров CubeMX лучше подходят машины состояний?
@VladimirMedintsev
@VladimirMedintsev 2 жыл бұрын
Пример не нужно адаптировать. Это не программирование получается а извращение. Пример необходимо изучать с целью научиться работать с технологией или периферией. Библиотеки USB от ST прекрасно работают с FreeRTOS.
@dmitryuser4327
@dmitryuser4327 4 жыл бұрын
Для многих задач и особенно для мелких контроллеров зачастую не нужен RTOS,достаточно Protothread
@zmeygavrilych
@zmeygavrilych 4 жыл бұрын
19:00 Забавный диалог... - При чём тут операционная система, когда нужны жёстко заданные тайминги? - При чём тут жёстко заданные тайминги, когда нужна операционная система???
@Beno_vu
@Beno_vu 3 жыл бұрын
Спасибо, очень полезную работу делаете, все чётко по полочкам. Не обращайте внимание на этих придурковатых умников, это все на что способен их мозг))
@merzott
@merzott 4 жыл бұрын
Было бы интересно увидеть видео разбора крупной программы, как в ней использовался FREERTOS и какие опасные моменты нужно учитывать. Вроде штука интересная, но как и где ее стоит применять все равно не очень понятно. В маленьких программах ради удобства - притянуто, маленькую программу как ни пиши - проблем нет никаких. В больших - можно кучу не отлавливаемых интересностей словить - стремно использовать. Вообще контент на канале достойный. +++
@PopryagaMike
@PopryagaMike 4 жыл бұрын
вот как раз операционная систем и нужна для отлова интересностей. Операционная система имеет средства контроля за работой процессов и имеет средства управления памятью. При использовании ОС есть недостатки - это потеря в скорости реакции и использование большего объема памяти. За это програмист получает возможность управления потоками, профилирование, отладку запущеной системы.
@slavaglow6933
@slavaglow6933 4 жыл бұрын
Спасибо за ваши видео. Могли бы вы дать информацию, где описывается FreeRTOS доступным языком? Хочется узнать по подробнее.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
у них на сайте freertos. org
@uno7802
@uno7802 4 жыл бұрын
microsin.net/programming/arm/freertos-part1.html
@denwerxampp4035
@denwerxampp4035 4 жыл бұрын
ув. автор, планируете ли обзор других RTOS систем? Напр. Mbed OS ?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Mbed OS точно не будет. Мы ее не используем внутри своей команды, не рекомендуем, а соответственно и обзора на нее не предвидится.
@NeussMsk
@NeussMsk 4 жыл бұрын
Как вы в keil включили всплывающие подсказки? (выпадающие списки в редакторе у курсора)
@user-qe2ii8hv8k
@user-qe2ii8hv8k 3 жыл бұрын
Та же проблема с авто подстановками!???
@user-mz8np1jz6h
@user-mz8np1jz6h 4 жыл бұрын
Расскажите о работе прерываний с ОС, они работают асинхронно от нее и используют стек текущей задачи и требуется выполнять дополнительные телодвижения в обработчике прерываний?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Прерывания используются точно так же как и без ОС. Единственное, для управления некоторыми функциями ОС из обработчиков прерываний надо вызывать специальные функции. Но это не сложно.
@user-bc7tm8vw9g
@user-bc7tm8vw9g 4 жыл бұрын
Vladimir Medintsev, про приоритет не сказали..
@user-sn1rx9xr3l
@user-sn1rx9xr3l 4 жыл бұрын
Классная ос.
@user-le7cf1qk8l
@user-le7cf1qk8l 4 жыл бұрын
Скажите пожалуйста еще про другие ОС например riot-os
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
А я все искал, кто же меня просил про другие ОС видео сделать. :-) выполнено.
@SerB-Radio
@SerB-Radio Жыл бұрын
Доброго дня. Спасибо Вам большое за познавательные видео. Только начинаю разбираться с Freertos и хотелось бы немного Ваше консультации. Пытаюсь большой проект адаптировать под ОС. Вот подсоединил через куб ОС, раскидал легкие задачи по приоритетам и таймигнам вызова - все очень хорошо, функционал заработал. И вот у меня есть большая функция расчетов, сей кусок кода занимает около 30кБ. Естественно, когда я эту функцию кладу в задачу у меня все вешается. Как мне его положить в Tasks? или вообще что мне делать? Расширять размер стека для данной задачи, как я понимаю? Спасибо.
@VladimirMedintsev
@VladimirMedintsev Жыл бұрын
На канале ещё будут видеоролики по операционной системе freeRTOS. Я постараюсь частично ответить на эти вопросы.
@SerB-Radio
@SerB-Radio Жыл бұрын
@@VladimirMedintsev Спасибо Вам большое
@user-ed9wd8ei1o
@user-ed9wd8ei1o 3 жыл бұрын
Подскажите, по поводу объёма кода в обработчике прерываний, какие есть ограничения или правила?
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Правило одно вы должны провести внутри обработчика как можно меньше времени. А это значит не делать задержек, не использовать таймауты. Чем быстрее выйдите из обработчика, тем лучше.
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
@astrahard Нечаев Вы сами читаете что пишете? Я сказал человеку, что в обработчике прерывания необходимо проводить минимум времени, это является безусловным требованием. Т.к. в любой момент может наступить новое прерывание от любого другого источника. Что в конечном итоге приведет к переполнению стека. Отсюда логично и требование не использовать таймаут и задержки в обработчике прерывания. Более того, это не мое личное придуманное мнение. Ровно то же самое можно прочитать в документации на FreeRTOS и также во всех известных мне учебниках программирования. Более того обработчики прерывания в пределах одного уровня приоритета друг друга не вытесняют. Так что осторожнее с оценками, пожалуйста.
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
@astrahard Нечаев Прежде всего я опираюсь на написанное в документации по FreeRTOS, а там прямо указано что обработчик должен быть как можно короче по времени, чтобы прерывания не накладывались друг на друга. Тут без разницы у вас микроконтроллер или большой компьютер. Система прерываний она не меняет своего смысла. Во-вторых я руководствуюсь написанным на сайте Cortex это как бы разработчик ядра микроконтроллеров. Ну а в третьих, programming manual на наши микроконтроллеры. Но если все это не заслуживающие внимания документы, то не проблема снимаю шляпу. Вы видимо великий специалист и знаток вопроса. Даже спорить не буду.
@nangelo0
@nangelo0 4 жыл бұрын
Как сильно отличаются понятия "сложный код" для контроллеров/процессоров и для высокоуровневых приложений для серверов/десктопов и т.д.
@xealit
@xealit 2 жыл бұрын
Насчёт тайминга действительно это просто недопонимание. На то она и “real time” ОСь, что её цель именно выдерживать детерминированный тайминг задач. Нужно только указывать им приоритеты и будет тайминг что надо. На ютубе есть видео с презентацией FreeRTOS от автора - там он отлично это поясняет. Конечно, могут быть какие-то другие причины не использовать RTOS. В каких-то супер-критических и супер-embedded задачах может будет необходим 1 контроллер на 1 задачу (или 1 PLC на задачу, если это совсем что-то суровое). И, конечно, если ваш код не сложен и не предвидится его развитие, то действительно нет смысла заранее заморачиваться с ОСью. Но тайминг это как раз не проблема для RTOS, это её работа 🙂
@agentsmit09
@agentsmit09 Жыл бұрын
Контроллеры разные бывают. Для ATmega 8 или 328 такая ОС мне кажется перебор, а вот для ESP32 необходимо использовать ОС.
@user-vb4pj2so5o
@user-vb4pj2so5o 4 жыл бұрын
Пожалуй без разбора примера и указаний достоинств работы с FreeRTOS (например с приемом кода пульта и включением чего нибудь) Было бы лучшим аргументом.
@iotmanager
@iotmanager 4 жыл бұрын
Вот такой вопрос. Если представить что у нас есть 2 задачи freertos с одинаковым значением vtaskdelay допустим 100 мс для обоих. То при таком раскраде как эти две задачи будут работать друг относительно друга? Если речь идет о автоматическом распределении процессорного времени то будет вызываться перавая задача а через 50 милисикунд вторая а потом еще через 50 снова первая. Или же как то иначе? Какую логику преоритезации задач несет в себе это "автоматическое распределение процессорного времени"?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
vtaskdelay определяет какое время диспетчер задач не должен передавать управление данной задаче. если у вас 2 задачи и они обе через osDelay указали что их не беспокоить 50 миллисекунд, то ближайшие 50 секунд будет выполняться только idle, а потом опять задачи 1 и 2 по очереди.
@sergbo3114
@sergbo3114 4 жыл бұрын
Да. Почти так. Но еще нужно учитывать что эти задачи будут делать. Если внутри есть полезная нагрузка отличная по тактам от другой, то циклы будут перескакивать. И отдельный вопрос как они были запущены одновременно или например 1 сразу вторая через 50 мс. Если сразу то так и будет t1 0, 100, 200, 300, 400 t2 0,100,200,400. Если с задержкой в 50 мс то t1 0,100,200,300 t2 50,150,250,350. А вот если внутри задачи t1 будет работы на 25 мс, а в t2 на 10мс то будет следующая картина при условии что ос вытесняющая. t1 0-35, 135-160, 260-285 t2 0-20,120-130,230-240 и т.д. Т.е. в тех местах где активная работа обеих потоков задачи выполняются (условно)одновременно но в два раза медленнее по времени. Отсюда вывод. Через какой-то промежуток времени задача 2 сделает на какое-то колличество циклов больше, потому как нагрузки у неё меньше.
@olejick4043
@olejick4043 4 жыл бұрын
Согласен. Я на асме пописываю для АВР ок, как попробовал кооперативную РТОС (от di Halt,) так в "суперцикл" и не тянет. В разы проще и в написании и в отладке
@user-zh6ps1ub8n
@user-zh6ps1ub8n 3 жыл бұрын
Спасибо за доклад. Очень долго заглядываюсь на FreeRTOS. Понимаю, что на вопрос тяжело ответить однозначно из-за весьма размытых границ и всё же. Есть ли у вас какие-то свои критерии по которым вы решаете стоит ставить FreeRTOS или не стоит ? Буду очень благодарен конкретным примерам . Заранее спасибо
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Вот сидите вы такой и с философским (обязательное условие) взглядом обращенным на облака обдумываете свою программу. Так вот если она рисуется вами как единая задача, то применять FreeRTOS НЕ НАДО. А вот если у вас в голове вырисовываются несколько процессов или подзадач, то применять FreeRTOS НАДО.
@user-zh6ps1ub8n
@user-zh6ps1ub8n 3 жыл бұрын
@@VladimirMedintsev Спасибо за ответ )
@ersafap
@ersafap 3 жыл бұрын
У меня принцип такой: если оперативы в контроллере 8кб и более, значит надо. Если 4кб - может быть. Все равно со временем нагородишь самодельный ее аналог худшего качества.
@Wo_Wang
@Wo_Wang 3 жыл бұрын
Ага, вот и я думаю: а зачем в микроконтроллере нужна многозадачность? )
@ersafap
@ersafap 3 жыл бұрын
@@Wo_Wang при разработках важно правильно понимать что ты хочешь сделать и правильно ставить задачу. Мне не нужна многозадачность, мне нужно изолирование друг от друга потоков кода, выполняющих разные задачи в устройстве, мне нужна возможность легко тасовать эти потоки, не нарушая работу всего остального, мне нужно чтобы программа оставалась линейной и простой так долго, как это возможно. ОС дает мне все это. Я уже сталкивался при разработках с ситуациями, когда городил жуткий код чтобы в итоге он сделал тоже самое, что доступно из коробки под freertos. Самый ценный ресурс - время. Мегагерцев и мегабайтов полно, времени, обычно - нет.
@oleholeynikov8659
@oleholeynikov8659 4 жыл бұрын
Владимир, здравствуйте! Спасибо за видео, пробую работать с ОС в своем проекте. Сразу возник вопрос о определении размера стека для задач. Возможно вопрос новичковый, но было бы круто выделить немного времени в видео о стеке, логике расчета, методах оценки ресурсов МК в отладчике (как с РТОС, так и без нее).
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Так вроде же есть видео про стек FreeRTOS. Я там даже на примере показывал как это делать.
@oleholeynikov8659
@oleholeynikov8659 4 жыл бұрын
@@VladimirMedintsev точно! я как-то проглядел. Спасибо
@oleholeynikov8659
@oleholeynikov8659 4 жыл бұрын
@@VladimirMedintsev Всё пересмотрел по FreeRTOS из плейлиста. Получилось запустить, почитать расход стека, все очень удобно. Эти видео - какой-то праздник! Еще раз спасибо.
@user-hm8yh7mz8u
@user-hm8yh7mz8u 4 жыл бұрын
А эта freeRtos под капотом что-то вроде невытесняющей многозадачности с прерываниями по таймеру реализует, правильно понял? Т.е. если в какой-то таске, например, что-то зависло, вся система зависнет, как оно в мсдос было? Или там как в посикс с fork() / еxec(), таблицей процессов и т.д.?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
зависнет только одна задача. этот факт легко определяется и вы можете ее перезапустить.
@user-hm8yh7mz8u
@user-hm8yh7mz8u 4 жыл бұрын
@@VladimirMedintsev вау, это круто, учитывая такое небогатое ресурсами окружение.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
@@user-hm8yh7mz8u В видео kzbin.info/www/bejne/rYWuYmR_edWabdU я рассказываю как определять загрузку процессора задачами, этот алгоритм можно использовать и для определения зависшей задачи. Ну или можно проще. Можно чтобы задача сама обновляла какой-нибудь флаг и тогда уже можно принимать меры к ее перезагрузке или лечению.
@anatoliygavrilov958
@anatoliygavrilov958 4 жыл бұрын
В FreeRTOS много разных настроек, в то числе и тип многозадачности. По умолчанию он вытесняющий, ток что зависания всей системы не будет.
@Rimmdp
@Rimmdp 4 жыл бұрын
Может работать как в вытеснящем, так и в кооперативном режиме, плюс в смешанном режиме.
@user-gr5qb2iv8w
@user-gr5qb2iv8w 2 жыл бұрын
уважаемый автор,извиняюсь за то,что не по теме,но : у вас есть курс по программированию stm32 для начинающих? или может посоветуете, где на ваш взгляд это доступно изложено.
@VladimirMedintsev
@VladimirMedintsev 2 жыл бұрын
go.redav.online/198c03d37cf84410 Это моя программа обучения.
@user-xs6mu8bc9q
@user-xs6mu8bc9q 9 ай бұрын
​@@VladimirMedintsevда ,но на курсе не написано stm32,а только ардуино.Так как бы хочется четко понять есть STM 32 курс или нет и сколько занятий?
@VladimirMedintsev
@VladimirMedintsev 9 ай бұрын
@@user-xs6mu8bc9q вот очень и очень хорошая программа дпо.фркт.рф/sse совместно с МФТИ. И есть диплом
@zjohnes
@zjohnes 4 жыл бұрын
При рассказе последовательности загрузки МК, Вы еще пропустили что будет с начало вызвана функция, так сказать инициализации языка С, называется она в Вашем случае __main(), а вот она уже затем вызовет пользовательскую функцию main(). На ББ в этой функции "__main()" как правило происходит статическая инициализация данных и инициализация стандартной библиотеки С ...... для МК скорее всего аналогично.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
и это как-то влияет на запуск программы? о всех мелочах рассказывать это видео бесконечным получится.
@zjohnes
@zjohnes 4 жыл бұрын
@@VladimirMedintsev нет конечно, просто Вы подробно начали рассказывать про цепочку вызовов, и при виде ассемблеровского вызова функи __main() в Вашем видео, почему то сразу перешли на main(), а мне просто это бросилось в глаза )) и я решил поделится с Вами инфой об этом. Я ни в коем случае не хотел вмешиваться в Ваш рассказ, а просто восполнить для Вас данный пробел. Но если Вы и так знали про это - то и отлично, извините меня за это программистическое занудство ))
@OlegKotchetov
@OlegKotchetov 4 жыл бұрын
@@VladimirMedintsev Влияет непосредственно, если использовать для инициализации статических переменных вызовы каких-либо функций, самое распространённое - при статическом создании объектов С++ вызываются конструкторы классов. Иной раз по невнимательности можно схлопотать HardFault не добравшись до точки входа main(). По-моему инициализация - достаточно важный вопрос, чтобы его упомянуть, хотя бы одним предложением.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
@@OlegKotchetov Можете хоть один, ну хоть вшивенький пример инициализации хоть чего-нибудь привести чтобы схлопотать HardFault не долетая до main. Ну хоть какой - нибудь примерчик.
@OlegKotchetov
@OlegKotchetov 4 жыл бұрын
@@VladimirMedintsev Пожалуйста: 1. Слепить класс, у которого в конструкторе присутствует обращение к периферии через HAL, надеясь, что создавать его объекты будут всегда _после_ инициализации HAL. 2. В угаре очередного горящего дедлайна вспомнить, что когда-то был такой отличный класс, который делал то, что нужно, скопировать его в проект и воткнуть статическое создание экземпляра, что-нть типа extern I2C_HandleTypeDef hi2c1; static I2C_SuperSensor sensor = I2C_SuperSensor(&hi2c1); А потом удивлённо смотреть в дебаггере на немедленный HardFault при запуске. Да, разумеется, это адский быдлокод и тот, кто так сделал - сам дурак. Но поверьте, ситуации бывают разные. Иногда приходится сознательно быдлокодить, когда на постройку башни из резной слоновой кости нет времени, задача копеечная и требуется чтобы результат сработал раз-другой и дальше станент не нужен. Да лучше за такое не браться, но иногда и отказать нельзя. Если Вы занимаетесь этим делом на потоке, наверняка сами прекрасно понимаете. А может новичок подобное слепит по неопытности и потом мозг сломает, пытаясь понять, что, блин, происходит :) Вот для последних как раз помянуть про фазу инициализации статики - методически оправдано полностью имхо. А то ведь зачастую смотрят на компилятор, как на чёрный ящик: на входе исходник, на выходе - светодиод моргает, а что там между - черт его знает...
@remontlive
@remontlive 4 жыл бұрын
Пожалуйста, пожалуйста, пожалуйста ответьте на вопрос, а то я не понял: если у нас, например, всего 5 задач в ОС, на каждую проц тратит 1 ms, что происходит на 6-ю ms, он переходит на первую задачу или ждет 995 ms, потом переходит на 1ю задачу?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
на первую задачу, если она не в простое. подробно тут - kzbin.info/www/bejne/ramWXqJ7iNyrla8
@megannnn98
@megannnn98 4 жыл бұрын
Вставлю свои пять копеек, 1) Там где вы вставили switch case в while(1), и говорили, что нужно долго дожидаться пока Program Counter дойдет до нужной обработки после прерывания, но вы же можете в этом прерывании ставить флаг, который скажет, в какой из кейсов переходить после прерывания и обработка после прерывания будет быстрее. Во freertos же надо придется дожидаться когда PC дойдет до задачи которая должна обработать после прерывания. 2) Для процессоров типа stm32F0 , на мой взгляд, freeRTOS жрет много оперативки, в отличии от тех же конечных автоматов, где 2 байта идут на запоминание состояния где мы были. Спасибо за качественный контент.
@Korbomen
@Korbomen Жыл бұрын
Нельзя в прерывания засовывать большие куски кода, а как на счёт работы usb?
@TK-wh6lf
@TK-wh6lf Жыл бұрын
Обрабатывать в задаче используя семафоры
@kardanium
@kardanium 3 жыл бұрын
Я сейчас пишу программу, так уж вышло, для AVR архитектуры (Atmega168) и меня эта туева хуча конечных автоматов уже успела достать. На I2C два устройства - делай аатомат. UART - делай автомат. Опрос клавиатуры и генерация событий - делай гребаный автомат. Короче, для всего, что может впустую застопорить главный цикл - нужен автомат. Я настолько упоролся этими автоматами, что даже для записи в EEPROM хотел его слепить, но остановило то, что запись ест немного тактов, а транзакции туда короткие. Погоня за быстродействием быстро сожрала половину ПЗУ. С RTOS все это безобразие было бы гораздо проще.
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
Есть порт FreeRTOS под AVR, если не ошибаюсь.
@kardanium
@kardanium 3 жыл бұрын
@@DmitryKandiner Проект уже окончен. В нем обширный GUI. Места, возможно, не хватит. Но можно попробовать. Ибо FreeRTOS туда прямо просится. На I2C шине сидит кучка периферии, активно задействуется UART и GUI хочется без тормозов. Памяти всё это сожрало намеренно (13 КБ ПЗУ и 400 байт ОЗУ), но при этом нет тормозов, камень всё успевает и код пригоден для дальнейших доработок и дополнений (модульный принцип). Остался килобайт на маневры в будущем и ещё два заняты бутлодером. И самое смешное - для оптимизации объема, некоторым функциям пришлось ставить атрибут no_inline. На производительности это не сказалось практически никак, но сэкономило целый килобайт ПЗУ. Чем глубже лезешь, тем больше сюрпризов от компилятора AVR GCC. Даже в таких вещах, как макросы и константные числовве выражения. Они все имеют тип int, который размером 2 байта в AVR. И когда выполняешь операции над переменными int32 и константами, компилятор без предупреждения приводит int32 к int (16), что у неподготовленного адепта Механикус может вызвать чувство вины перед Омниссией. 🤣
@squidyPet
@squidyPet 2 жыл бұрын
@@kardanium рекомендую посмотреть на st. Все что вы описали делается с использованием директ мемори аксесс и вообще не жрет ресурсы. А граф интерф делать на главном камне некашерно даже на неспециальнвх st. Есть же готовые с управлением по usart
@ravil6018
@ravil6018 2 жыл бұрын
Здравствуйте! Мне очень интересны автоматы, я сам на них пишу, но пока очень не опытен в этом деле. Можете ли вы поделиться кодом проекта, чисто в образовательных целях?
@gimeron-db
@gimeron-db 4 жыл бұрын
Всё пытаюсь понять, как именно происходит переключение контекста подпрограмм. На ум приходит только подмена адреса возврата при выходе из обработчика прерывания (как это делалось некоторыми утилитами в DOS). Т.е во время работы одной программы срабатывает прерывание, диспетчер (в обработчике прерывания) сохраняет контекст и адрес возврата текущей программы, восстанавливает контекст и адрес следующей и "возвращает" управление. При следующем прерывании вторая программа меняется на третью и т.д. Хорошо, если памяти у контролёра хватит, чтобы хранить контексты всех программ.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Наверное причина в том, что вы пытаетесь мыслить категориями привычными для IBM PC совместимых компьютеров. Вы и написали - "программ". По факту же мы имеем дело с небольшими задачами выполняющими те или иные функции. Разумеется памяти им хватит. На канале достаточно роликов по этой операционной системе, даже есть фрагмент где показывается как вывести в консоль реальную загрузку и стека и кучи. Можете посмотреть, взять там несколько строк кода и даже попробовать.
@alximedkylibin3059
@alximedkylibin3059 4 жыл бұрын
Всем привет ! Уж посмотрел Я и почитал коменты , и вот вопрос ко всем знающим . Если есть PIC . AVR. STM и нужна программа измерять температуру , вкл или выключать пару реле, дисплей , пусть будет . 1 - сколько займет памяти эта прога ? 2 - для таких PIC . AVR. STM задач , есть ли предпочтение , что лучше ? 3 - так что выбрать PIC . AVR. STM ?
@iwh1te340
@iwh1te340 4 жыл бұрын
Я бы выбрал stm32f042 в корпусе tssop-20. Влезет в 16 кило. (Сейчас делаю что-то анологичное, dht22, вентиялтор на управлении ШИМ, передача данных на nrf24). Все на HAL, весит около 10кб (может чуть больше), с оптимизаций O2. Приемная сторона, экран ST7735+NRF24, влезает в 16 кило(оптимизация по O-size). И ко всему использую stmcubeide
@anatoliygavrilov958
@anatoliygavrilov958 4 жыл бұрын
Здравствуйте! Данную задачу можно решить на любом МК и разными способами, так что размер занимаемой памяти оценить сложно. Лучшем будет МК с которым знакомы. Если ни с чем не знакомы, то начните с Arduino. Самой простой под Вашу задачу будет достаточно.
@user-mv9tc7xq4h
@user-mv9tc7xq4h 3 жыл бұрын
В целом верно, но только примеры выбраны неудачно. Из-за этого объяснения выглядят не очень убедительно. Нельзя объяснять преимущества многопоточности на примере ввода с "клавиатуры" (а в видео это основной пример), поскольку она реализуется исключительно на прерываниях. Не считая конечно новичков, кому кажется проще опрашивать в цикле :) Лучше бы объяснили на реальном примере. Вот у меня был проект на AtMega128. На дисплей 128x128 выводится информация из нескольких источников: от часов, от барометра, от термометра, от таймера, от "клавиатуры" и нескольких аварийных кнопок и даже от радио. Оказалось, что удобнее всего реализовать посредством эмуляции многопоточности, когда "менеджер задач" поочередно вызывает "потоки" (по одному на каждый источник), а те, выполнив какую-то часть работы, передают управление дальше. Причем, задачи получения данных от датчиков и вывод на экран обработанных данных были разделены. Единственно, что те же кнопки использовали прерывания, запуская "поток", выводящий на дисплей информацию и проигрывая определенный сигнал. Вот где преимущества многопоточности облегчают написание кода, его отладку и читабельность. Думаю и у Вас нашелся бы подходящий пример из жизни.
@lmarloe
@lmarloe 4 жыл бұрын
Вы с RIOT работали? Что думаете?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Мне не подходит.
@timslabchannel6650
@timslabchannel6650 4 жыл бұрын
Riot OS пробовали использовать?
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Пробовали, для наших проектов она не подходит.
@agentsmit09
@agentsmit09 Жыл бұрын
На ESP32 хотел изначально использовать или библиотеки Arduino, или напрямую язык Си, но как выяснилось что компания Espressif в своих библиотеках всегда использует FreeRTOS. Так зачем мне изобретать то что уже и так эффективно работает. Тем более что для 2-х ядерного процессора лучше использовать ОС, которая упрощает работу с железом.
@mvxburov
@mvxburov Жыл бұрын
есть еще nanoFramework от Майкрософт, он тоже поверх какой-то ОС работает, но программировать можно на C#. Для дотнетчиков это просто песня)
@agentsmit09
@agentsmit09 Жыл бұрын
@@mvxburov Мне почему-то не удалось его завести на Visual Studio 2019 и опробовать. А так бы сказал что он компилирует, ассемблерные выходные листинги я отлично понимаю.
@VAscetic
@VAscetic 3 жыл бұрын
Так. Созрел глупый вопрос: А при переключении на другую задачу, значения переменных и состояние выполняемой сохраняется? Судя по тому, что Вы упомянули отдельный стек, вроде ответ должен быть да. Но можно для деревянных уточнить ))
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Да, сохраняется.
@VAscetic
@VAscetic 3 жыл бұрын
@@VladimirMedintsev Спасибо, очень помогли понять в каком направлении копать. Столкнулся с такой необходимостью, когда не плохо бы, чтобы одновременно выполнялись несколько задач, параллельно так сказать. Понятно было, что решение где-то есть.. но где... ))
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
@@VAscetic Каждой задаче под FreeRTOS выделяется собственный стек, одна и таже функция может использоваться для нескольких одинаковых задач (например, для обработки портокола на нескольких последовательных портах одновременно*), и стек у каждой задачи всё равно свой. Статические переменные работают как обычно. * Не совсем одновременно, конечно, а под управлением диспетчера задач.
@VAscetic
@VAscetic 3 жыл бұрын
@@DmitryKandiner Ага, спасибо, я в целом понял концепт. По сути, очень сильно такого плана решение мне требовалось пока 1 раз, и то более менее обошёлся. Когда с ETH учил контроллер работать, для поддержания одновременно нескольких активных соединений TCP по разным портам. А так, в большинстве случаев, достаточно стандартного набора прерываний, тем более если в контроллере есть DMA. Ну или я ещё в сложные задачи не залез :)
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
@@VAscetic как вариант -- построение веб сервера. Один процесс только принимает новые соединения, и запускает дочерние процессы на каждый запрос. А запросы, в свою очередь, обрабатываются каждый своим экземпляром одного и того же кода (важно не полагаться на статические переменные -- они общие для всех). По окончании обработки процесс закрывает соединение и самоубивается.
@DmitriNesterov
@DmitriNesterov 4 жыл бұрын
14:50 - лучший способ исправления опечаток! 😁👍 Спасибо за отличный урок!
@user-qe2ii8hv8k
@user-qe2ii8hv8k 3 жыл бұрын
! о!; 14минута(прошло час) скелетное программирование, кооперативная многозадачность >>> OS...ОЧЕНЬ ДОХОДЧИВО!
@namernum5692
@namernum5692 3 жыл бұрын
Контроллер обычно приемняется в адачах с жестко заданными таймингами и последовательностью переключения,а тут совершенно непонятно что и как работает
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Если вам нужны "жестко заданные тайминги" то возьмите таймер и он вам очень точно измерит временные интервалы. Что касается последовательности переключения, то совсем не все задачи так примитивны как вы пытаетесь это представить. Есть весьма сложные алгоритмы. И в этих случаях применение операционной системы экономит много времени как на разработку так и на отладку. Более того, использование FreeRTOS весьма заметно повышает общую живучесть системы в целом.
@romandosaev9860
@romandosaev9860 3 жыл бұрын
В где вы читаете лекции про freeRTOS, если не секрет?
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Да нет не секрет. Я частным образом организую группы и с ними занимаюсь.
@VAscetic
@VAscetic 3 жыл бұрын
@@VladimirMedintsev Новому подписчику не хватает данных о локации в Вашем ответе ;)
@ozn_
@ozn_ 4 жыл бұрын
А разве приоритет прерываний не должен быть меньше приоритета обработчика задач? А вообще прикольно , давайте больше видео про ос!
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
честно говоря не помню. что-то было на эту тему у них в документации. потом посмотрю.
@ihanick
@ihanick 4 жыл бұрын
приоритет прерывания может быть выше чем приоритет обработчика задач, но такое прерывание не может вызывать функции freertos напрямую
@Siliverst
@Siliverst 4 жыл бұрын
Если квант времени у ОС 1мс, как быть в случае, когда имеется задача, которую нужо успевать обрабатывать за время от 1мс? Эта функция или реакция на внешнее воздействие, или она в принципе должна вызываться с периодом около 1мс.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
дык таймеры и прерывания.
@Siliverst
@Siliverst 4 жыл бұрын
@@VladimirMedintsev Т.е. имеется ввиду совмещение двух подходов? Задачи не требовательные к времени отклика - крутим в RTOS а задачи которым нужно обеспечить быстродействие пишем по старинке? Я в своё время писал много вещей у котрых большинство функций не требовательно ко времени, т.е. их можно выполнять с периодом 100мс просто по очереди. Но есть обработка внутренней логики которую нужно успеть за 1mc. Ещё есть фильтры для которых важно тактирование с постоянным периодом. Есть внешние прерывания. Есть UART в который нужно ответить желательно за 1-2мс. Я написал свой диспетчер не требовательных к времени отклика задач, и да, согласен с Вами, написание таких вещей тянет за собою много времени. Но всё равно остаётся ещё много задач, для которых время отклика важно. И всё это крутится в mainloop и да, на pipelined 8051 8МГц loop time получается около 1мс. Меня не отпускает мысль, что при использовании RTOS я бы мог обрабатывать быстрые задачи ещё быстрее... Это возможно?
@megannnn98
@megannnn98 4 жыл бұрын
@@Siliverst Из прерывания можно переключать контекст на более приоритетный процесс.
@astarkmn
@astarkmn 4 жыл бұрын
А почему бесконечные циклы в задачах выполнены через for? В этом есть какой-то сакральный смысл?
@Rimmdp
@Rimmdp 4 жыл бұрын
Нет. Это дань моде. По сути одно и тоже, что и while
@user-qk1vf9cg9i
@user-qk1vf9cg9i 4 жыл бұрын
Необходимо указать важный момент. Если Вы пишете программу , НАПРИМЕР, передачи по радиоканалу потокового аудио, то FreeRTOS, не справится с подобными задачами и необходимо написать программу в классическом режиме последовательный код с прерывателями ит.п., подсчитывая в дебаггере каждый такт,, чтобы соблюсти точные временные слоты оцифровки и передачи пакета с накопленными сэмплами. . Поясню. Вы указали, что квант времени отводимый FreRTOS 1 ms. Я в программе каждые 125 мкс оцифровываю внутренним АЦП аналоговую речь, попутно накапливаю оцифрованные сэмплы во внутреннем буфере ОЗУ порядка 300 байт, при заполнении буфера я передаю его по SPI в CC1100 (радиопередатчик) . При употреблении FRERTOS у меня все поплывет, особенно в программе приемника , теорема Котельникова нарушится, пакеты с цифровыми сэмплами (речью) будут приходи не в нужные слоты времени, соответственно на ЦАП в каждые 125 мкс не будет поступать очередной сэмпл для декодирования. Так что,FRERTOS не поможет для решения данной задачи. для устройств, которые разрабатываете Вы, и для устройств которые не требуют точного до 1 мкс подсчета выполнения определенных частей программ и промежутков между ними, FREERTOS самое то. Хотя я возможно не совсем прав.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Использование операционной системы никак не влияет на быстрые процессы если они вам необходимы. DMA, таймеры, прерывания, это все никто не отменял.
@user-qk1vf9cg9i
@user-qk1vf9cg9i 4 жыл бұрын
@@VladimirMedintsev Владимир, будьте добры посоветуйте какую-нибудь литературу по FREERTOS, желательно англоязычную.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
freertos. org там все в виде pdf есть. прям много.
@user-nr2mg1pg6v
@user-nr2mg1pg6v 4 жыл бұрын
Необходим доскональный разбор этой системы, желательно с "подводными камнями"... Понимаю, что учиться на собственных ошибках хорошо, но таким образом уходит слишком много времени.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
На этом канале уже есть несколько роликов по FreeRTOS.
@user-nr2mg1pg6v
@user-nr2mg1pg6v 4 жыл бұрын
@@VladimirMedintsev ага... Значит будем рыть😊😊😊!!!
@sergbo3114
@sergbo3114 4 жыл бұрын
Не понимаю откуда такие вопросы в комментариях про прерывания и быстродействие. Ну если вам нужно последовательно что-то считать используйте ДМА. Да и с чего вы взяли что ОС это замена прерываниям. Это как что лучше мясо или мел?
@linovermac
@linovermac 3 жыл бұрын
*_Что за программа или компилятор?, пожалуйста, напишите название таймкод _**_2:02_*
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Это Keil uvision
@linovermac
@linovermac 3 жыл бұрын
@@VladimirMedintsev Большое спасибо)
@acrsofter
@acrsofter 4 жыл бұрын
я бы опредил пременимость RTOS так, если декомпозиция задачи укладывается менее чем в десять потоков, то применее RTOS скорее нежелательно и является "Overengineering", в таком случае лучше использовать конечный автомат, а чтобы код непревращался в"лапшу" просто аккуратно офрмлять код, больше использовать шаблонное програмирование, макросы
@kardanium
@kardanium 4 жыл бұрын
Был у меня один проект, где было пять почти не связанных друг с другом потоков. Написан был на автоматах, но весь код был тихим ужасом. Там свитчи были на 25-40 кейсов. Один поток работал с кнопками и GUI, второй через один UART работал с одной группой устройств по RS-485, третий через второй UART работал с другой группой устройств по шине K-Line, четвёртый работал с такими же контроллерами по шине CAN и пятый поток, получая все данные с остальных потоков, отрабатывал логику работы устройства. На FreeRTOS это было бы гораздо проще, эффективнее и быстрее. Однако, это был камень AT90CAN128 и порты FreeRTOS под него на тот момент были кривоватыми, а девайс нужен был "еще вчера".
@acrsofter
@acrsofter 4 жыл бұрын
@@kardanium был у меня один проект, на один поток, код был ужасен, на FreeRTOS он бы стал сложнее, тяжелее и тормознее.
@kardanium
@kardanium 4 жыл бұрын
@@acrsofter Ясно, что бывают задачи, где ОС не нужна. Я в таких случаях пишу функции опроса таким образом, что только когда данные будут готовы, функция их вернёт. А иначе возвращает ноль или иной признак неготовности. А задержки используются только неблокирующие, с использованием системного таймера. Часто даже автоматы писать не приходится.
@acrsofter
@acrsofter 4 жыл бұрын
@@kardanium да, иногда кооперативной многозадачности вполне достаточно
@crazydigger1
@crazydigger1 4 жыл бұрын
@@acrsofter это говорит скорее о скиллах разработчика.
@radio-l_ru7958
@radio-l_ru7958 4 жыл бұрын
Ну кому что, можно и на операционной системы FreeRTOS делать, но проще и быстрее чтоб работало сделать всё на прерываниях. Сработало прерывание, получили какую то информацию, выставили флаг событие, разбудили основную программу. Программа проснулась всё это обработала и опять в сон.
@boriskrasnoperov483
@boriskrasnoperov483 4 жыл бұрын
Если FreeRTOS уже есть в портированном состоянии под данный контроллер, то как раз использовать её много проще, нежели настраивать прерывания. Да и что там портировать...
@user-by8ji5nm2o
@user-by8ji5nm2o 4 жыл бұрын
Во-первых: а если задач больше, чем прерываний? Во-вторых: вы уже сами начали описывать что-то вроде простейшего диспетчера в главном цикле, который флаги проверяет. Добавляем сюда необходимость приоритетного выполнения некоторых задач, софтовые задержки, детерминированное время отклика на событие - и вуаля, у нас страшный франкенштейн (если он работает вообще), поддерживать который сам замучаешься. А уж отлаживать. И куча зависимостей между кусками кода. Поправил одно - отвалилось другое. Добро пожаловать в мир говнософта.
@user-bc7tm8vw9g
@user-bc7tm8vw9g 4 жыл бұрын
Роман Роман, предложенный автором способ, тоже не решит описанную вами проблему. Но в целом ОС полезна, если использовать где и как надо.
@anatoliydad0x078
@anatoliydad0x078 4 жыл бұрын
Все идет к усложнению архитектуры проца.. Уверен появится аппаратный менеджер задач, который например будет включать задачи по таймерам и отводить им сколько нибудь тактов... Потом выяснится, что два таких проца еще лучше чем один, потом защитят память кольцами защиты от вирусов, писАть под stm32(64/128/../2048) без ОС станет невозможно, выдут книги по программированию для ОС ртос.... Уверен мы наблюдаем ускоренную эволюцию от процессоров 8080..i486,...233mmx,....core i3.... и параллельно ms-dos...windows 3.11,...NT...XP....
@TheNamelessOne12357
@TheNamelessOne12357 4 жыл бұрын
На самых крупных микроконтроллерах STM32 уже запускается Linux. А в простых это не нужно.
@trollquantum
@trollquantum 4 жыл бұрын
Аплодую, я гадаю користь з того матеріалу новачкам буде велика! Збережу собі, десь в мене армка валялася)))
@user-jf8bb8kp4e
@user-jf8bb8kp4e 3 жыл бұрын
Спасибо, отличный пример задачи для которой и даром не нужна ОСь. И, пожалуйста, не называйте конечный автомат "диспетчером задач".
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
Спасибо, очень содержательный комментарий. Но это диспетчер задач и я обещаю вам называть его так и впредь. Спасибо что смотрите. Не забывайте поддерживать канал.
@user-jf8bb8kp4e
@user-jf8bb8kp4e 3 жыл бұрын
@@VladimirMedintsev наверное, у Вас сложилось впечатление что просто "а Баба-Яга против" (с). Нет, я не злостный противник операционнок на МК (ладно, противник, но это уже другая история). В первую очередь, я противник усложнения там, где не надо, и внедрения лишних точек отказа, где не просили. Пример из практики: на очень похожем проекте, но с крайне жесткими ограничениями по таймингам, один товарищ тоже решил что FreeRTOS - быстрая, а такты - дешевые. Почему у него не получилось докупить оптом тактов в уже выбранные МК, объяснять, думаю, не надо. В итоге, все было выброшено в окно, и переписано на Bare Metal. Вышло 46 строк ассемблерного кода на все про все. Пара часов разработки, пара часов в QA, и готово. Воюй мы с ОС, до сих пор сюрпризы по углам отлавливали бы. Впрочем, я уже лет 6 программатор в руках не держал, может что и изменилось с тех пор. Хотя, что там могло измениться? Частоты чуть подросли, да память еще чуток подешевела? Не тянет на принципиальные изменения.
@VladimirMedintsev
@VladimirMedintsev 3 жыл бұрын
@@user-jf8bb8kp4e У меня совсем не сложилось впечатление что "Баба-Яга против", после описанного вами явственное чувство другой пословицы "Дуть на воду, обжегшись на молоке". Вы пришли под учебное видео рассказывающее о том, как можно применить операционную систему и какие преимущества в скорости разработки она дает и рассказываете о случае проекта с жесткими ограничениями по таймингам.... Т.е. ваш товарищ ошибся при выборе подхода к построению скелета программного обеспечения для слишком слабого для решаемой задачи микроконтроллера и теперь из этого следует, что использование операционной системы это плохо и это точка отказа? Ну ладно, я готов смириться с тем фактом что это ваше мнение. Честно говоря это как в известном анекдоте, что микроскоп плохой, плохо консервные банки открывает. Я вашу позицию понял, спорить не буду...
@user-jf8bb8kp4e
@user-jf8bb8kp4e 3 жыл бұрын
@@VladimirMedintsev использование операционной системы - не плохо. Плохо, когда ее пытаются натянуть туда, где она не нужна. Равно как и плохо, когда изо всех сил пытаются обойтись без нее, когда очевидно, что она нужна. Все верно, для каждой задачи - свой инструмент. Изначальный посыл первого поста был, что в качестве примера как раз приведена крайне простая задача, которая с высокой долей вероятности без ОСи решается быстрее, чем с нею. Впрочем, я Вас понимаю: в учебный ролик трудно уместить сложный пример, с МК, который должен хороводить дюжиной устройств, читать тачскрин, да еще и в эфир шуметь. Тогда любой начинающий разработчик сбежит в панике :-)
@anatolyilinykh7888
@anatolyilinykh7888 4 жыл бұрын
У меня это видео и первая часть трилогии FreeRTOS испорчено.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Проверил на 5 (пяти) разных компьютерах. Все работает. Авторы роликов заливают их на ютуб, дальнейшее от нас не зависит.
@anatolyilinykh7888
@anatolyilinykh7888 4 жыл бұрын
Да, согласен, только на одном из 5 глючит. Извините что не исправил.
@ilhitindustries7499
@ilhitindustries7499 4 жыл бұрын
Здравствуйте Владимир! У меня такой вопрос: заказал один проект,его мне выполнили и я все оплатил.Все работало нормально,но прошло не много времени и программа в каком то месте перестала выполняться. Исходный код или hex файл при заливке никаких результатов не дал. Кстати сказать там тоже была операционка FREERTOS. Так вот собственно вопрос: мог ли программист сделать так,что бы программа спустя какое то время перестала частично работать? Если да,то можно ли устранить данный прикол? Тот программист перестал выходить на связь. Спасибо.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
напишите мне по электронной почте vmedintsev@yandex.ru и обсудим
@kalobyte
@kalobyte 4 жыл бұрын
если это стм32, то могу предположить, что там есть функция-подлянка, которая перезаписывает память в области памяти программ в этих контроллерах нет епром как в авр и часть общего флеша можно использовать как память для хранения каких-то данных т.е. можно из своей же проги перезаписывать любые области памяти и вот работает твой контроллер, функция перезаписывает байт и изнашивает ячейку через какое-то время ячейка перестает читаться правильно и прога глючит если это авр, то там может загрузчик есть и он при каждом старте тоже перезаписывает байт во флеше либо таймбомба, когда в ячейку епром пишется число и при каждом старте оно увеличивается на 1 при достижении какого-то числа прога больше не выполняется и перепрошивка не поможет, только стереть нужную ячейку в епроме программатором
@ilhitindustries7499
@ilhitindustries7499 4 жыл бұрын
@@kalobyte Вот за это спасибо! Не знал, но возможно где то мысля такая побегала. Проц stm32f103c8t6. А как стирать ячейку не подскажите?
@kalobyte
@kalobyte 4 жыл бұрын
@@ilhitindustries7499 я не углублялся в такие дебри просто знаю, что можно писать во флеш прямо из проги, а не только программатором или загрузчиком вот я загуглил www.devcoons.com/how-to-write-data-to-the-internal-flash-memory-of-an-stm32/ основная функция HAL_FLASH_Program
@vadimerofeev1148
@vadimerofeev1148 4 жыл бұрын
Все эти ртосы очень напоминают ардуину. Расточительно, но может пригодиться при унификации подключаемых к проекту модулей: вставили INIT и все остальное модуль запустит. Именно так пишут свои примеры разработчики микроконтроллеров, например, STM. Основной недостаток - все это очень медленно. За время переключения с одной задачи на другую, в моих проектах успевают выполниться все мои задачи. При переключении диспечер сначала обрабатыыает все очереди событий, выбирает задачу, потом собирает чемоданы от текущей задачи и распаковывает для следующей. Я пишу сложные многопроцессорные приложения с обработкой звука в реальном времени, комуникацией, графикой, вложенными прерываниями, распределением приоритета и т.д. Мой опыт работы 27 лет. Применение ртос не оправдалось нигде. Все решается проще.
@Mura905
@Mura905 4 жыл бұрын
Потому что микроконтроллер СТМ32 имеет в составе процессор Кортекс М4. А кроме него ещё память и много чего.
@bogdanzayatsastronomyandna4722
@bogdanzayatsastronomyandna4722 3 жыл бұрын
смотря какая серия
@bogdanzayatsastronomyandna4722
@bogdanzayatsastronomyandna4722 3 жыл бұрын
ести и с ARM Cortex М0, М0+ и с М7, М3...
@aleksandrivanov4756
@aleksandrivanov4756 4 жыл бұрын
Алгоритм который вы описали можно реализовать и без применения FreeRTOS , будет работать надёжнее но читаться хуже
@user-oz3kc6vh6b
@user-oz3kc6vh6b 4 жыл бұрын
Да , и это будет AiRTOS )))
@microsinnet7718
@microsinnet7718 4 жыл бұрын
Пожалуй, содержимое ролика никак не коррелирует с его темой (в заголовке). После прослушивания возникает четкий ответ на вопрос "Почему использование операционной системы оправдано даже в небольших проектах" - да ни почему. Просто так автору кажется. В небольших проектах может быть как раз лучше применить простой дешевый чип с малым объемом памяти, куда FreeRTOS никак не впишется.
@anatoliygavrilov958
@anatoliygavrilov958 4 жыл бұрын
Оправдано тем, что код получается чище и понятней - каждая мини-задача в отдельной функции и без лишнего мусора. Такой код проще и быстрее писать, отлаживать и поддерживать. А время сейчас стоит дороже чипов.
@kalobyte
@kalobyte 4 жыл бұрын
так для автора может быть небольшой проект это не помигать светодиодами, а какая-то замороченная херня вот он и говорит, что с виду вроде бы все просто, но есть куча состояний и все они как бы сами по себе должны работать и такое лучше оформить при помощи ртос, а не автоматом больше сожрет памяти, зато меньше писанины если ты бабло получаеш за проект, а не по часам, то в твоих же интересах написать это все как можно быстрее и чтобы через год ты мог понять, что ты там написал и встроить новую плюшку а то бывает так, что новая плюшка потянет переписывание всего кода
@user-bc7tm8vw9g
@user-bc7tm8vw9g 4 жыл бұрын
microsin net, на совремнные чипы почти на любой фриртос влазит..
@user-bc7tm8vw9g
@user-bc7tm8vw9g 4 жыл бұрын
Anatoliy Gavrilov, у автора видео лишь иллюзия этого. Он декларирует эти цели, представленный псевдокод их не реализует.
@microsinnet7718
@microsinnet7718 4 жыл бұрын
@@user-bc7tm8vw9g Тут ключевое слово "почти". Таки да, именно так. Поэтому нельзя утверждать, что "даже в небольших проектах использование FreeRTOS оправдано". Не все чипы "современные", и ни на все "современные" чипы "влазит" RTOS. Всякий инструмент хорош на своем месте.
@tx-rx
@tx-rx 4 жыл бұрын
Не претендую на истину, а лишь выскажу свое личное мнение. Мне кажется что писать с использованием RTOS можно только при соблюдении некоторых факторов : 1. Вы умеете писать работоспособный код и без нее и поэтому хорошо понимаете плюсы и минусы данного подхода. 2. можно писать с ней если приоритеты прерываний кажутся чем-то маловажным для вас и вы никогда не гуглили ответы на свои вопросы фразами типа "interrupt latency" и не считали такты(да да , в некоторых задачах на 100-180Мгц тоже приходится это делать и не по приколу, а по необходимости). 3. проект чисто домашний и можно смело брать самый "жирный МК" и не думать о его стоимости. Если новички читают это, то просто поймите - RTOS это просто один из подходов к программированию - иногда оправдан, иногда нет, все зависит от ваших задач. Ну а сам ролик нормальный.
@VitaliyRu
@VitaliyRu 4 жыл бұрын
Да вы озверели чтоли, новичкам много поточное приложение писать... Со всеми гонками переменных и прочими прелестями асинхронности. Это 90% программистов вообще не умеют. Ибо в 90% случаев не нужно.
@tx-rx
@tx-rx 4 жыл бұрын
​@@VitaliyRu ну по моему мнению - в 90-95%(а вообще и больше) использование ОС на МК тоже особо и не нужно. ОС нужно в других устройства, где чуть выше уровень и другие вычислительные возможности. обычно примерно так: система где есть 1) устройство на линуксе + 2) устройство на МК. линукс с ОС для вычислений, МК для связи с датчиками и ИМ. как то так. Новичкам (и не только )лучше RM читать , книжки по Си и Хоровица + практика практика практика. Я уже не совсем новичок, но все равно повторяю по кругу эти действия :) А кто хочет просто побаловаться "миганием лампочкой" и сделать это без особых затрат(умственных и временных) и забыть как пропадет интерес - ардуино будет идеально вариант и все эти ОС нафиг не нужны.
@VitaliyRu
@VitaliyRu 4 жыл бұрын
@@tx-rx По мне так тоже. Либо линух, винда и тому подобное. Либо по стараинке в петле с прерываниями(там своей боли хватит :) Их к слово по возможности лучше тоже избегать. В видео описана задача которая прекрасно выполняется последовательно(это не только МК касается, но и той же винды), а ее предлагают сделать асинхронной. Выше я там уже Рихтера цитировал "В общем, мораль этого вступления такова: многопоточность следует использовать разумно. Не создавайте несколько потоков только потому, что это возможно. Многие полезные и мощные программы по-прежнему строятся на основе одного первично го потока, принадлежащего процессу "
@tx-rx
@tx-rx 4 жыл бұрын
@@VitaliyRu полностью согласен.
@alexpood9227
@alexpood9227 4 жыл бұрын
@@tx-rx за Хоровица отдельный привет и спасибо, дядька знатный и дай бог ему долгих лет жизни. Я после окончания университета его до сих пор перечитываю и каждый раз нахожу новое!
@TK-wh6lf
@TK-wh6lf Жыл бұрын
Все яйца обычно в одну корзину не кладут, тот кто говорит надо аппаратную часть жестко вести жестко привязанную ко времени и freertos это неправильный выбор для техпроцессов - используйте свою периферию: ПЛИС, DSP и тд, а stm очень хорошо на FREErtos может дирижировать вашим оркестром при этом отображая данные на дисплей и отправляя/принимая уставки куда нибудь сразу по нескольким каналам ю, при этом можно что-то не критичное ко времени привязать на саму стм что-то вроде температуры, заряда акб и тд, осциллограф из него не сделаешь, дельта-сигма фильтр из него лепить? Один контроллер на функцию? Да это просто кошмар такое предлагать, тогда на устройство надо 5 контроллеров или очень толстый стм. Автор учит как использовать стм, а вот как его использовать с умом тут каждый должен вырасти сам.
@alexeidubrovin5234
@alexeidubrovin5234 Жыл бұрын
конечно интересно, но вот на столе лежит две конкретные задачи - зарядка LiFePO4 100кГц ШИМ с ПИД-регулятором на stm32f303 и передача спектра звука 32кГц (естественно через fft) с I2S по tcp на комп на stm32f745, ни в одном из случаев freeRTOS ничего не успевает, о каких osDelay или квантах в мс идёт речь, если нужны мкс? в первом случае, кстати даже HAL не успевает, перешёл на LL, приходится писать отсебятину, если речь идёт о чтении кнопки, выводе на дисплей, где сотня миллисекунд вообще ничего не решает - одно дело, если же настоящий real time с квантами в микросекунды, то нужно намного глубже разбираться во freertos, чем в прерываниях и DMA
@NoName-yp9to
@NoName-yp9to Жыл бұрын
Для зарядки лития нужна скорость ответа регулятора в 100кГц?) Да, ШИМ может понадобиться в 100кГц, но используйте для этого хардварный таймер. А пид-регклятору и 1кГц overkill.
@vladevro222
@vladevro222 Жыл бұрын
@@NoName-yp9to . Ну ну. Сравнил шип 1кГц и 100кГц. Там какбы индуктивность (трансформатор) совсем разные по габариту получаются)))) Автор выше прав - если что-то медленное и неответственносое, то freertos рулит. А когда надо выше 1кГц то- сосай мосай
@NoName-yp9to
@NoName-yp9to Жыл бұрын
@@vladevro222 а теперь перечитайте то, что я написал выше. Вобще то я предложил шим генерить с частотой 100кГц аппаратным таймером, а с частотой 1кГц - только лишь обеспечивать регуляцию. А уж если нужна какая то быстрая обратная связь (например по току КЗ), то в большинстве стмок есть компаратор.
@Blow_BacK
@Blow_BacK Жыл бұрын
@@NoName-yp9to зачем страдать если написать напрямую просто проще? Без абстракции ради абстракций. Просто сделать задачу. Единственно зачем там стм вопрос. Там какая нить аттини или пик вполне.
@sc0or
@sc0or 10 ай бұрын
Вы просто не захотели заниматься трассировкой. И не было бизнес-заказчика, который правильно бы подсчитал все свои текущие и будущие затраты. Я подозреваю, что для каждой из Ваших задач есть аппаратные решения. И для заряда аккумулятора, и w5500, и, возможно, какой-то dsp со встроенным fft. Вам останется только взять кракозяблу для управления периферией. Код - минимальный, поддержка - дешевая, конец производства - не приговор, затраты на переписывание управляющего кода - минимальные. FreeRTOS - для правильно организованного проекта.
@ShaneAMC
@ShaneAMC 4 жыл бұрын
Порекомендуйте с чего начать в программировании на STM? В AVR есть понимания, а вот к STM не знаю как подойти. Боюсь пойти не по тому пути.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
1.купите или изготовьте программатор st-link 2. купите или изготовьте платку с микроконтроллером выбранного вами семейства. 3. скачайте с сайта st.com последнюю версию STM32CubeIDE. Установите. 4. в примерах найдите мигалку лампочкой. мигните и убедитесь что все работает. 5. изучайте reference manual и все ОК.
@ShaneAMC
@ShaneAMC 4 жыл бұрын
@@VladimirMedintsev А есть что-то что сначало немного проще, типо как ардуино дает быстрый старт. (Только не ардуино под стм). Первые 2 пункта уже давно пылятся (купил на пробу, но так и не решился так как на тот момент информации было не так много как по авр), а 3 пункт вызывает вопрос с того ли стоит начинать или с другого.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
Вы просили совет - я его дал. Следовать ему или нет, это ваше дело. Среда разработки (пункт 3) значения никакого не имеет, это просто инструмент. Что еще проще - платы nucleo. это как ардуино но stm.
@ShaneAMC
@ShaneAMC 4 жыл бұрын
@@VladimirMedintsev а вот эти все cmsys, freertos, hal я вот в этом запутолся.
@arielvolog
@arielvolog 4 жыл бұрын
@@ShaneAMC если нет хороших навыков программирования, то стм32 будет даваться долго и муторно... если конечно вы планируете делать сложные проекты в будущем.. для основ АВР хватает за глаза, а если взять софт flowcode, то и знаний программирования на первое время не понадобится..
@user-qk1vf9cg9i
@user-qk1vf9cg9i 4 жыл бұрын
Познавательный и Интересный ролик, но звуки "ватсапа" на заднем фоне... Лучше бы их не было вовсе.
@VladimirMedintsev
@VladimirMedintsev 4 жыл бұрын
это жизнь.
@sergbo3114
@sergbo3114 4 жыл бұрын
По поводу микроконтроллера и процессора все просто. Процессор это само по себе АЛУ и только. А контроллер это все вместе с периферией. По моему все предельно понятно. А как кто называет это уже их интимное дело.
@DmitryKandiner
@DmitryKandiner 3 жыл бұрын
АЛУ и регистры, как минимум.
FreeRTOS Программные таймеры.
12:04
Vladimir Medintsev
Рет қаралды 7 М.
Increíble final 😱
00:37
Juan De Dios Pantoja 2
Рет қаралды 92 МЛН
Sprinting with More and More Money
00:29
MrBeast
Рет қаралды 185 МЛН
ТАМАЕВ vs ВЕНГАЛБИ. ФИНАЛЬНАЯ ГОНКА! BMW M5 против CLS
47:36
Неприятная Встреча На Мосту - Полярная звезда #shorts
00:59
Полярная звезда - Kuzey Yıldızı
Рет қаралды 3,6 МЛН
STM32. BlackPill - рождение новой легенды на F4
27:08
STM32 DMA ч.1
26:54
MBDLB
Рет қаралды 1,3 М.
PlatformIO или прощай, Arduino IDE
35:23
Alex Morozov
Рет қаралды 155 М.
One To Three USB Convert
0:42
Edit Zone 1.8M views
Рет қаралды 441 М.
Samsung Galaxy 🔥 #shorts  #trending #youtubeshorts  #shortvideo ujjawal4u
0:10
Ujjawal4u. 120k Views . 4 hours ago
Рет қаралды 3,5 МЛН
iPhone 12 socket cleaning #fixit
0:30
Tamar DB (mt)
Рет қаралды 45 МЛН