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

Поділитися
Вставка
  • Опубліковано 10 січ 2025

КОМЕНТАРІ • 457

  • @alekseywolf5405
    @alekseywolf5405 4 роки тому +21

    Как раз сейчас и решаем схожую задачу, используя RTOS: нужно быстро и часто опрашивать акселерометр, анализировать полученные данные, при этом управлять контроллером электропитания, что-то периодически (хотя бы 4 раза в секунду) обновлять на экранчике и при этом обмениваться с сервером информацией через очень медленную LoRa. Задачи слишком разного масштаба времени. Можно, конечно, самому городить семафоры, очереди и т.п., но если это уже всё сделано во FreeRTOS, то зачем изобретать велосипед?

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому

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

  • @СергейХренов-ф9х
    @СергейХренов-ф9х 4 роки тому +4

    Спасибо за доступную подачу информации. Пока сижу на AVR, делаю хобби-проекты. Крайний проект, после реализации на AVR, с помощью вашего канала планирую перевести на STM32. Еще раз спасибо и надеюсь что терпения на развитие канала Вам хватит, а в том что сумеете подать актуальную информацию в доступном ключе-у меня сомнений нет.

    • @sovchem1275
      @sovchem1275 4 роки тому +3

      Хватай на али "stm32f103c8t6 board" + прогер-отлдачик "STLink2" за 100р. Качай CubeMX + Keil5, 2копиасты кода, 5 кликов мышки и проект готов :)
      А не заработает, врубай пошаговую отладку как белый человек и смотри где ступор

  • @klondike2009
    @klondike2009 4 роки тому +4

    Наконец-то доступно объяснили для чего нужен freertos😁 Спасибо за видео!

  • @ВладиславТочёный-у9б

    Ну я прямо не знаю сколько тонн лайков надо ставить))) Сам с FreeRTOS уже 5 лет работаю в коммерческих проекта и глубоко убежден, что что-то серьёзное сделать без оной можно но ОЧЕНЬ сложно.... А Вы так доходчиво народу объяснили что да как и по чём)))

    • @Wo_Wang
      @Wo_Wang 3 роки тому +1

      Пожалуйста поподробнее: 2 таймера с выводом ШИМ и ввод-вывод по USB можно ли считать настолько сложной задачей, что без FreeRTOS не обойтись?
      :)

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому

      @@Wo_Wang есть разница между "не обойтись" и "некомфортно работать". Проще - с операционкой, как минимум протокол общения (поверх стека USB) я бы выделил в отдельный процесс.

  • @cezis666
    @cezis666 4 роки тому +4

    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  4 роки тому

      It’s a surprise for me that someone is watching these videos in Europe. Good luck to you.

    • @cezis666
      @cezis666 4 роки тому +2

      @@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 :)

    • @ДенисовВладислав-ш3о
      @ДенисовВладислав-ш3о 4 роки тому

      Братан! Пиши на русском языке, а то скоро вы его совсем забудете!

  • @ДимаДима-к1н
    @ДимаДима-к1н 4 роки тому

    Первые 3 минуты изучал пол часа.... магия раскрыта, БлагоДаря Вам!

  • @iotmanager
    @iotmanager 4 роки тому +2

    Спасибо большое за обзор! Очень многое стало яснее...

  • @Vod-b4n
    @Vod-b4n 4 роки тому +5

    У меня в usart по дма иногда пропадает посылка на прием при использовании freertos, точно такой самый код, но без операционки, за ночь при тесте модбаса дал всего лишь две ошибки при 256000 кб/с, не знаю, плюс для реализации canopen нужно прерывание 1мс и проц stm32f407vet6 не может обслужить программу где одновременно используется 5 интерфесов и 200 кбайт кода...принял решение отказатся от операционки

  • @DaeGrom
    @DaeGrom 4 роки тому +7

    Посыл конечно понятен. Не понятно только, почему по мнению автора есть только 2 альтернативы: последовательный код и freeRTOS(или любая другая RTOS). Для 99% задач которые делают на стмках, хватит банальной event-driven системы, в отдельных случаях вкупе со стейт машиной. И первое и второе пишется за 30 минут и занимает минимум места. RTOS это хорошо, но это чаще всего стрельба из пушки по воробьям. Не надо так.

    • @ДимаДима-к1н
      @ДимаДима-к1н 4 роки тому +1

      Я новичок с 12-ти летним стажем...и половину слов не умею реализовывать"event-driven системы, в отдельных случаях вкупе со стейт"... в дальнейшем научусь, но ОС доступный инструмент int_32t, забивать гвозди в int_8t!

  • @ДмитрийВсемогущий-я2и

    Контроллер это устройство состоящее из процессора, ОЗУ, Флеш памяти и прочее. Автор совершенно прав.

  • @megannnn98
    @megannnn98 4 роки тому +4

    Вставлю свои пять копеек,
    1) Там где вы вставили switch case в while(1), и говорили, что нужно долго дожидаться пока Program Counter дойдет до нужной обработки после прерывания, но вы же можете в этом прерывании ставить флаг, который скажет, в какой из кейсов переходить после прерывания и обработка после прерывания будет быстрее. Во freertos же надо придется дожидаться когда PC дойдет до задачи которая должна обработать после прерывания.
    2) Для процессоров типа stm32F0 , на мой взгляд, freeRTOS жрет много оперативки, в отличии от тех же конечных автоматов, где 2 байта идут на запоминание состояния где мы были.
    Спасибо за качественный контент.

  • @jsonslim
    @jsonslim 4 роки тому +3

    Десять благодарностей вам :)

  • @АлександрПронин-х3ъ

    Кстати, Владимир, Ваше видео дало мне повод задуматься, что возможно нижеописанную мною проблему можно реализовать с помощью FreeRTOS. Вы мне дали повод для размышлений и изучения FREERTOS.

  • @parennasubaru
    @parennasubaru 4 роки тому +2

    Отличный обзор. Прошу рассказать особенности работы виртуализации с dma , какие существую подходы для качественной работы

  • @kardanium
    @kardanium 4 роки тому +7

    Не понимаю тех, кто не хочет использовать FREERTOS, даже тогда, когда ситуация позволяет. Например, очередь - это очень крутая вещь. Можно в обработчике прерываний заталкивать туда данные и когда у задачи появится время, она их обработает, извлекая из очереди. Данные можно даже получить из неё не извлекая их из неё. Такое очень даже пригодится, когда на одни и те же данные нужно реагировать нескольким задачам. Еще круче получается с несколькими источниками данных для очереди. Например, одна задача окрашивает кнопки и помещает коды нажатых кнопок в очередь. Задача, отвечающая за работу с GUI получает их и обрабатывает. А теперь нам захотелось управлять GUI с помощью пакетов, приходящих с UART. Создаём задачу, которая принимает эти пакеты, извлекает из них команды и помещает их в эту же очередь. Так вот, сильно не напрягаясь и не затрагивая кода GUI, мы добавили еще один "пульт управления". И таких вот фишек там масса.

    • @sovchem1275
      @sovchem1275 4 роки тому +1

      Я не хочу :) т.к. нашел куда круче RTOS2 RTX5 - родная ARM ось, ХАЛЯВНО включена в CMSIS2 !!! НЕ ОБРЕЗАННАЯ как все GNU "халявные" как
      FreeRTOS или ChibiOS хочешь полную и надежную ПЛАТИ! Открытый код!. портирована в IAR и GCC, работает не только в платном Keil5
      в CMSIS2 есть шаблоны под потоки, таймера итп, подключается быстрее чем фриртос из куба. И к ней есть EventRecorder классная GUI консоль для отладки в Keil5
      (галочки не забудь расставить, а то будет пустой график)
      Попробуй!

    • @leharuso
      @leharuso 4 роки тому

      И я не хочу. Хватает TNeo.
      На код freertos как ни посмотрю, напоминает древние версии php...

    • @evgenevgen3011
      @evgenevgen3011 4 роки тому

      И я не хочу. Дорог каждый байт памяти и каждый такт не лишний.

    • @ЮристЧастнойПракитки
      @ЮристЧастнойПракитки 4 роки тому

      Андрей Батищев, говорят кольцевой буфер с этим отлично справляется))

    • @kardanium
      @kardanium 4 роки тому +1

      @@ЮристЧастнойПракитки Говорят много чего, но более мерзкого (в плане реализации), чем кольцевой буфер, я больше ничего не видел.

  • @МихаилАаа-д3ю
    @МихаилАаа-д3ю 4 роки тому +3

    "... код становится не сильно легко читаемым..." - Класс!!!!!

  • @НиколайТорощин-е6э
    @НиколайТорощин-е6э 4 роки тому +1

    Классно 👍👍 спасибо вам за данное видео... Я когда кодил под Ардуино, пытался реализовать что-то подобное. Пытался написать ОС для микропроцессоров, но мои навыки программирования на чистом C не позволили сделать подобную ось (более 3 лет разрабатываю программы на C++/C#), а тут есть готовый велик, как говорится "садись и едь!".

  • @Techn0man1ac
    @Techn0man1ac 4 роки тому +1

    Спасибо, да действительно удобный инструмент

  • @JingoBo
    @JingoBo 4 роки тому +6

    Хах, всё то у вас просто получается, как в примерах аля "помигать светодиодом". А не забыли ли вы упомянуть про тонкости синхронизации данных (в которых нужно в принципе иметь хорошие скилы в многопоточном программировании), трудно отлавливаемые дедлоки, тонкости вызова функций ос в контексте прерываний? В небольших проектах freertos никак не оправдан, всегда можно сделать систему событий, софтовые таймеры и практически всегда работать в контексте главного цикла и не заботиться о синхронизации. Вот реально freertos может быть оправдан там где куча долгих синхронный операций, например работа с bsd сокетам (интерфейс которых эмулируется через lwip) - да тут код будет куда короче и стройнее чем работа асинхронно.

    • @VitaliyRu
      @VitaliyRu 4 роки тому

      Золотые слова, вот и я о том же. Автор видимо никогда многоточечных приложений не писал. А дедлоки это еще и меньшая из бед(ее изобразить сложнее), хоть и очень противная. А вот логика работы, не так как задумал - легко. И не обязательно гонки переменных, просто выполнилось не в той последовательности или данные разрушила, или обратилась к полупустому указателю и так далее. Тут занимался оптимизации одного своего проекта. Нашел ошибку, а суммарный аптайм десятки лет(всех экземпляров), не проявлялось только потому, что ошибка четная, т.е. их 2, вторая маскирует первую... А критическую секцию туда нельзя, слишком "тяжелая" даже для сервачных процов, а тут МК, хи-хи. Весь рак мозга начинается когда нельзя сильно обкладывать в кретические секции, да если все ими обложить - нахрена козе баян(вообще многопоточность)

    • @ЮристЧастнойПракитки
      @ЮристЧастнойПракитки 4 роки тому +1

      Виталий Алпатов, особенно пример с клавой доставил, да и уарт не лучше. А ведь так хорошо начиналось видео, все в одной задаче))

  • @cnjzyjdheckfy
    @cnjzyjdheckfy 4 роки тому +2

    А ещё по прерыванию можно разбудить процесс,выполнить что то и усыпить )
    Вообще более правильный вариант использования ос будет в комбинации всех доступных возможностей - ос+прерывания+дма

  • @dmitryuser4327
    @dmitryuser4327 4 роки тому +2

    Для многих задач и особенно для мелких контроллеров зачастую не нужен RTOS,достаточно Protothread

  • @Beno_vu
    @Beno_vu 4 роки тому +4

    Спасибо, очень полезную работу делаете, все чётко по полочкам. Не обращайте внимание на этих придурковатых умников, это все на что способен их мозг))

  • @Ruslan-kk4pf
    @Ruslan-kk4pf 2 роки тому +3

    В общем как многопоточное программирование в каком-нибудь дотнете, ясненько, спасибо👍

  • @olejick4043
    @olejick4043 4 роки тому +2

    Согласен. Я на асме пописываю для АВР ок, как попробовал кооперативную РТОС (от di Halt,) так в "суперцикл" и не тянет. В разы проще и в написании и в отладке

  • @zmeygavrilych
    @zmeygavrilych 4 роки тому +2

    19:00 Забавный диалог...
    - При чём тут операционная система, когда нужны жёстко заданные тайминги?
    - При чём тут жёстко заданные тайминги, когда нужна операционная система???

  • @stenzoautomatic
    @stenzoautomatic 2 роки тому

    Спасибо, подчерпнул многое для себя, потихоньку отстраняюсь от ардуины

  • @ВладимирН-ц7ы
    @ВладимирН-ц7ы 4 роки тому +4

    Пожалуй без разбора примера и указаний достоинств работы с FreeRTOS (например с приемом кода пульта и включением чего нибудь) Было бы лучшим аргументом.

  • @wsws7939
    @wsws7939 2 роки тому +1

    Спасибо, я с первого раза понял преимущества ос. Тут получается хороший мултитрединг, каждый таск получает своё время. На интерапты хорошо и сразу можно отреагировать.
    Заказал себе микро контроллер, попробую...

  • @ГеннадийГром-в8ю
    @ГеннадийГром-в8ю 4 роки тому +1

    Примерно к такой же структуре программы я и пришел лет 20 назад, с таймерами и флажками, после 2-х летних изысканий. Задача: упаковочный автомат с 2-3-4 весовыми головками(CAS). Контроллер: fastwel CPU188-5. Правда, RTOS-ов тогда ещё не было... ☹ Гы: зато, ещё был MS-DOS 6.22, на этой плате! 🙂

  • @statstopfinish
    @statstopfinish 4 роки тому +2

    С freertos вроде все удобней , но вот появилась задача управления шаговыми двигателями и обработкой энкодеров и тут столкнулся с затруднениями генерации импульсов для ШД и обработкой прерываний от энкодеров.

  • @НиколайТорощин-е6э
    @НиколайТорощин-е6э 4 роки тому +1

    Без условно, использование операционной системы это грамотный подход👍

  • @xealit
    @xealit 3 роки тому +4

    Насчёт тайминга действительно это просто недопонимание. На то она и “real time” ОСь, что её цель именно выдерживать детерминированный тайминг задач. Нужно только указывать им приоритеты и будет тайминг что надо. На ютубе есть видео с презентацией FreeRTOS от автора - там он отлично это поясняет.
    Конечно, могут быть какие-то другие причины не использовать RTOS. В каких-то супер-критических и супер-embedded задачах может будет необходим 1 контроллер на 1 задачу (или 1 PLC на задачу, если это совсем что-то суровое). И, конечно, если ваш код не сложен и не предвидится его развитие, то действительно нет смысла заранее заморачиваться с ОСью. Но тайминг это как раз не проблема для RTOS, это её работа 🙂

    • @agentsmit09
      @agentsmit09 2 роки тому

      Контроллеры разные бывают. Для ATmega 8 или 328 такая ОС мне кажется перебор, а вот для ESP32 необходимо использовать ОС.

  • @zjohnes
    @zjohnes 4 роки тому +2

    При рассказе последовательности загрузки МК, Вы еще пропустили что будет с начало вызвана функция, так сказать инициализации языка С, называется она в Вашем случае __main(), а вот она уже затем вызовет пользовательскую функцию main(). На ББ в этой функции "__main()" как правило происходит статическая инициализация данных и инициализация стандартной библиотеки С ...... для МК скорее всего аналогично.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +1

      и это как-то влияет на запуск программы? о всех мелочах рассказывать это видео бесконечным получится.

    • @zjohnes
      @zjohnes 4 роки тому +3

      @@VladimirMedintsev нет конечно, просто Вы подробно начали рассказывать про цепочку вызовов, и при виде ассемблеровского вызова функи __main() в Вашем видео, почему то сразу перешли на main(), а мне просто это бросилось в глаза )) и я решил поделится с Вами инфой об этом. Я ни в коем случае не хотел вмешиваться в Ваш рассказ, а просто восполнить для Вас данный пробел. Но если Вы и так знали про это - то и отлично, извините меня за это программистическое занудство ))

    • @OlegKotchetov
      @OlegKotchetov 4 роки тому +2

      @@VladimirMedintsev Влияет непосредственно, если использовать для инициализации статических переменных вызовы каких-либо функций, самое распространённое - при статическом создании объектов С++ вызываются конструкторы классов.
      Иной раз по невнимательности можно схлопотать HardFault не добравшись до точки входа main(). По-моему инициализация - достаточно важный вопрос, чтобы его упомянуть, хотя бы одним предложением.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      @@OlegKotchetov Можете хоть один, ну хоть вшивенький пример инициализации хоть чего-нибудь привести чтобы схлопотать HardFault не долетая до main. Ну хоть какой - нибудь примерчик.

    • @OlegKotchetov
      @OlegKotchetov 4 роки тому +2

      @@VladimirMedintsev
      Пожалуйста:
      1. Слепить класс, у которого в конструкторе присутствует обращение к периферии через HAL, надеясь, что создавать его объекты будут всегда _после_ инициализации HAL.
      2. В угаре очередного горящего дедлайна вспомнить, что когда-то был такой отличный класс, который делал то, что нужно, скопировать его в проект и воткнуть статическое создание экземпляра, что-нть типа
      extern I2C_HandleTypeDef hi2c1;
      static I2C_SuperSensor sensor = I2C_SuperSensor(&hi2c1);
      А потом удивлённо смотреть в дебаггере на немедленный HardFault при запуске.
      Да, разумеется, это адский быдлокод и тот, кто так сделал - сам дурак. Но поверьте, ситуации бывают разные. Иногда приходится сознательно быдлокодить, когда на постройку башни из резной слоновой кости нет времени, задача копеечная и требуется чтобы результат сработал раз-другой и дальше станент не нужен. Да лучше за такое не браться, но иногда и отказать нельзя. Если Вы занимаетесь этим делом на потоке, наверняка сами прекрасно понимаете. А может новичок подобное слепит по неопытности и потом мозг сломает, пытаясь понять, что, блин, происходит :)
      Вот для последних как раз помянуть про фазу инициализации статики - методически оправдано полностью имхо. А то ведь зачастую смотрят на компилятор, как на чёрный ящик: на входе исходник, на выходе - светодиод моргает, а что там между - черт его знает...

  • @lutsiuk5
    @lutsiuk5 4 роки тому

    Спасибо вам , открыл для себя ОС - Ртосс !!

  • @tx-rx
    @tx-rx 4 роки тому +9

    Не претендую на истину, а лишь выскажу свое личное мнение.
    Мне кажется что писать с использованием RTOS можно только при соблюдении некоторых факторов :
    1. Вы умеете писать работоспособный код и без нее и поэтому хорошо понимаете плюсы и минусы данного подхода.
    2. можно писать с ней если приоритеты прерываний кажутся чем-то маловажным для вас и вы никогда не гуглили ответы на свои вопросы фразами типа "interrupt latency" и не считали такты(да да , в некоторых задачах на 100-180Мгц тоже приходится это делать и не по приколу, а по необходимости).
    3. проект чисто домашний и можно смело брать самый "жирный МК" и не думать о его стоимости.
    Если новички читают это, то просто поймите - RTOS это просто один из подходов к программированию - иногда оправдан, иногда нет, все зависит от ваших задач.
    Ну а сам ролик нормальный.

    • @VitaliyRu
      @VitaliyRu 4 роки тому +3

      Да вы озверели чтоли, новичкам много поточное приложение писать... Со всеми гонками переменных и прочими прелестями асинхронности.
      Это 90% программистов вообще не умеют. Ибо в 90% случаев не нужно.

    • @tx-rx
      @tx-rx 4 роки тому +5

      ​@@VitaliyRu ну по моему мнению - в 90-95%(а вообще и больше) использование ОС на МК тоже особо и не нужно. ОС нужно в других устройства, где чуть выше уровень и другие вычислительные возможности. обычно примерно так: система где есть 1) устройство на линуксе + 2) устройство на МК. линукс с ОС для вычислений, МК для связи с датчиками и ИМ.
      как то так.
      Новичкам (и не только )лучше RM читать , книжки по Си и Хоровица + практика практика практика. Я уже не совсем новичок, но все равно повторяю по кругу эти действия :) А кто хочет просто побаловаться "миганием лампочкой" и сделать это без особых затрат(умственных и временных) и забыть как пропадет интерес - ардуино будет идеально вариант и все эти ОС нафиг не нужны.

    • @VitaliyRu
      @VitaliyRu 4 роки тому

      @@tx-rx По мне так тоже. Либо линух, винда и тому подобное. Либо по стараинке в петле с прерываниями(там своей боли хватит :) Их к слово по возможности лучше тоже избегать.
      В видео описана задача которая прекрасно выполняется последовательно(это не только МК касается, но и той же винды), а ее предлагают сделать асинхронной.
      Выше я там уже Рихтера цитировал
      "В общем, мораль этого вступления такова: многопоточность следует использовать разумно. Не создавайте несколько потоков только потому, что это возможно. Многие полезные и мощные программы по-прежнему строятся на основе одного первично го потока, принадлежащего процессу "

    • @tx-rx
      @tx-rx 4 роки тому

      @@VitaliyRu полностью согласен.

    • @alexpood9227
      @alexpood9227 4 роки тому

      @@tx-rx за Хоровица отдельный привет и спасибо, дядька знатный и дай бог ему долгих лет жизни. Я после окончания университета его до сих пор перечитываю и каждый раз нахожу новое!

  • @agentsmit09
    @agentsmit09 2 роки тому +3

    На ESP32 хотел изначально использовать или библиотеки Arduino, или напрямую язык Си, но как выяснилось что компания Espressif в своих библиотеках всегда использует FreeRTOS. Так зачем мне изобретать то что уже и так эффективно работает. Тем более что для 2-х ядерного процессора лучше использовать ОС, которая упрощает работу с железом.

    • @mvxburov
      @mvxburov 2 роки тому +1

      есть еще nanoFramework от Майкрософт, он тоже поверх какой-то ОС работает, но программировать можно на C#. Для дотнетчиков это просто песня)

    • @agentsmit09
      @agentsmit09 2 роки тому

      @@mvxburov Мне почему-то не удалось его завести на Visual Studio 2019 и опробовать. А так бы сказал что он компилирует, ассемблерные выходные листинги я отлично понимаю.

    • @Ар-к8х
      @Ар-к8х Місяць тому

      Подскажите пожалуйста на esp32 можно ли добиться быстрого чтения данных с акселерометра (5кгц) и быстрой записи на sd карту? Что лучше использовать arduino ide или esp idf?

  • @merzott
    @merzott 4 роки тому +2

    Было бы интересно увидеть видео разбора крупной программы, как в ней использовался FREERTOS и какие опасные моменты нужно учитывать. Вроде штука интересная, но как и где ее стоит применять все равно не очень понятно. В маленьких программах ради удобства - притянуто, маленькую программу как ни пиши - проблем нет никаких. В больших - можно кучу не отлавливаемых интересностей словить - стремно использовать. Вообще контент на канале достойный. +++

    • @PopryagaMike
      @PopryagaMike 4 роки тому

      вот как раз операционная систем и нужна для отлова интересностей. Операционная система имеет средства контроля за работой процессов и имеет средства управления памятью. При использовании ОС есть недостатки - это потеря в скорости реакции и использование большего объема памяти. За это програмист получает возможность управления потоками, профилирование, отладку запущеной системы.

  • @microsinnet7718
    @microsinnet7718 4 роки тому +9

    Пожалуй, содержимое ролика никак не коррелирует с его темой (в заголовке). После прослушивания возникает четкий ответ на вопрос "Почему использование операционной системы оправдано даже в небольших проектах" - да ни почему. Просто так автору кажется. В небольших проектах может быть как раз лучше применить простой дешевый чип с малым объемом памяти, куда FreeRTOS никак не впишется.

    • @anatoliygavrilov958
      @anatoliygavrilov958 4 роки тому +1

      Оправдано тем, что код получается чище и понятней - каждая мини-задача в отдельной функции и без лишнего мусора. Такой код проще и быстрее писать, отлаживать и поддерживать. А время сейчас стоит дороже чипов.

    • @kalobyte
      @kalobyte 4 роки тому +3

      так для автора может быть небольшой проект это не помигать светодиодами, а какая-то замороченная херня
      вот он и говорит, что с виду вроде бы все просто, но есть куча состояний и все они как бы сами по себе должны работать
      и такое лучше оформить при помощи ртос, а не автоматом
      больше сожрет памяти, зато меньше писанины
      если ты бабло получаеш за проект, а не по часам, то в твоих же интересах написать это все как можно быстрее и чтобы через год ты мог понять, что ты там написал и встроить новую плюшку
      а то бывает так, что новая плюшка потянет переписывание всего кода

    • @ЮристЧастнойПракитки
      @ЮристЧастнойПракитки 4 роки тому

      microsin net, на совремнные чипы почти на любой фриртос влазит..

    • @ЮристЧастнойПракитки
      @ЮристЧастнойПракитки 4 роки тому

      Anatoliy Gavrilov, у автора видео лишь иллюзия этого. Он декларирует эти цели, представленный псевдокод их не реализует.

    • @microsinnet7718
      @microsinnet7718 4 роки тому

      @@ЮристЧастнойПракитки Тут ключевое слово "почти". Таки да, именно так. Поэтому нельзя утверждать, что "даже в небольших проектах использование FreeRTOS оправдано". Не все чипы "современные", и ни на все "современные" чипы "влазит" RTOS. Всякий инструмент хорош на своем месте.

  • @alextiga8166
    @alextiga8166 4 роки тому +11

    Процессор - это часть микроконтроллера, какой тут может быть спор вообще?
    никто же не спорит как правильно: компьютер или процессор, если процессор - это часть компьютера.
    микроконтроллер, помимо процессора, включает в себя постоянную память, оперативную память и прочую периферию, если бы он её не включал - был бы просто процессором, а так микроконтроллер.
    если речь про работу процессора - можно сказать и процессор и микроконтроллер, т.к. он этот самый процессор содержит.
    а вообще если человек спорит о таком - это говорит о его полной ограниченности, ведь важно не выбранное слово, а суть за ним стоящая, можно хоть хуёвиной его называть - лишь бы было понятно о чём речь!

    • @Vlad_4572
      @Vlad_4572 4 роки тому

      Ты знаки препинания нахера ставишь? Спорим, что и без них все понятно?!

    • @alextiga8166
      @alextiga8166 4 роки тому

      @@Vlad_4572 вот нет, без них далеко не всегда понятно.
      Казнить нельзя помиловать.

    • @Vlad_4572
      @Vlad_4572 4 роки тому +1

      @@alextiga8166 , конечно, не всегда понятно, потому, и желательно следовать правилам и договорённостям, что бы не было неразберихи, а не называть всё вокруг хуёвинами. Его право называть микроконтроллер как он хочет, моё право, его поправить.

    • @alextiga8166
      @alextiga8166 4 роки тому

      @@Vlad_4572 можно сказать "компьютер выполняет программу", а можно сказать то же самое про процессор. Можно сказать "автомобиль потребляет топливо", а можно сказать то же самое про двигатель.
      Так в чём проблема с "микроконтроллер/процессор выполняет инструкцию"? И то и то правда, процессор - часть контроллера.
      Никто не называет микроконтроллер процессором, но когда речь про часть микроконтроллера которая является arm процессором - и так и так правильно.
      Или я в чём-то ошибаюсь?

    • @Vlad_4572
      @Vlad_4572 4 роки тому +1

      @@alextiga8166 , его дело, как и что называть, но автор не очень хорошо отозвался о тех кто его поправляет и привел пример комментария, типа: вот, смотрите написано же, что это процессор! Так никто и не спорит, что ЭТО(cortex-m) процессор/ядро. Но он упоминая устройство, говорит - процессор. Ты разницу понимаешь? В мануале всё чётко написано, что есть что, не пойму, в чём прикол подменять понятия?

  • @chipunit
    @chipunit 4 роки тому +1

    Спасибо, полезная информация

  • @Andrey-None
    @Andrey-None 4 роки тому +2

    В целом верно, но только примеры выбраны неудачно. Из-за этого объяснения выглядят не очень убедительно. Нельзя объяснять преимущества многопоточности на примере ввода с "клавиатуры" (а в видео это основной пример), поскольку она реализуется исключительно на прерываниях. Не считая конечно новичков, кому кажется проще опрашивать в цикле :)
    Лучше бы объяснили на реальном примере. Вот у меня был проект на AtMega128. На дисплей 128x128 выводится информация из нескольких источников: от часов, от барометра, от термометра, от таймера, от "клавиатуры" и нескольких аварийных кнопок и даже от радио. Оказалось, что удобнее всего реализовать посредством эмуляции многопоточности, когда "менеджер задач" поочередно вызывает "потоки" (по одному на каждый источник), а те, выполнив какую-то часть работы, передают управление дальше. Причем, задачи получения данных от датчиков и вывод на экран обработанных данных были разделены. Единственно, что те же кнопки использовали прерывания, запуская "поток", выводящий на дисплей информацию и проигрывая определенный сигнал. Вот где преимущества многопоточности облегчают написание кода, его отладку и читабельность. Думаю и у Вас нашелся бы подходящий пример из жизни.

  • @slavaglow6933
    @slavaglow6933 4 роки тому +2

    Спасибо за ваши видео. Могли бы вы дать информацию, где описывается FreeRTOS доступным языком? Хочется узнать по подробнее.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      у них на сайте freertos. org

    • @uno7802
      @uno7802 4 роки тому +3

      microsin.net/programming/arm/freertos-part1.html

  • @СергейСтрелочных
    @СергейСтрелочных 4 роки тому +2

    Подскажите, по поводу объёма кода в обработчике прерываний, какие есть ограничения или правила?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +3

      Правило одно вы должны провести внутри обработчика как можно меньше времени. А это значит не делать задержек, не использовать таймауты. Чем быстрее выйдите из обработчика, тем лучше.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +4

      @astrahard Нечаев Вы сами читаете что пишете? Я сказал человеку, что в обработчике прерывания необходимо проводить минимум времени, это является безусловным требованием. Т.к. в любой момент может наступить новое прерывание от любого другого источника. Что в конечном итоге приведет к переполнению стека. Отсюда логично и требование не использовать таймаут и задержки в обработчике прерывания. Более того, это не мое личное придуманное мнение. Ровно то же самое можно прочитать в документации на FreeRTOS и также во всех известных мне учебниках программирования. Более того обработчики прерывания в пределах одного уровня приоритета друг друга не вытесняют. Так что осторожнее с оценками, пожалуйста.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +6

      @astrahard Нечаев Прежде всего я опираюсь на написанное в документации по FreeRTOS, а там прямо указано что обработчик должен быть как можно короче по времени, чтобы прерывания не накладывались друг на друга. Тут без разницы у вас микроконтроллер или большой компьютер. Система прерываний она не меняет своего смысла. Во-вторых я руководствуюсь написанным на сайте Cortex это как бы разработчик ядра микроконтроллеров. Ну а в третьих, programming manual на наши микроконтроллеры. Но если все это не заслуживающие внимания документы, то не проблема снимаю шляпу. Вы видимо великий специалист и знаток вопроса. Даже спорить не буду.

  • @acrsofter
    @acrsofter 4 роки тому +2

    я бы опредил пременимость 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 роки тому +1

      @@acrsofter это говорит скорее о скиллах разработчика.

  • @alximedkylibin3059
    @alximedkylibin3059 4 роки тому +1

    Всем привет ! Уж посмотрел Я и почитал коменты , и вот вопрос ко всем знающим . Если есть 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 роки тому +1

      Здравствуйте! Данную задачу можно решить на любом МК и разными способами, так что размер занимаемой памяти оценить сложно. Лучшем будет МК с которым знакомы. Если ни с чем не знакомы, то начните с Arduino. Самой простой под Вашу задачу будет достаточно.

  • @aleksandrzakutnyy4450
    @aleksandrzakutnyy4450 4 роки тому

    актуально. нужно на практике показать сколько сьедает ОС ресурсов. считаю по умолчанию ОС много сьест. для меня актуальным примером будет приложение электропривода на 4-5 задач на 1-10 кГц. а так конечно ОС будет удобно использовать. а у тена с бочкой воды постоянная времени 20 минут или 1 час. с теном можно и виндос использовать ;)

  • @ПетерФеренци-н3о
    @ПетерФеренци-н3о 3 роки тому +2

    FreeRtos ОСРВ? В новой упаковке? Простите, с 90-х этим не занимался. Опять пришлось. Очень полезный канал.

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому

      RTOS и переводится как ОСРВ

  • @ЮрийКривощёков-ш3ж
    @ЮрийКривощёков-ш3ж 3 роки тому +1

    Спасибо! Это то что надо!

  • @СергейТ-т8э
    @СергейТ-т8э 4 роки тому +2

    Скажите пожалуйста еще про другие ОС например riot-os

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      А я все искал, кто же меня просил про другие ОС видео сделать. :-) выполнено.

  • @gimeron-db
    @gimeron-db 4 роки тому

    Всё пытаюсь понять, как именно происходит переключение контекста подпрограмм. На ум приходит только подмена адреса возврата при выходе из обработчика прерывания (как это делалось некоторыми утилитами в DOS).
    Т.е во время работы одной программы срабатывает прерывание, диспетчер (в обработчике прерывания) сохраняет контекст и адрес возврата текущей программы, восстанавливает контекст и адрес следующей и "возвращает" управление. При следующем прерывании вторая программа меняется на третью и т.д.
    Хорошо, если памяти у контролёра хватит, чтобы хранить контексты всех программ.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +2

      Наверное причина в том, что вы пытаетесь мыслить категориями привычными для IBM PC совместимых компьютеров. Вы и написали - "программ". По факту же мы имеем дело с небольшими задачами выполняющими те или иные функции. Разумеется памяти им хватит. На канале достаточно роликов по этой операционной системе, даже есть фрагмент где показывается как вывести в консоль реальную загрузку и стека и кучи. Можете посмотреть, взять там несколько строк кода и даже попробовать.

  • @NeussMsk
    @NeussMsk 4 роки тому +1

    Как вы в keil включили всплывающие подсказки? (выпадающие списки в редакторе у курсора)

  • @Mura905
    @Mura905 4 роки тому +3

    Потому что микроконтроллер СТМ32 имеет в составе процессор Кортекс М4. А кроме него ещё память и много чего.

  • @namernum5692
    @namernum5692 4 роки тому +1

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

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +1

      Если вам нужны "жестко заданные тайминги" то возьмите таймер и он вам очень точно измерит временные интервалы. Что касается последовательности переключения, то совсем не все задачи так примитивны как вы пытаетесь это представить. Есть весьма сложные алгоритмы. И в этих случаях применение операционной системы экономит много времени как на разработку так и на отладку. Более того, использование FreeRTOS весьма заметно повышает общую живучесть системы в целом.

  • @АлександрПронин-х3ъ

    Необходимо указать важный момент. Если Вы пишете программу , НАПРИМЕР, передачи по радиоканалу потокового аудио, то FreeRTOS, не справится с подобными задачами и необходимо написать программу в классическом режиме последовательный код с прерывателями ит.п., подсчитывая в дебаггере каждый такт,, чтобы соблюсти точные временные слоты оцифровки и передачи пакета с накопленными сэмплами. . Поясню. Вы указали, что квант времени отводимый FreRTOS 1 ms. Я в программе каждые 125 мкс оцифровываю внутренним АЦП аналоговую речь, попутно накапливаю оцифрованные сэмплы во внутреннем буфере ОЗУ порядка 300 байт, при заполнении буфера я передаю его по SPI в CC1100 (радиопередатчик) . При употреблении FRERTOS у меня все поплывет, особенно в программе приемника , теорема Котельникова нарушится, пакеты с цифровыми сэмплами (речью) будут приходи не в нужные слоты времени, соответственно на ЦАП в каждые 125 мкс не будет поступать очередной сэмпл для декодирования. Так что,FRERTOS не поможет для решения данной задачи. для устройств, которые разрабатываете Вы, и для устройств которые не требуют точного до 1 мкс подсчета выполнения определенных частей программ и промежутков между ними, FREERTOS самое то.
    Хотя я возможно не совсем прав.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +4

      Использование операционной системы никак не влияет на быстрые процессы если они вам необходимы. DMA, таймеры, прерывания, это все никто не отменял.

    • @АлександрПронин-х3ъ
      @АлександрПронин-х3ъ 4 роки тому

      @@VladimirMedintsev Владимир, будьте добры посоветуйте какую-нибудь литературу по FREERTOS, желательно англоязычную.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +2

      freertos. org там все в виде pdf есть. прям много.

  • @anatoliydad0x078
    @anatoliydad0x078 4 роки тому +1

    Все идет к усложнению архитектуры проца.. Уверен появится аппаратный менеджер задач, который например будет включать задачи по таймерам и отводить им сколько нибудь тактов... Потом выяснится, что два таких проца еще лучше чем один, потом защитят память кольцами защиты от вирусов, писАть под stm32(64/128/../2048) без ОС станет невозможно, выдут книги по программированию для ОС ртос.... Уверен мы наблюдаем ускоренную эволюцию от процессоров 8080..i486,...233mmx,....core i3.... и параллельно ms-dos...windows 3.11,...NT...XP....

    • @TheNamelessOne12357
      @TheNamelessOne12357 4 роки тому +3

      На самых крупных микроконтроллерах STM32 уже запускается Linux. А в простых это не нужно.

  • @ГеоргийАксенов-к9ь

    Расскажите о работе прерываний с ОС, они работают асинхронно от нее и используют стек текущей задачи и требуется выполнять дополнительные телодвижения в обработчике прерываний?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Прерывания используются точно так же как и без ОС. Единственное, для управления некоторыми функциями ОС из обработчиков прерываний надо вызывать специальные функции. Но это не сложно.

    • @ЮристЧастнойПракитки
      @ЮристЧастнойПракитки 4 роки тому

      Vladimir Medintsev, про приоритет не сказали..

  • @ДимаДима-к1н
    @ДимаДима-к1н 4 роки тому +1

    ! о!; 14минута(прошло час) скелетное программирование, кооперативная многозадачность >>> OS...ОЧЕНЬ ДОХОДЧИВО!

  • @kardanium
    @kardanium 3 роки тому +3

    Я сейчас пишу программу, так уж вышло, для AVR архитектуры (Atmega168) и меня эта туева хуча конечных автоматов уже успела достать. На I2C два устройства - делай аатомат. UART - делай автомат. Опрос клавиатуры и генерация событий - делай гребаный автомат. Короче, для всего, что может впустую застопорить главный цикл - нужен автомат. Я настолько упоролся этими автоматами, что даже для записи в EEPROM хотел его слепить, но остановило то, что запись ест немного тактов, а транзакции туда короткие. Погоня за быстродействием быстро сожрала половину ПЗУ. С RTOS все это безобразие было бы гораздо проще.

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому

      Есть порт FreeRTOS под AVR, если не ошибаюсь.

    • @kardanium
      @kardanium 3 роки тому +4

      @@DmitryKandiner Проект уже окончен. В нем обширный GUI. Места, возможно, не хватит. Но можно попробовать. Ибо FreeRTOS туда прямо просится. На I2C шине сидит кучка периферии, активно задействуется UART и GUI хочется без тормозов. Памяти всё это сожрало намеренно (13 КБ ПЗУ и 400 байт ОЗУ), но при этом нет тормозов, камень всё успевает и код пригоден для дальнейших доработок и дополнений (модульный принцип). Остался килобайт на маневры в будущем и ещё два заняты бутлодером.
      И самое смешное - для оптимизации объема, некоторым функциям пришлось ставить атрибут no_inline. На производительности это не сказалось практически никак, но сэкономило целый килобайт ПЗУ. Чем глубже лезешь, тем больше сюрпризов от компилятора AVR GCC. Даже в таких вещах, как макросы и константные числовве выражения. Они все имеют тип int, который размером 2 байта в AVR. И когда выполняешь операции над переменными int32 и константами, компилятор без предупреждения приводит int32 к int (16), что у неподготовленного адепта Механикус может вызвать чувство вины перед Омниссией. 🤣

    • @squidyPet
      @squidyPet 3 роки тому

      @@kardanium рекомендую посмотреть на st. Все что вы описали делается с использованием директ мемори аксесс и вообще не жрет ресурсы. А граф интерф делать на главном камне некашерно даже на неспециальнвх st. Есть же готовые с управлением по usart

    • @ravil6018
      @ravil6018 3 роки тому

      Здравствуйте! Мне очень интересны автоматы, я сам на них пишу, но пока очень не опытен в этом деле. Можете ли вы поделиться кодом проекта, чисто в образовательных целях?

  • @iotmanager
    @iotmanager 4 роки тому +1

    Вот такой вопрос. Если представить что у нас есть 2 задачи freertos с одинаковым значением vtaskdelay допустим 100 мс для обоих. То при таком раскраде как эти две задачи будут работать друг относительно друга? Если речь идет о автоматическом распределении процессорного времени то будет вызываться перавая задача а через 50 милисикунд вторая а потом еще через 50 снова первая. Или же как то иначе? Какую логику преоритезации задач несет в себе это "автоматическое распределение процессорного времени"?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      vtaskdelay определяет какое время диспетчер задач не должен передавать управление данной задаче. если у вас 2 задачи и они обе через osDelay указали что их не беспокоить 50 миллисекунд, то ближайшие 50 секунд будет выполняться только idle, а потом опять задачи 1 и 2 по очереди.

    • @sergbo3114
      @sergbo3114 4 роки тому +1

      Да. Почти так. Но еще нужно учитывать что эти задачи будут делать. Если внутри есть полезная нагрузка отличная по тактам от другой, то циклы будут перескакивать.
      И отдельный вопрос как они были запущены одновременно или например 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 сделает на какое-то колличество циклов больше, потому как нагрузки у неё меньше.

  • @oleholeynikov8659
    @oleholeynikov8659 4 роки тому

    Владимир, здравствуйте! Спасибо за видео, пробую работать с ОС в своем проекте. Сразу возник вопрос о определении размера стека для задач. Возможно вопрос новичковый, но было бы круто выделить немного времени в видео о стеке, логике расчета, методах оценки ресурсов МК в отладчике (как с РТОС, так и без нее).

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Так вроде же есть видео про стек FreeRTOS. Я там даже на примере показывал как это делать.

    • @oleholeynikov8659
      @oleholeynikov8659 4 роки тому

      @@VladimirMedintsev точно! я как-то проглядел. Спасибо

    • @oleholeynikov8659
      @oleholeynikov8659 4 роки тому +2

      @@VladimirMedintsev Всё пересмотрел по FreeRTOS из плейлиста. Получилось запустить, почитать расход стека, все очень удобно. Эти видео - какой-то праздник! Еще раз спасибо.

  • @ozn_
    @ozn_ 4 роки тому +1

    А разве приоритет прерываний не должен быть меньше приоритета обработчика задач? А вообще прикольно , давайте больше видео про ос!

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      честно говоря не помню. что-то было на эту тему у них в документации. потом посмотрю.

    • @ihanick
      @ihanick 4 роки тому

      приоритет прерывания может быть выше чем приоритет обработчика задач, но такое прерывание не может вызывать функции freertos напрямую

  • @nangelo0
    @nangelo0 4 роки тому

    Как сильно отличаются понятия "сложный код" для контроллеров/процессоров и для высокоуровневых приложений для серверов/десктопов и т.д.

  • @Влад-с7к5й
    @Влад-с7к5й 4 роки тому +1

    А эта freeRtos под капотом что-то вроде невытесняющей многозадачности с прерываниями по таймеру реализует, правильно понял? Т.е. если в какой-то таске, например, что-то зависло, вся система зависнет, как оно в мсдос было? Или там как в посикс с fork() / еxec(), таблицей процессов и т.д.?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      зависнет только одна задача. этот факт легко определяется и вы можете ее перезапустить.

    • @Влад-с7к5й
      @Влад-с7к5й 4 роки тому

      @@VladimirMedintsev вау, это круто, учитывая такое небогатое ресурсами окружение.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +1

      @@Влад-с7к5й В видео ua-cam.com/video/wTK11IDpg7s/v-deo.html я рассказываю как определять загрузку процессора задачами, этот алгоритм можно использовать и для определения зависшей задачи. Ну или можно проще. Можно чтобы задача сама обновляла какой-нибудь флаг и тогда уже можно принимать меры к ее перезагрузке или лечению.

    • @anatoliygavrilov958
      @anatoliygavrilov958 4 роки тому +1

      В FreeRTOS много разных настроек, в то числе и тип многозадачности. По умолчанию он вытесняющий, ток что зависания всей системы не будет.

    • @Rimmdp
      @Rimmdp 4 роки тому +1

      Может работать как в вытеснящем, так и в кооперативном режиме, плюс в смешанном режиме.

  • @MikeNugget
    @MikeNugget 4 роки тому

    Хорошее видео и объяснение доступное. А есть что-нибудь по работе с видео камерой?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Абсолютно непонятно что такое работа с видеокамерой.

  • @anatolyilinykh7888
    @anatolyilinykh7888 4 роки тому +2

    У меня это видео и первая часть трилогии FreeRTOS испорчено.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Проверил на 5 (пяти) разных компьютерах. Все работает. Авторы роликов заливают их на ютуб, дальнейшее от нас не зависит.

    • @anatolyilinykh7888
      @anatolyilinykh7888 4 роки тому

      Да, согласен, только на одном из 5 глючит. Извините что не исправил.

  • @MatthewBystrin
    @MatthewBystrin 4 роки тому +1

    Спасибо за доклад. Очень долго заглядываюсь на FreeRTOS. Понимаю, что на вопрос тяжело ответить однозначно из-за весьма размытых границ и всё же. Есть ли у вас какие-то свои критерии по которым вы решаете стоит ставить FreeRTOS или не стоит ? Буду очень благодарен конкретным примерам . Заранее спасибо

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +11

      Вот сидите вы такой и с философским (обязательное условие) взглядом обращенным на облака обдумываете свою программу. Так вот если она рисуется вами как единая задача, то применять FreeRTOS НЕ НАДО. А вот если у вас в голове вырисовываются несколько процессов или подзадач, то применять FreeRTOS НАДО.

    • @MatthewBystrin
      @MatthewBystrin 4 роки тому +1

      @@VladimirMedintsev Спасибо за ответ )

    • @ersafap
      @ersafap 4 роки тому +1

      У меня принцип такой: если оперативы в контроллере 8кб и более, значит надо. Если 4кб - может быть. Все равно со временем нагородишь самодельный ее аналог худшего качества.

    • @Wo_Wang
      @Wo_Wang 4 роки тому +2

      Ага, вот и я думаю: а зачем в микроконтроллере нужна многозадачность?
      )

    • @ersafap
      @ersafap 4 роки тому +4

      @@Wo_Wang при разработках важно правильно понимать что ты хочешь сделать и правильно ставить задачу. Мне не нужна многозадачность, мне нужно изолирование друг от друга потоков кода, выполняющих разные задачи в устройстве, мне нужна возможность легко тасовать эти потоки, не нарушая работу всего остального, мне нужно чтобы программа оставалась линейной и простой так долго, как это возможно. ОС дает мне все это. Я уже сталкивался при разработках с ситуациями, когда городил жуткий код чтобы в итоге он сделал тоже самое, что доступно из коробки под freertos. Самый ценный ресурс - время. Мегагерцев и мегабайтов полно, времени, обычно - нет.

  • @aleksandrivanov4756
    @aleksandrivanov4756 4 роки тому +1

    Алгоритм который вы описали можно реализовать и без применения FreeRTOS
    , будет работать надёжнее но читаться хуже

  • @НиколайПр-з3в
    @НиколайПр-з3в 4 роки тому +3

    Нужно еще одно видео - ибо вообще непонятно как скрестить FreeRTOS с задачей требующей высокого быстродействия. Вот вводные: оптический датчик с 1800 линий на оборот стоит на шпинделе станка, который имеет максимальную скорость 2000 оборотов в минуту - нужно получить данные о положении шпинделя и в зависимости от этого вращать шаговый мотор - логику вы эту в прерывание не засунете - ибо там расчетов много и из этого вы "отодвинете" время срабатывания других прерываний. Засунуть логику обработки в задачу, которая выполняется не чаще 1мСек и имеет время старта "как FreeRTOS решит " - это вообще не вариант. Вот как вы можете решить данную задачу с FreeRTOS ?
    А если честно - я вообще не понимаю - почему FreeRTOS - это система РЕАЛЬНОГО времени ибо операционка MS-DOS вот это система РЕАЛЬНОГО времени, а та же Windows это уже операционка НЕРЕАЛЬНОГО времени и там тоже тайминги в 1мСек и время старта задачи там тоже "как операционка решит".

    • @avi-crakhome2524
      @avi-crakhome2524 4 роки тому +3

      Если считать программно каждый тик энкодера - то да, непосильная задача для любого- даже самого быстрого процессора.
      Но вместо подсчётов тиков энкодера - достаточно опрашивать его аппаратную часть на таймере, через фиксированное количество времени. В этом случае считается не его текущее положение - а изменение за фиксированное время, со сдвигом к нулю. В этом случае доступен весь диапазон таймера работающего на энкодер, и отпадает необходимость как-либо управлять его переполнением.
      Ведущий мотор может вращаться с низкой скоростью, для того чтобы ловить это состояние - используется дробные числа. Старшая часть повторяет значение аппаратного энкодера, а младшая - дробные числа.
      Для ведомого шагового двигателя считается положение в которое он должен встать через фиксированное время того-же таймера, что запускает считывание таймера энкодера. Тут тоже дробные числа, и тоже с переходом через ноль. Перемножаем дробное от энкодера - и получаем любое разумное соотношение скоростей вращения. И да, это угловая скорость.
      Дык вот, считывание и управление происходит в прерывании, или через дма. А обработку можно делать в основном цикле. Потому как на фиксированную задержку в 5-30мс - механика станка (инерция) просто не в состоянии отреагировать.
      Общая задача достаточно простая, и может целиком выполняться в прерывании (буквально несколько строк).
      Ос может понадобится для работы с экраном и кнопками. Потому как реакция человека заметно ниже требований к железу, тут +- лапоть к задержкам - вообще никто не заметит.

    • @НиколайПр-з3в
      @НиколайПр-з3в 4 роки тому

      @@avi-crakhome2524 - я завис на вашей фразе и дальше уже не читал: "Но вместо подсчётов тиков энкодера - достаточно опрашивать его аппаратную часть на таймере, через фиксированное количество времени". Аппаратная часть промышленного оптического энкодера есть фотодиод и как вы его можете опрашивать периодически чтобы узнать положение шпинделя станка - я даже не представляю.

    • @avi-crakhome2524
      @avi-crakhome2524 4 роки тому +4

      @@НиколайПр-з3в Аппаратный таймер чипа stm32xxx - режим энкодера. Вход две линии от промышленного энкодера, выхлоп - значение счётчика таймера. Вот именно это значение и нужно считывать через фиксированные промежутки времени.

    • @НиколайПр-з3в
      @НиколайПр-з3в 4 роки тому

      @@avi-crakhome2524 спасибо - посмотрю данный вариант - но "фиксированные промежутки времени" через freeRTOS в 1мСек???

    • @avi-crakhome2524
      @avi-crakhome2524 4 роки тому +2

      @@НиколайПр-з3в Не через, а совместно. В ос есть таймер, который фиксировано срабатывает каждую 1мс. Если в его прерывание добавить немного кода - система не рухнет.
      А вот изменение коэффициентов множителей для ускорения/торможения и начальную синхронизацию - можно делать через freeRTOS. Этот код жирнее, и не требует моментальной реакции.

  • @Korbomen
    @Korbomen 2 роки тому +1

    Нельзя в прерывания засовывать большие куски кода, а как на счёт работы usb?

    • @TK-wh6lf
      @TK-wh6lf 2 роки тому

      Обрабатывать в задаче используя семафоры

  • @SerB-Radio
    @SerB-Radio 2 роки тому +1

    Доброго дня. Спасибо Вам большое за познавательные видео. Только начинаю разбираться с Freertos и хотелось бы немного Ваше консультации. Пытаюсь большой проект адаптировать под ОС. Вот подсоединил через куб ОС, раскидал легкие задачи по приоритетам и таймигнам вызова - все очень хорошо, функционал заработал. И вот у меня есть большая функция расчетов, сей кусок кода занимает около 30кБ. Естественно, когда я эту функцию кладу в задачу у меня все вешается. Как мне его положить в Tasks? или вообще что мне делать? Расширять размер стека для данной задачи, как я понимаю? Спасибо.

    • @VladimirMedintsev
      @VladimirMedintsev  2 роки тому +3

      На канале ещё будут видеоролики по операционной системе freeRTOS. Я постараюсь частично ответить на эти вопросы.

    • @SerB-Radio
      @SerB-Radio 2 роки тому

      @@VladimirMedintsev Спасибо Вам большое

  • @astarkmn
    @astarkmn 4 роки тому +1

    А почему бесконечные циклы в задачах выполнены через for? В этом есть какой-то сакральный смысл?

    • @Rimmdp
      @Rimmdp 4 роки тому +1

      Нет. Это дань моде. По сути одно и тоже, что и while

  • @VAscetic
    @VAscetic 3 роки тому +1

    Так. Созрел глупый вопрос: А при переключении на другую задачу, значения переменных и состояние выполняемой сохраняется? Судя по тому, что Вы упомянули отдельный стек, вроде ответ должен быть да. Но можно для деревянных уточнить ))

    • @VladimirMedintsev
      @VladimirMedintsev  3 роки тому +3

      Да, сохраняется.

    • @VAscetic
      @VAscetic 3 роки тому +1

      @@VladimirMedintsev Спасибо, очень помогли понять в каком направлении копать. Столкнулся с такой необходимостью, когда не плохо бы, чтобы одновременно выполнялись несколько задач, параллельно так сказать. Понятно было, что решение где-то есть.. но где... ))

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому +2

      @@VAscetic Каждой задаче под FreeRTOS выделяется собственный стек, одна и таже функция может использоваться для нескольких одинаковых задач (например, для обработки портокола на нескольких последовательных портах одновременно*), и стек у каждой задачи всё равно свой. Статические переменные работают как обычно.
      * Не совсем одновременно, конечно, а под управлением диспетчера задач.

    • @VAscetic
      @VAscetic 3 роки тому +1

      @@DmitryKandiner Ага, спасибо, я в целом понял концепт. По сути, очень сильно такого плана решение мне требовалось пока 1 раз, и то более менее обошёлся. Когда с ETH учил контроллер работать, для поддержания одновременно нескольких активных соединений TCP по разным портам. А так, в большинстве случаев, достаточно стандартного набора прерываний, тем более если в контроллере есть DMA. Ну или я ещё в сложные задачи не залез :)

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому +1

      @@VAscetic как вариант -- построение веб сервера. Один процесс только принимает новые соединения, и запускает дочерние процессы на каждый запрос. А запросы, в свою очередь, обрабатываются каждый своим экземпляром одного и того же кода (важно не полагаться на статические переменные -- они общие для всех). По окончании обработки процесс закрывает соединение и самоубивается.

  • @mnanorn
    @mnanorn 4 роки тому +2

    А знаете ли Вы, почему появляется потребность вот в таких видео? А потому, что на дисциплине "информатика" операционная система - это системное ПО, задачей которого является управление файлами. Я не шучу. Именно в такой формулировке. А что такое ядро, системные сервисы и даже, банально, механизм прерываний - этого знать не нужно. И ладно ещё общеобразовательный предмет. В ВУЗе дают такие определения!
    Кому интересно, Тёненбаум, "Современные ОС". Всё понятно и доступно.

    • @kardanium
      @kardanium 4 роки тому

      Видимо это явление консерватизма. Первые ОС действительно создавались вместе с файловыми системами и предназначались для работы с файлами. MS-DOS тоже зовётся операционной системой, однако многозадачности там нет.

    • @mnanorn
      @mnanorn 4 роки тому

      @@kardanium не соглашусь и оспорю. Первые ОС - как раз таки пакетные загрузчики вычислительных задач. Тогда ещё понятия "файловая система" не было. Была перфолента, стопка перфокарт или (в лучшем случае) пара десятков метров магнитной ленты. Задача - последовательный запуск заданий и вывод результатов куда-нибудь (чаще, на печать).

    • @kardanium
      @kardanium 4 роки тому

      @@mnanorn Ну так, тогда тоже небыло многозадачности, ядра, диспетчера и прочих подобных вещей. Был просто код, который читал перфоленту, заносил ее в ОЗУ и отдавал загруженной программе управление. Позже ленты заменили на диски и следовательно, на файлы. Многозадачность появилась позже, когда вычислительные ресурсы и развитие компьютеров стали это позволять.

    • @mnanorn
      @mnanorn 4 роки тому

      @@kardanium Вы считаете прерывания многозадачностью? Уточню вопрос: Вы считаете возможным организовать действительную многозадачность на одном вычислительном ядре?

    • @mnanorn
      @mnanorn 4 роки тому

      @@kardanium и, да, изначальная тема комментария была "подмена действительной роли операционной системы в образовательном процессе". )

  • @nangelo0
    @nangelo0 4 роки тому +3

    Так и не "пересели" на CubeIDE?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Я говорил что учебные штуки останутся на Keil. Он более распространен. В кубиде только коммерческие за денежку.

    • @Asmcavr
      @Asmcavr 4 роки тому

      @@VladimirMedintsev она вроде бесплатная

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +1

      @@Asmcavr Кэп? Вы ли это? Я в кубеиде делаю коммерческие проекты, за которые деньги получаю именно потому что она бесплатная чтобы не нарушать лицензионное соглашение и законы.

    • @Asmcavr
      @Asmcavr 4 роки тому

      @@VladimirMedintsev Сорян, я неправильно вас понял).

    • @sovchem1275
      @sovchem1275 4 роки тому

      @@VladimirMedintsev Так теперь считай все и делают, точнее пишут в комфорте, в Keil / IAR, а на продажу пересобирают из под CubeIDE ;)
      Еще бы отладку с программатором в этом CubeIDE допилили, а то здорово подбешивает шиться вне среды

  • @АлексейБочаров-т1и
    @АлексейБочаров-т1и 3 роки тому +1

    Спасибо за обзор.

  • @vadimnikolaevich2886
    @vadimnikolaevich2886 3 роки тому

    Здравствуйте!
    Интересует возможность адаптации примеров из CubeMX по работе с USB (CDC, CDC+MSD) под FreeRtos. Есть ли такие примеры в принципе? Или для примеров CubeMX лучше подходят машины состояний?

    • @VladimirMedintsev
      @VladimirMedintsev  3 роки тому +1

      Пример не нужно адаптировать. Это не программирование получается а извращение. Пример необходимо изучать с целью научиться работать с технологией или периферией. Библиотеки USB от ST прекрасно работают с FreeRTOS.

  • @alexeidubrovin5234
    @alexeidubrovin5234 2 роки тому +2

    конечно интересно, но вот на столе лежит две конкретные задачи - зарядка LiFePO4 100кГц ШИМ с ПИД-регулятором на stm32f303 и передача спектра звука 32кГц (естественно через fft) с I2S по tcp на комп на stm32f745, ни в одном из случаев freeRTOS ничего не успевает, о каких osDelay или квантах в мс идёт речь, если нужны мкс? в первом случае, кстати даже HAL не успевает, перешёл на LL, приходится писать отсебятину, если речь идёт о чтении кнопки, выводе на дисплей, где сотня миллисекунд вообще ничего не решает - одно дело, если же настоящий real time с квантами в микросекунды, то нужно намного глубже разбираться во freertos, чем в прерываниях и DMA

    • @NoName-yp9to
      @NoName-yp9to Рік тому +3

      Для зарядки лития нужна скорость ответа регулятора в 100кГц?) Да, ШИМ может понадобиться в 100кГц, но используйте для этого хардварный таймер. А пид-регклятору и 1кГц overkill.

    • @vladevro222
      @vladevro222 Рік тому +1

      @@NoName-yp9to . Ну ну. Сравнил шип 1кГц и 100кГц. Там какбы индуктивность (трансформатор) совсем разные по габариту получаются)))) Автор выше прав - если что-то медленное и неответственносое, то freertos рулит. А когда надо выше 1кГц то- сосай мосай

    • @NoName-yp9to
      @NoName-yp9to Рік тому +8

      @@vladevro222 а теперь перечитайте то, что я написал выше. Вобще то я предложил шим генерить с частотой 100кГц аппаратным таймером, а с частотой 1кГц - только лишь обеспечивать регуляцию. А уж если нужна какая то быстрая обратная связь (например по току КЗ), то в большинстве стмок есть компаратор.

    • @Blow_BacK
      @Blow_BacK Рік тому

      @@NoName-yp9to зачем страдать если написать напрямую просто проще? Без абстракции ради абстракций. Просто сделать задачу. Единственно зачем там стм вопрос. Там какая нить аттини или пик вполне.

    • @sc0or
      @sc0or Рік тому +8

      Вы просто не захотели заниматься трассировкой. И не было бизнес-заказчика, который правильно бы подсчитал все свои текущие и будущие затраты. Я подозреваю, что для каждой из Ваших задач есть аппаратные решения. И для заряда аккумулятора, и w5500, и, возможно, какой-то dsp со встроенным fft. Вам останется только взять кракозяблу для управления периферией. Код - минимальный, поддержка - дешевая, конец производства - не приговор, затраты на переписывание управляющего кода - минимальные. FreeRTOS - для правильно организованного проекта.

  • @Siliverst
    @Siliverst 4 роки тому

    Если квант времени у ОС 1мс, как быть в случае, когда имеется задача, которую нужо успевать обрабатывать за время от 1мс? Эта функция или реакция на внешнее воздействие, или она в принципе должна вызываться с периодом около 1мс.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +1

      дык таймеры и прерывания.

    • @Siliverst
      @Siliverst 4 роки тому

      @@VladimirMedintsev Т.е. имеется ввиду совмещение двух подходов? Задачи не требовательные к времени отклика - крутим в RTOS а задачи которым нужно обеспечить быстродействие пишем по старинке? Я в своё время писал много вещей у котрых большинство функций не требовательно ко времени, т.е. их можно выполнять с периодом 100мс просто по очереди. Но есть обработка внутренней логики которую нужно успеть за 1mc. Ещё есть фильтры для которых важно тактирование с постоянным периодом. Есть внешние прерывания. Есть UART в который нужно ответить желательно за 1-2мс. Я написал свой диспетчер не требовательных к времени отклика задач, и да, согласен с Вами, написание таких вещей тянет за собою много времени. Но всё равно остаётся ещё много задач, для которых время отклика важно. И всё это крутится в mainloop и да, на pipelined 8051 8МГц loop time получается около 1мс. Меня не отпускает мысль, что при использовании RTOS я бы мог обрабатывать быстрые задачи ещё быстрее... Это возможно?

    • @megannnn98
      @megannnn98 4 роки тому +1

      @@Siliverst Из прерывания можно переключать контекст на более приоритетный процесс.

  • @denwerxampp4035
    @denwerxampp4035 4 роки тому

    ув. автор, планируете ли обзор других RTOS систем? Напр. Mbed OS ?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +1

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

  • @sergbo3114
    @sergbo3114 4 роки тому

    Не понимаю откуда такие вопросы в комментариях про прерывания и быстродействие. Ну если вам нужно последовательно что-то считать используйте ДМА. Да и с чего вы взяли что ОС это замена прерываниям. Это как что лучше мясо или мел?

  • @ufers1027
    @ufers1027 4 роки тому +1

    Пример для описания многопоточности не самый логичный. Многопоточность имеет смысл, если управляется несколько устройств с одного МК. К примеру (если рассуждать про тен как в примере) - если мы хотим его переключать один раз за 100 тактов системного таймера, нет никакого резона чаще опрашивать датчики температуры. Проводить расчеты/вычисления чаще, чем поступают новые данные тоже не логично. Т.е. в примере с теном все действия должны выполняться на одной частоте. И если позволяют ресурсы МК, то почему бы не делать это максимально часто, т.е. просто оставив код в бесконечном цикле. Единственное что логично вынести в отдельный поток это вывод на дисплей, его нет смысла обновлять чаще чем 50-200 мс.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Так многопоточности или все-таки многозадачности?

    • @ufers1027
      @ufers1027 4 роки тому

      @@VladimirMedintsev а как не назови сути не меняет) так же как процессор или микроконтроллер. если устройством нужно управлять 1 раз за 100 тактов, то не имеет смысла опрашивать датчики и проводить вычисления чаще или реже этого

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Не, я просто уточнил.

    • @DmitryKandiner
      @DmitryKandiner 3 роки тому

      @@ufers1027 еще как имеет! Например, если реализовано управление PID, то тенденции изменений можно отслеживать с бОльшим разрешением, чем выдавать команды на управление.

    • @ufers1027
      @ufers1027 3 роки тому +1

      @@DmitryKandiner Данные на выходе PID будут одни и те же т.к. не изменяется показания датчиков (обратных связей) и входного воздействия. Я работаю в данной области больше 15 лет)

  • @TK-wh6lf
    @TK-wh6lf 2 роки тому +4

    Все яйца обычно в одну корзину не кладут, тот кто говорит надо аппаратную часть жестко вести жестко привязанную ко времени и freertos это неправильный выбор для техпроцессов - используйте свою периферию: ПЛИС, DSP и тд, а stm очень хорошо на FREErtos может дирижировать вашим оркестром при этом отображая данные на дисплей и отправляя/принимая уставки куда нибудь сразу по нескольким каналам ю, при этом можно что-то не критичное ко времени привязать на саму стм что-то вроде температуры, заряда акб и тд, осциллограф из него не сделаешь, дельта-сигма фильтр из него лепить? Один контроллер на функцию? Да это просто кошмар такое предлагать, тогда на устройство надо 5 контроллеров или очень толстый стм. Автор учит как использовать стм, а вот как его использовать с умом тут каждый должен вырасти сам.

    • @Ар-к8х
      @Ар-к8х Місяць тому

      То есть stm32 не лучший вариант напримдля бысьрого чтения данных с акселерометра (5кГц) и быстрая запись на sd?

  • @vadimerofeev1148
    @vadimerofeev1148 4 роки тому +3

    Все эти ртосы очень напоминают ардуину. Расточительно, но может пригодиться при унификации подключаемых к проекту модулей: вставили INIT и все остальное модуль запустит. Именно так пишут свои примеры разработчики микроконтроллеров, например, STM.
    Основной недостаток - все это очень медленно. За время переключения с одной задачи на другую, в моих проектах успевают выполниться все мои задачи. При переключении диспечер сначала обрабатыыает все очереди событий, выбирает задачу, потом собирает чемоданы от текущей задачи и распаковывает для следующей. Я пишу сложные многопроцессорные приложения с обработкой звука в реальном времени, комуникацией, графикой, вложенными прерываниями, распределением приоритета и т.д. Мой опыт работы 27 лет. Применение ртос не оправдалось нигде. Все решается проще.

  • @remontlive
    @remontlive 4 роки тому

    Пожалуйста, пожалуйста, пожалуйста ответьте на вопрос, а то я не понял: если у нас, например, всего 5 задач в ОС, на каждую проц тратит 1 ms, что происходит на 6-ю ms, он переходит на первую задачу или ждет 995 ms, потом переходит на 1ю задачу?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      на первую задачу, если она не в простое. подробно тут - ua-cam.com/video/wx3-oESwx_M/v-deo.html

  • @linovermac
    @linovermac 4 роки тому

    *_Что за программа или компилятор?, пожалуйста, напишите название таймкод _**_2:02_*

  • @DrOlegLebedev
    @DrOlegLebedev 4 роки тому +1

    Посмотрел коменты. Прям из крайности в крайность ))) FreeRTOS имеет 3 типа многозадачности, в тч кооперативную и гибридную. Ну т в целом, сражаться за каждый такт процессора смысла нет, тк стоимость такта снижается. К тому же, всегда приятно иметь "коэфициент спокойной ночи" в виде некоторого запаса по ресурсам и перспективам.

  • @tvirkutsk5830
    @tvirkutsk5830 3 роки тому

    Огромное спасибо!

  • @Vlad_4572
    @Vlad_4572 4 роки тому +5

    Ну вы же умный человек, почему кидаете всё в кучу? Правильно, Cortex-M4, это процессор, никто и не спорит. Но микроконтроллер, это же устройство на базе микропроцессороного ядра. Наверное это проблема всех узких специалистов.

    • @alfarabius
      @alfarabius 4 роки тому

      А какая тут проблема? Пойдет человек к поставщику и купит микропроцессоры вместо микроконтроллеров? Нет, все на одном чипе находится, а большинство вообще только на отладочных платах что-то делает.

    • @alfarabius
      @alfarabius 4 роки тому

      @@bogdangriniv5695 Аналогия полностью неверна, человек должен предложить мне сесть в центре города на неотъемлемую часть трамвая, а не на похожий вид транспорта)))

    • @Vlad_4572
      @Vlad_4572 4 роки тому +1

      @@alfarabius , железные колеса, которые движутся по рельсам не оно? )

    • @alfarabius
      @alfarabius 4 роки тому

      @@Vlad_4572 Так в аналогии поезд, а не железные колеса движущиеся по рельсам.

    • @Vlad_4572
      @Vlad_4572 4 роки тому

      @@alfarabius , )) а у проезда с трамваем нет аналогии?

  • @НикитаПопов-г2ц
    @НикитаПопов-г2ц 4 роки тому +3

    Тут прям холивар развели! Надо-не надо...Не нравится frtos - пиши свой диспетчер... В любом раскладе задачи быстрее 0,5-1мс придется выполнять, изгаляясь, где-нибудь в прерывании или еще как придумывать... А все диспетчеры и оси нужны для обработки МЕДЛЕННОЙ БИЗНЕС-ЛОГИКИ!!! Когда у тебя дохрена кнопок, дофига светодиодов, датчики, цапы, ацп, и все работает независимо - иди собери все это в кучу! Вот тут и выруливают помогаторы!

  • @romandosaev9860
    @romandosaev9860 3 роки тому +1

    В где вы читаете лекции про freeRTOS, если не секрет?

    • @VladimirMedintsev
      @VladimirMedintsev  3 роки тому +2

      Да нет не секрет. Я частным образом организую группы и с ними занимаюсь.

    • @VAscetic
      @VAscetic 3 роки тому

      @@VladimirMedintsev Новому подписчику не хватает данных о локации в Вашем ответе ;)

  • @MrCrossRaccoon
    @MrCrossRaccoon 4 роки тому +1

    спасибо

  • @radio-l_ru7958
    @radio-l_ru7958 4 роки тому +4

    Ну кому что, можно и на операционной системы FreeRTOS делать, но проще и быстрее чтоб работало сделать всё на прерываниях. Сработало прерывание, получили какую то информацию, выставили флаг событие, разбудили основную программу. Программа проснулась всё это обработала и опять в сон.

    • @boriskrasnoperov483
      @boriskrasnoperov483 4 роки тому

      Если FreeRTOS уже есть в портированном состоянии под данный контроллер, то как раз использовать её много проще, нежели настраивать прерывания. Да и что там портировать...

    • @РоманРоман-н4н
      @РоманРоман-н4н 4 роки тому

      Во-первых: а если задач больше, чем прерываний? Во-вторых: вы уже сами начали описывать что-то вроде простейшего диспетчера в главном цикле, который флаги проверяет. Добавляем сюда необходимость приоритетного выполнения некоторых задач, софтовые задержки, детерминированное время отклика на событие - и вуаля, у нас страшный франкенштейн (если он работает вообще), поддерживать который сам замучаешься. А уж отлаживать. И куча зависимостей между кусками кода. Поправил одно - отвалилось другое. Добро пожаловать в мир говнософта.

    • @ЮристЧастнойПракитки
      @ЮристЧастнойПракитки 4 роки тому

      Роман Роман, предложенный автором способ, тоже не решит описанную вами проблему. Но в целом ОС полезна, если использовать где и как надо.

  • @timslabchannel6650
    @timslabchannel6650 4 роки тому

    Riot OS пробовали использовать?

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      Пробовали, для наших проектов она не подходит.

  • @ЕвгенийДюбайло
    @ЕвгенийДюбайло 2 роки тому

    уважаемый автор,извиняюсь за то,что не по теме,но : у вас есть курс по программированию stm32 для начинающих? или может посоветуете, где на ваш взгляд это доступно изложено.

    • @VladimirMedintsev
      @VladimirMedintsev  2 роки тому

      go.redav.online/198c03d37cf84410
      Это моя программа обучения.

    • @Сергій-ш5б8э
      @Сергій-ш5б8э Рік тому

      ​@@VladimirMedintsevда ,но на курсе не написано stm32,а только ардуино.Так как бы хочется четко понять есть STM 32 курс или нет и сколько занятий?

    • @VladimirMedintsev
      @VladimirMedintsev  Рік тому +1

      @@Сергій-ш5б8э вот очень и очень хорошая программа дпо.фркт.рф/sse совместно с МФТИ. И есть диплом

  • @АлексейШутко
    @АлексейШутко 4 роки тому +1

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

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      На этом канале уже есть несколько роликов по FreeRTOS.

    • @АлексейШутко
      @АлексейШутко 4 роки тому

      @@VladimirMedintsev ага... Значит будем рыть😊😊😊!!!

  • @DmitriNesterov
    @DmitriNesterov 4 роки тому

    14:50 - лучший способ исправления опечаток! 😁👍 Спасибо за отличный урок!

  • @lmarloe
    @lmarloe 4 роки тому

    Вы с RIOT работали? Что думаете?

  • @ЕвгенийАвдеев-к7н
    @ЕвгенийАвдеев-к7н 3 роки тому +1

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

    • @VladimirMedintsev
      @VladimirMedintsev  3 роки тому +1

      Спасибо, очень содержательный комментарий. Но это диспетчер задач и я обещаю вам называть его так и впредь. Спасибо что смотрите. Не забывайте поддерживать канал.

    • @ЕвгенийАвдеев-к7н
      @ЕвгенийАвдеев-к7н 3 роки тому +1

      @@VladimirMedintsev наверное, у Вас сложилось впечатление что просто "а Баба-Яга против" (с). Нет, я не злостный противник операционнок на МК (ладно, противник, но это уже другая история). В первую очередь, я противник усложнения там, где не надо, и внедрения лишних точек отказа, где не просили. Пример из практики: на очень похожем проекте, но с крайне жесткими ограничениями по таймингам, один товарищ тоже решил что FreeRTOS - быстрая, а такты - дешевые. Почему у него не получилось докупить оптом тактов в уже выбранные МК, объяснять, думаю, не надо. В итоге, все было выброшено в окно, и переписано на Bare Metal. Вышло 46 строк ассемблерного кода на все про все. Пара часов разработки, пара часов в QA, и готово. Воюй мы с ОС, до сих пор сюрпризы по углам отлавливали бы. Впрочем, я уже лет 6 программатор в руках не держал, может что и изменилось с тех пор. Хотя, что там могло измениться? Частоты чуть подросли, да память еще чуток подешевела? Не тянет на принципиальные изменения.

    • @VladimirMedintsev
      @VladimirMedintsev  3 роки тому +5

      @@ЕвгенийАвдеев-к7н У меня совсем не сложилось впечатление что "Баба-Яга против", после описанного вами явственное чувство другой пословицы "Дуть на воду, обжегшись на молоке". Вы пришли под учебное видео рассказывающее о том, как можно применить операционную систему и какие преимущества в скорости разработки она дает и рассказываете о случае проекта с жесткими ограничениями по таймингам.... Т.е. ваш товарищ ошибся при выборе подхода к построению скелета программного обеспечения для слишком слабого для решаемой задачи микроконтроллера и теперь из этого следует, что использование операционной системы это плохо и это точка отказа? Ну ладно, я готов смириться с тем фактом что это ваше мнение. Честно говоря это как в известном анекдоте, что микроскоп плохой, плохо консервные банки открывает. Я вашу позицию понял, спорить не буду...

    • @ЕвгенийАвдеев-к7н
      @ЕвгенийАвдеев-к7н 3 роки тому +1

      @@VladimirMedintsev использование операционной системы - не плохо. Плохо, когда ее пытаются натянуть туда, где она не нужна. Равно как и плохо, когда изо всех сил пытаются обойтись без нее, когда очевидно, что она нужна. Все верно, для каждой задачи - свой инструмент. Изначальный посыл первого поста был, что в качестве примера как раз приведена крайне простая задача, которая с высокой долей вероятности без ОСи решается быстрее, чем с нею. Впрочем, я Вас понимаю: в учебный ролик трудно уместить сложный пример, с МК, который должен хороводить дюжиной устройств, читать тачскрин, да еще и в эфир шуметь. Тогда любой начинающий разработчик сбежит в панике :-)

  • @avi-crakhome2524
    @avi-crakhome2524 4 роки тому +2

    Кхм, а в каком месте у вас заполняются статические переменные, и очищаются пустые (.data и .bss). Потому как без них функции нормально работать не будут...
    Для настройки железа есть место SystemInit.c, куда помещается всё что отвечает за железо - наружу торчит фиксированное api.
    FreeRTOS не единственная ос, таких на самом деле много ru.wikibedia.ru/wiki/RTOS
    Почти всех с кем общался - написали собственную ос, в этом как оказалось - ничего сложного нет.
    Когда пользователь начнёт понимать и применять машины состояний - всё остальное покажется пустяком.
    А после изучения протоколов связи - пользователя можно опускать в большой мир. Обученного и привитого, где он гарантированно никого не покусает.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому +2

      Да, и половину ненужного кода из той же FreeRTOS можно выкинуть. Смысл этого видео был показать что облегчается в программировании.

    • @JingoBo
      @JingoBo 4 роки тому +1

      Кстати да про инициализацию данных ОЗУ тоже заметил, там же в векторе прерываний указывается символ main с подчеркиванием, тоеесть там вход в рантайм библиотеки кейла и от туда уже потом вызывается по адресу символа настоящего main.

    • @VladimirMedintsev
      @VladimirMedintsev  4 роки тому

      @@JingoBo там столько интересного и вкусного...

    • @ДимаДима-к1н
      @ДимаДима-к1н 4 роки тому

      @@VladimirMedintsev хорошо бы понять принять и применять!
      и что за странные буквы перед "_" расшифруйте ...СПАСИБО!

  • @lllbenderlll
    @lllbenderlll 4 роки тому +1

    Никого не слушайте. Хэйтеры хэйтят, тролли тролят. Ничего нового.
    Просто не тратьте свое психическое здоровье на них.