Working with WB devices without a controller: различия между версиями
(→ОС Windows: убрал про адаптер из данного раздела) |
(убрал информацию про Modbus Poll, добавил про работу с Rilheva Modbus Poll) |
||
Строка 10: | Строка 10: | ||
Независимо от используемой операционной системы вам нужно знать [[Определение и изменение Modbus-адреса устройств Wirenboard | modbus-адрес]] устройства, [[Протокол Modbus#Коды функций чтения и записи регистров|коды функций]] чтения и записи регистров, а также адреса регистров устройства. Перечень общих для всех устройств Wiren Board регистров можно найти в [[Common_Modbus_Registers | таблице общих регистров]]. Полный список регистров для каждого устройства смотрите в документации к нему. | Независимо от используемой операционной системы вам нужно знать [[Определение и изменение Modbus-адреса устройств Wirenboard | modbus-адрес]] устройства, [[Протокол Modbus#Коды функций чтения и записи регистров|коды функций]] чтения и записи регистров, а также адреса регистров устройства. Перечень общих для всех устройств Wiren Board регистров можно найти в [[Common_Modbus_Registers | таблице общих регистров]]. Полный список регистров для каждого устройства смотрите в документации к нему. | ||
== | == Программы для работы по протоколу Modbus == | ||
Для работы с устройствами по протоколу Modbus | Для работы с устройствами по протоколу Modbus мы рекомендуем использовать программу <b>[https://www.rilheva.com/rilheva-modbus-poll-desktop-edition/ Rilheva Modbus Poll]</b>. Эта программа бесплатна, не требует установки, имеет понятный интерфейс и возможность сохранения настроек обмена и конфигурации регистров. | ||
= | Программа написана для ОС Windows. Однако ОС Linux программа может быть запущена с помощью эмулятора [https://www.winehq.org/ wine] и указанием пути к исполняемому файлу: | ||
<syntaxhighlight lang="console"> | |||
wine ~/RilhevaModbusPoll_1.0.7/RilhevaModbusPoll.exe | |||
</syntaxhighlight> | |||
Для запуска использовалась программа wine версии 7.0. | |||
Можно также использовать утилиты [https://www.modbustools.com/download.html Modbus Poll] из комплекта Modbus Tools (программа платная, но с бесплатным пробным периодом в 30 дней) и [http://s2-team.ru/wrkrs/prods/modbus-tools/termite/ termite] (есть «Pro» и «Free» версия) в ОС Windows и утилиту [[Modbus-client| modbus_client]] в ОС Linux. | |||
== Выбор порта == | |||
В ОС Windows узнать, к какому порту у вас подключен адаптер, можно в диспетчере устройств. Найдите в дереве тип устройств '''Порты (COM и LPT)''', разверните ветку и найдите в ней свой адаптер. Если устройство выделено восклицательным знаком — это значит, что драйвер не был установлен автоматически. Установите его вручную по инструкции производителя. | В ОС Windows узнать, к какому порту у вас подключен адаптер, можно в диспетчере устройств. Найдите в дереве тип устройств '''Порты (COM и LPT)''', разверните ветку и найдите в ней свой адаптер. Если устройство выделено восклицательным знаком — это значит, что драйвер не был установлен автоматически. Установите его вручную по инструкции производителя. | ||
В ОС Linux порт можно узнать с помощью команды команды <code>dmesg -wH</code>, которую нужно запустить перед физическим подключением USB-адаптера. В диагностических сообщениях будет выведено сообщение об обнаружении адаптера и назначении ему порта: | |||
<syntaxhighlight lang="console"> | |||
[ +7,705022] usb 3-7: new full-speed USB device number 6 using xhci_hcd | |||
[ +0,149142] usb 3-7: New USB device found, idVendor=1a86, idProduct=7523, bcdDevice= 2.62 | |||
[ +0,000014] usb 3-7: New USB device strings: Mfr=0, Product=2, SerialNumber=0 | |||
[ +0,000005] usb 3-7: Product: USB2.0-Serial | |||
[ +0,001500] ch341 3-7:1.0: ch341-uart converter detected | |||
[ +0,000549] usb 3-7: ch341-uart converter now attached to ttyUSB0 | |||
</syntaxhighlight> | |||
В данном примере был назначен порт /dev/ttyUSB0. | |||
В интерфейсе программы '''Rilheva Modbus Poll''' для адаптера обычно нужно выбрать COM-порт с самым большим номером. Чтобы проверить правильность выбора порта в Linux, нужно в пользовательской директории со списком портов эмулятора wine (<code>~/.wine/dosdevices</code>) найти файл, который является символической ссылкой на реальный USB-порт, к которому подключен адаптер. | |||
<gallery mode="traditional" widths ="350px" heights="200px"> | <gallery mode="traditional" widths ="350px" heights="200px"> | ||
Image: Windows-com-port-check.png |Определение номера COM-порта | Image: Windows-com-port-check.png |Определение номера COM-порта в диспетчере устройств ОС Windows | ||
Image: Wine-com-port-check.png | Определение номера COM-порта при работе через wine в OC Linux | |||
</gallery> | </gallery> | ||
== | == Работа с программой Rilheva Modbus Poll == | ||
=== Создание собственной конфигурации === | |||
Для начала работы с modbus-модулем нужно настроить параметры обмена: выбрать порт, а также скорость, четность и количество стопбитов в соответствии с настройками модуля, таймаут ответа и частоту запросов. Затем требуется добавить регистры устройства, которые необходимо опрашивать. Нажмите кнопку <b>Add register</b> и в появившемся диалоговом окне заполните поля в соответствии с картой регистров используемого модуля. Для регистров, значения которых нужно изменить снимите галочку <b>Read only</b>. Подтвердите правильность ввода, нажав на кнопку <b>OK</b>. Можно добавлять в список опроса сразу несколько регистров одного типа, а также задавать множитель, сдвиг и количество десятичных знаков для значения регистра. | |||
== | Для начала опроса регистров нужно нажать кнопку <b>Connect</b>. Состояния регистров примут актуальные значения. При необходимости изменения значения регистров типа <code>holding</code> или <code>coil</code> задайте его в поле <code>Current value</code>. Для прекращения опроса регистров нужно нажать <b>Disconnect</b>. | ||
<gallery mode="traditional" widths ="350px" heights="200px"> | |||
Image: Rilheva-modbus-poll-register-config.png | Конфигурирование опроса регистра устройства Wirenboard, содержащего modbus-адрес | |||
Image: Rilheva-modbus-poll-register-polling.png | Опроса регистра устройства Wirenboard, содержащего modbus-адрес | |||
</gallery> | |||
=== Конфигурирование модулей Wirenboard === | |||
Чтобы избавить пользователей от необходимости создавать шаблон опроса регистров самостоятельно мы подготовили файл файл с общими регистрами для всех устройств, а также файлы с набором основных регистров настройки для модулей реле WB-MR6xx, WB-MR3xx, модуля диммера [[WB-MDM3_230V_Modbus_Dimmer | WB-MDM3]], модуля диммера светодиодных лент [[ WB-MRGBW-D_Modbus_LED_Dimmer | WB-MRGBW-D]]. | |||
После запуска программы нужно выбрать файл конфигурации регистров соответственно модулю. Все настойки обмена будут заполнены для работы с параметрами модуля по умолчанию. Если какие-либо настройки устройства были изменены ранее, то установите соответствующие значения. Также нужно задать адрес устройства (у всех устройств он разный) и выбрать используемый COM-порт. Для начала опроса регистров нужно нажать кнопку <b>Connect</b>. Состояния регистров примут актуальные значения. При необходимости изменения значения регистров типа <code>holding</code> или <code>coil</code> задайте его в поле <code>Current value</code>. Для прекращения опроса регистров нужно нажать <b>Disconnect</b>. | |||
<gallery mode="traditional" widths ="350px" heights="200px"> | |||
Image: Rilheva-modbus-poll-wb-mr6с.png | Настройка модуля реле WB-MR6С | |||
Image: Rilheva-modbus-poll-wb-mdm3.png | Настройка диммера WB-MDM3 | |||
Image: Rilheva-modbus-poll-wb-mrgbw-d.png | Настройка диммера WB-MRGBW-D | |||
</gallery> | |||
[[ | ==== Файлы регистров модулей ==== | ||
Файл с общими для всех Modbus-устройств Wiren Board регистрами:<br> | |||
[[Media:Common-registers-wb-device.zip | Общие для всех Modbus-устройств Wiren Board регистры ]] | |||
Файлы регистров и настроек для Modbus-модулей Wirenboard по типам: <br> | |||
[[Media: Registers-wb-mrgbw-d.zip | WB-MRGBW-D fw3 (4-канальный диммер светодиодных лент)]] <br> | |||
[[Media: Registers-wb-mr6xx-without-inputs.zip | WB-MR6CU v.2, WB-MRPS6 (6-канальный модуль реле)]] <br> | |||
[[Media: Registers-wb-mr6xx-with-inputs.zip | WB-MR6C v.2, WB-MR6LV/x, WB-MR6HV/x, WB-MR6C/NC (6-канальный модуль реле)]] <br> | |||
[[Media: Registers-wb-mr3xx-with-inputs.zip | WB-MR3LV/x, WB-MR3HV/x, WB-MRWL3 (3-канальный модуль реле)]] <br> | |||
[[Media: Registers-wb-mdm3.zip | WB-MDM3 (3-канальный диммер)]] <br> | |||
== Работа с программой modbus_client == | |||
Для работы с modbus-утройством используется утилита [[Modbus-client| modbus_client]]. | |||
[ | Скачайте [https://github.com/contactless/modbus-utils/releases/download/1.2/modbus-utils_1.2_amd64.deb пакет для настольных компьютеров с Linux]. | ||
= | Перейдите в папку со скаченным пакетом и установите его командой: | ||
<syntaxhighlight lang="bash"> | |||
sudo apt install ./modbus-utils_1.2_amd64.deb | |||
</syntaxhighlight> | |||
Также автоматически должен установиться пакет <code>libmodbus</code>, если этого не произошло — установите его из репозитория apt. | |||
Как работать и примеры использования смотрите в статье[[Modbus-client| modbus_client]]. | |||