Краткий рассказ о работе с modbus

Поделиться
HTML-код
  • Опубликовано: 14 окт 2024

Комментарии • 49

  • @manul88
    @manul88 7 месяцев назад +4

    Здравствуйте, Владимир. Я купил вашу книгу одним из первых. Спасибо за труд, она отличная.
    За подробный рассказ о модбас, отдельное спасибо.

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад

      И вам спасибо большое за поддержку

  • @user-LatroNew
    @user-LatroNew 6 месяцев назад +1

    Здравствуйте Владимир. Спасибо Вам огромное за обучающие видео. Благодаря книге понял как правильно работать с операционной системой. Книгу купил в самом начале продаж и очень рад тому, что она у меня теперь есть. Удачи!

    • @VladimirMedintsev
      @VladimirMedintsev  6 месяцев назад

      И вам спасибо за позитивный отзыв

  • @ВячеславКалугин-и9т
    @ВячеславКалугин-и9т 7 месяцев назад +5

    Посмотрю позже. Модбасом пользовался и буду пользоваться, так что по любому что то новое для себя найду. Кстати, лет 6 или 7 назад подключал свои платы к панели Овена, СП307, столкнулся с тем, что они не обрабатывают коды ошибок. ))) Дошло до того, что связывался с ними, спрашивал почему. У них при любом варианте ошибки, который посылала моя плата, всегда выскакивало сообщение: "Нет связи" или что то подобное, точно не помню. А мне очень хотелось, чтобы мои платы сообщали что им не нравится, какие у них проблемы. ))) Не вышло. Пришлось довольствоваться малым.

  • @sultanail84
    @sultanail84 7 месяцев назад

    Очень интересно, особенно, интересно, что это работает с промышленным оборудованием. Ну и Овены его широко используют.

  • @victorlowlevel8063
    @victorlowlevel8063 7 месяцев назад +1

    Писал свои библиотеки modbus на основе этой статьи. И мастер и слейв для AVR/STM8/STM32. Мастер для PC. Для слейва в MCU делал их через функции обратного вызова. Использую для коммуникации между оборудованием для спортивных судейских систем. Консоли, табло, пульты, устройства отображения. Единственная проблема - частенько выгорают конечные трансиверы. Пытаемся победить. Есть конечно куда оптимизировать либу. Например использовать один буфер для приёма/передачи, а не как сейчас у меня - два буфера. Пока не добрался.

    • @sergeysemenkov6474
      @sergeysemenkov6474 7 месяцев назад

      Делайте гальваническую развязку, выгорать не будет.
      Или все нужно питать от одного БП.

    • @victorlowlevel8063
      @victorlowlevel8063 7 месяцев назад

      @@sergeysemenkov6474 Мы ща нашли п...здатые микрухи со встроенным DC-DC - будем заказывать и пробовать! 🙄

  • @chepegin
    @chepegin 7 месяцев назад

    Владимир, спасибо. По поводу union. Необходимо обрамлять эту конструкцию #pragma pack(push, 1) и #pragma pack(pop). Иначе можно поиметь проблемы в некоторых случаях с выравниванием данных в памяти. Для того, чтобы понять о чём я - статья на хабре с заголовком "Расставим точки над структурами C/C++".

  • @СергейГород_ко
    @СергейГород_ко 7 месяцев назад +1

    Ура наконец то....
    Надеюсь я не ситьно ошибался, жаль пропустил стрим.

    • @СергейГород_ко
      @СергейГород_ко 7 месяцев назад

      Надеюсь будет на примере оси OSI.
      Потому что modbus пишут над 232,485, Ethernet.

  • @Ironium_555
    @Ironium_555 7 месяцев назад

    камень F303, FreeRTOS, модбас на два уарта, через LL DMA с использованием RTO (кэллбэк HALL прерывания RTO обрабатывает как ошибку, и запрещает прием по уарт)
    помимо модбаса на этих же уартах, одновременно крутится протокол IEC 60870-101.

  • @facset1
    @facset1 7 месяцев назад +1

    Уважаемый Владимир, если не возражаете, для тех кто только заинтересовался modbus RTU на stm: на зарубежном сайте есть цикл статей по modbus RTU где разжованы все протоколы и алгоритмы общения по modbus, и как настроить stm в режиме Мастера или Ведомого, статьи как в текстовом виде с пояснениями и участками кода, так и с видео разбором алгоритмов работы автора статей, статьи можно найти по "Modbus #1. Read Holding and Input Registers". Да статьи и видео на Английском, но яндекс браузер творит чудеса перевода)))

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад

      Да с чего бы мне возражать, я всегда "за" поддержание инженерных кадров России.

    • @facset1
      @facset1 7 месяцев назад +1

      и да благодаря этим статьям смог запилить управление частотником KEB, от ПЛК Овен Мастер к stm32f103 Ведомому

  • @СергейХолодырь
    @СергейХолодырь 7 месяцев назад

    Пробовал Modbus RTU на CH32 - работает, но нужен имеено апаратный таймер, программный может перестать вызывать свой callback через какокое-то время, хотя с приоритетами вроде всё норм. Очереди медленные, в разы медленее циклического буфера. Насчёт определения конца посылки в 3,5 символа он не всегда нужен, об этом нитересно написано у Овена "Заметки о Модбас"

  • @michal621
    @michal621 7 месяцев назад +1

    о, я тоже эту библиотеку от alejoseb использую. Портируется легко. И приятна она тем, что есть в ней реализация мастера.

  • @ВасяАстроном
    @ВасяАстроном 7 месяцев назад

    Здравствуйте, Владимир!
    Не могли бы Вы сказать какой программатор используете для прошивки STM32? Для отладки в Keil нужно использовать что-то наподобие J-link или можно обойтись китайской копией ST-Link? Какой программатор посоветуете?
    Плата, с которой Вы связываетесь по Modbus- Ваша новая разработка, но не могли бы Вы в двух словах рассказать о ней?

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад

      Для работы с микроконтроллерами STM32 можно использовать любой программатор с интерфейсом SWD полный список достаточно длинный. Из популярных J-Link, ST_Link, DAP_Link. Я использую собственный клон ST_Link как его сделать рассказано в одном из видео на канале.

  • @panigo63
    @panigo63 7 месяцев назад

    На гите есть такой nimaltd. Его библиотеки мне нравятся. И с FreeRtos тоже дружат.

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад

      Я его библиотеки много раз показывал. Более того, с ним даже переписывался много месяцев.

    • @sergsapov2927
      @sergsapov2927 7 месяцев назад

      Ради интереса скачал его gsm_v5-master. И вижу в pdu setAddress() идет работа с буфером без контроля размера. Дальше смотреть не стал...

  • @zisoua
    @zisoua 6 месяцев назад

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

    • @VladimirMedintsev
      @VladimirMedintsev  6 месяцев назад +1

      Это собственная разработка и мы не распространяем ее исходные коды.

  • @jackkatch3839
    @jackkatch3839 7 месяцев назад

    Мало знаком с STM32. Пришлось делать приёмопередатчик двух каналов RS485 (удлинитель линии, для искро-безопасного оборудования. Один канал к передатчику, второй канал к приёмнику). Абонент , в некоторых случаях, отвечает очень быстро, поэтому после завершения передачи необходимо как можно быстрее переключится на приём. Есть подозрение, что прерывание по завершению передачи (UART) происходит не всегда в середине стопового бита т.к. расчётная задержка (пол стопового бита + ещё немножко приводило к спорадическим сбоям при обмене) (По крайней мере на SiLabs ни когда не было проблем). Пришлось значительно увеличить задержку до переключения на приём. Кто нибудь может прокомментировать?

  • @yohabi
    @yohabi 7 месяцев назад +2

    Modbus - наше всё

  • @DART2WADER
    @DART2WADER 7 месяцев назад

    37:41 Тут прекрасно тернарник зашёл бы: HAL_GPIO_WritePin(RL1_GPIO_Port, RL1_Pin, (ModbusDATA[3] & 0x0001) ? GPIO_PIN_SET : GPTO_PIN_RESET);
    А вообще в цикл по массиву с «тритами» (бит, порт, пин) я бы это запаковал. Нагляднее и меньше ошибок при написании. Кпипаста много раз стреляла)))
    52:00 Я таймер на частоте ядра запускаю и сбрасываю счётчик перед исполнением кода, а затем в конце его вычитываю.

    • @silentage6310
      @silentage6310 7 месяцев назад

      и так бы сработало :)
      HAL_GPIO_WritePin(RL1_GPIO_Port, RL1_Pin, ModbusDATA[3] & 0x0001);

  • @Ololoshize
    @Ololoshize 7 месяцев назад +1

    Скажите, когда вы собираете код, вы используете опции компилятора по оптимизации (скорость, размер), если да, то какие?

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад +1

      Опции используются в зависимости от того, какой эффект мне нужно получить.

  • @GurikN1
    @GurikN1 7 месяцев назад +1

    каким образом UART - физический протокол передачи данных, похож на ModBus - коммуникационный протокол ?

    • @ВячеславКалугин-и9т
      @ВячеславКалугин-и9т 7 месяцев назад

      В каком смысле похож? Есть физическая часть, есть протокол обмена. Просто надо понимать, что одну и туже информацию вы передаёте различными способами. Я и по радиоканалу обмениваюсь информацией между двумя устройствами при помощи протокола ModBus. Всё соблюдается - адресация, контрольная сумма. Обработка ошибок, правда, написана под мои хотелки. Мне нравится, когда система помогает мне при поиске возможных неполадок. ))) За два года непрерывной работы ни разу не пригодилось, будем надеяться, что и в дальнейшем не понадобится.

  • @vladimirkomarov6250
    @vladimirkomarov6250 7 месяцев назад

    Всё ещё на STM ?) На китайцев не планируете переходить?

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад

      STM стали более доступными чем в кризис полупроводников. Зачем переходить если они есть и доступны?

    • @vladimirkomarov6250
      @vladimirkomarov6250 7 месяцев назад

      У меня на работе решили перейти. Там HAL-а нет, сижу все проекты переписываю с нуля.

  • @Владимир-ч5м1л
    @Владимир-ч5м1л 7 месяцев назад

    Странно. Почему-то мой комментарий удален.
    Опишу тогда коротко суть. У ModbusRTU есть минус - последовательная работа с каждым подчиненным устройсвом с ожиданием ответа. Это может сказываться на времени полного опроса всех устройств при обрыве связи с одним устройством, зависит от таймаута на запросы и количество повторов. Если это критично, то стоит обратить внимание на ModbysTCP. Кроме того в сети с протоколом ModbusTCP возможно использования нескольких мастеров.

    • @Владимир-ч5м1л
      @Владимир-ч5м1л 7 месяцев назад

      Дополню, если кому-то интересен ModbusTCP.
      Есть ModbusTCP, есть ModbusRTU поверхности Ethernet.разница в том, что в первом случае запускается свой сервер для каждого мастера в сети и в шапке сообщения передается номер мастера. Во втором случае пакет ModbusRTU просто помещается в пакет TCP, обработчик один и мастер тоже один.
      Правда для всего этого нужны процессоры достаточно неслабые.

    • @VladimirMedintsev
      @VladimirMedintsev  7 месяцев назад

      Ютуб очень жестко удаляет комментарии со ссылками или со словами которые кажутся ему странными

    • @sergsapov2927
      @sergsapov2927 7 месяцев назад

      Если устройство отвалилось по таймауту - начинаем его опрашивать редко, например раз в 1 мин. Когда ответило - возвращаемся к нормальному частому опросу.

  • @inventoruz
    @inventoruz 7 месяцев назад

    Могу я использовать один порт как ModBus slave а второй как ModBus master ? Этот библиотека может это сделать ? У меня есть другой библиотека но мне не нравится скорость этого библиотека.

  • @RomaNovikov1980
    @RomaNovikov1980 7 месяцев назад

    Я сюда ещё вернусь.

  • @SERVICE_KARELIA
    @SERVICE_KARELIA 4 месяца назад

    На самом деле непонятно что означает RTU.

    • @VladimirMedintsev
      @VladimirMedintsev  4 месяца назад

      Remote Terminal Unit, это же очевидно.