Перейти к содержанию

Навигация

Wb-mcu-fw-updater: различия между версиями

Нет описания правки
Строка 4: Строка 4:
{{DISPLAYTITLE:Обновление прошивок на устройствах Wiren Board}}
{{DISPLAYTITLE:Обновление прошивок на устройствах Wiren Board}}
<translate>
<translate>
Статья находится в процессе редактирования!


== Возможность обновления == <!--T:1-->
== Возможность обновления == <!--T:1-->


<!--T:2-->
<!--T:2-->
Для всех устройств Wiren Board, работающих по протоколу Modbus RTU, доступно удалённое обновление ПО (микрокода) самого устройства. Обновление реализовано посредством прошивки файла .wbfw по шине modbus с помощью утилиты wb-mcu-fw-flasher. Подробная информация о процедуре прошивки доступна [[WB-MCU-Flasher | здесь.]]
Для устройств Wiren Board, работающих по протоколу Modbus RTU, доступно удалённое обновление ПО (микрокода) самого устройства. Обновление реализовано посредством прошивки файла .wbfw по шине modbus с помощью утилиты wb-mcu-fw-flasher. Подробная информация о процедуре прошивки доступна [[WB-MCU-Flasher | здесь.]]


<!--T:3-->
<!--T:3-->
Строка 46: Строка 44:
===== Режим "update-fw": ===== <!--T:8-->
===== Режим "update-fw": ===== <!--T:8-->
[[File:Bootloader.gif||right||Индикация режима загрузчика]]
[[File:Bootloader.gif||right||Индикация режима загрузчика]]
Обновление прошивки устройства с известным slaveid. Утилита сама находит настройки соединения с устройством, запрашивает у устройства его версию ПО, производит обновление, если требуется. Данный режим гибко настраивается с помощью ключей запуска (см. wb-mcu-fw-updater update-fw -h). Например, в данном режиме можно устанавливать тестовые прошивки с новой функциональностью.
Обновление прошивки устройства с известным slaveid. Утилита сама находит настройки соединения с устройством, запрашивает у устройства версию ПО, производит обновление, если требуется. Данный режим гибко настраивается с помощью ключей запуска (см. wb-mcu-fw-updater update-fw -h). Например, в данном режиме можно устанавливать тестовые прошивки.


===== Режим "update-bl": ===== <!--T:9-->
===== Режим "update-bl": ===== <!--T:9-->
Обновление бутлоадера устройства с известным slaveid. Утилита сама находит настройки соединения с устройством, запрашивает у устройства его версию бутлоадера и производит обновление, если требуется. '''Обновление бутлоадера - потенциально опасная операция''', поэтому, данный режим имеет минимальное количество настроек (описание ключей запуска доступно в wb-mcu-fw-updater update-bl -h). Если во время обновления бутлоадера пропало питание, устройство может превратиться в "кирпич". В таком случае, гарантия на него аннулируется. При обновлении бутлоадера, устройство будет '''автоматически прошито самой свежей прошивкой'''.
Обновление бутлоадера устройства с известным slaveid. Утилита сама находит настройки соединения с устройством, запрашивает у устройства версию бутлоадера и производит обновление, если требуется. '''Обновление бутлоадера - потенциально опасная операция''', поэтому, данный режим имеет минимальное количество настроек (описание ключей запуска доступно в wb-mcu-fw-updater update-bl -h). Если во время обновления бутлоадера пропало питание, устройство может превратиться в "кирпич". В таком случае, гарантия на него аннулируется. При обновлении бутлоадера, устройство будет '''автоматически прошито самой свежей прошивкой'''.


===== Режим "recover": ===== <!--T:10-->
===== Режим "recover": ===== <!--T:10-->
Восстановление устройства с испорченной прошивкой (например, при прошивке пропало питание, и устройство перестало загружаться). После указания slaveid и порта, утилита попробует восстановить устройство. В случае неудачи, (с согласия пользователя), утилита пытается восстановить устройство с помощью всех доступных прошивок (процесс может быть длительным).
Восстановление устройства с испорченной прошивкой (например, при прошивке пропало питание, и устройство перестало загружаться). После указания slaveid и порта, утилита попробует восстановить устройство. В случае неудачи, (с согласия пользователя), утилита пытается восстановить устройство с помощью всех доступных прошивок (процесс может быть длительным).


===== Режим "update-all": ===== <!--T:11-->
===== Режим "update-all": ===== <!--T:12-->
'''Только для контроллеров WirenBoard'''. Обновление всех устройств, подключенных к wb-mqtt-serial (настроенных через web-интерфейс).
'''Только для контроллеров WirenBoard'''. Обновление всех устройств, подключенных к wb-mqtt-serial (настроенных через web-интерфейс).
Для каждого обнаруженного устройства в конфигурационном файле /etc/wb-mqtt-serial.conf утилита проверяет наличие обновления и устанавливает его, если имеется. По завершению, пользователю вовзвращаются результаты (сколько устройство обновлено/сколько - нет)
Для каждого обнаруженного устройства в конфигурационном файле /etc/wb-mqtt-serial.conf утилита проверяет наличие обновления и устанавливает его, если имеется. По завершению, пользователю вовзвращаются результаты (сколько устройство обновлено/сколько - нет)


===== Режим "recover-all": ===== <!--T:11-->
===== Режим "recover-all": ===== <!--T:13-->
'''Только для контроллеров WirenBoard'''. Утилита проходит по всем устройствам, подключённым к wb-mqtt-serial (настроенным через web-интерфейс). Если какое-то из устройств находится в режиме бутлоадера, утилита прошивает его самой свежей прошивкой.
'''Только для контроллеров WirenBoard'''. Утилита проходит по всем устройствам, подключённым к wb-mqtt-serial (настроенным через web-интерфейс). Если какое-то из устройств находится в режиме бутлоадера, утилита прошивает его самой свежей прошивкой.


==== Ключи и порядок запуска wb-mcu-fw-updater: ==== <!--T:11-->
==== Ключи и порядок запуска wb-mcu-fw-updater: ==== <!--T:14-->
{| class="wikitable"
{| class="wikitable"
|+ wb-mcu-fw-updater <режим работы> <ключи/флаги для этого режима>
|+ wb-mcu-fw-updater <режим работы> <ключи/флаги для этого режима>
Строка 100: Строка 98:
|-
|-
|-
|-
| --force || Произвести перепрошивку устройства даже, если установлена самый свежий бутлоадер || Флаг
| --force || Произвести перепрошивку устройства даже, если установлен самый свежий бутлоадер || Флаг
|-
|-
|-
|-
Строка 121: Строка 119:
|-
|-


!colspan="3"|Режим "update-all". Ключи со значением (-<ключ> <значение>)
!colspan="3"|Режим "update-all". Обновление прошивок всех устройств, подключённых к драйверу.
|-
|-
| --config || Путь к конфигурационному файлу wb-mqtt-serial || /etc/wb-mqtt-serial.conf
| --force || Произвести перепрошивку устройств даже, если на них установлена самая свежая прошивка || Флаг
|-
|-
!colspan="3"|Режим "update-all". Флаги (-<ключ>)
|-
|-
| --force || Произвести перепрошивку устройств даже, если на них установлена самая свежая прошивка || False
| -h, --help || Описание ключей запуска для режима '''update-all''' || Флаг
|-
|-
!colspan="3"|Режим "recover-all". Восстановление прошивок всех устройств, подключённых к драйверу.
|-
|-
| -h, --help || Описание ключей запуска для режима '''update-all''' || None
| -h, --help || Описание ключей запуска для режима '''recover-all''' || Флаг
|-
|-
|}
|}


== Типичные сценарии обновления == <!--T:12-->
== Типичные сценарии использования == <!--T:15-->
Рассмотрим порядок действий и запуск wb-mcu-fw-updater для некоторых типичных случаев:
Рассмотрим порядок действий и запуск wb-mcu-fw-updater для некоторых типичных случаев:


==== Обновление одного работающего устройства с известным адресом: ==== <!--T:13-->
==== Обновление прошивки устройства: ==== <!--T:16-->
Устройство находится на шине с другими устройствами.
# Узнать modbus адрес обновляемого устройства (адрес по умолчанию напечатан на наклейке сбоку устройства) и порт, к которому оно подключено (например, /dev/ttyRS485-1).
# Остановить драйвер, опрашивающий порт с устройством (например, wb-mqtt-serial).
# Узнать modbus адрес обновляемого устройства (адрес по умолчанию напечатан на наклейке сбоку устройства).
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
<pre>
<pre>
wb-mcu-fw-updater <порт, на которм находится устройство> -a <modbus адрес устройства> update
wb-mcu-fw-updater update-fw <порт, на котором находится устройство> -a <modbus адрес устройства>
</pre>
</pre>
# <li value="4">Дождаться завершения обновления и перезапустить драйвер, если он был остановлен.</li>


==== Обновление одного устройства с неизвестным адресом: ==== <!--T:14-->
==== Установка тестовой прошивки: ==== <!--T:17-->
Подключить устройство на отдельную modbus-шину.
# Узнать modbus адрес обновляемого устройства (адрес по умолчанию напечатан на наклейке сбоку устройства) и порт, к которому оно подключено (например, /dev/ttyRS485-1).
# Убедиться, что устройство - '''единственное на шине.'''
# Узнать название тестовой ветки (branch).
# Остановить драйвер, опрашивающий порт с устройством (например, wb-mqtt-serial).
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
<pre>
<pre>
wb-mcu-fw-updater <порт, на которм находится устройство> update
wb-mcu-fw-updater update-fw <порт, на котором находится устройство> -a <modbus адрес устройства> --branch <ветка с тестовой прошивкой>
</pre>
</pre>
# <li value="4">Подтвердить задание устройству адреса '''245''' (можно изменить в настройках утилиты).</li>
# Дождаться завершения обновления и задать устройству желаемый modbus адрес. Перезапустить драйвер, если нужно


==== Обновление всех устройств, подключённых к драйверу: ==== <!--T:15-->
==== Обновление всех устройств, подключённых к драйверу: ==== <!--T:18-->
Устройства должны опрашиваться драйвером wb-mqtt-serial (находиться в его конфигурационном файле).
Устройства должны опрашиваться драйвером wb-mqtt-serial (находиться в его конфигурационном файле).
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
<pre>
<pre>
wb-mcu-fw-updater <порт, на которм находится устройство> update-all
wb-mcu-fw-updater update-all
</pre>
</pre>
# <li value="2">Дождаться завершения обновления всех устройств.</li>
# <li value="2">Дождаться результатов обновления.</li>


==== Восстановление прошивки на устройстве с известным адресом: ==== <!--T:16-->
==== Восстановление прошивки на устройстве: ==== <!--T:19-->
Устройство находится в режиме бутлоадера (зелёный светодиод мигает 1 раз в секунду) и не может запустить нормальный режим работы. По завершению восстановления, адрес устройства и настройки uart '''остаются прежними.'''
Устройство находится в режиме бутлоадера (зелёный светодиод мигает 1 раз в секунду) и не может запустить нормальный режим работы. По завершению восстановления, адрес устройства и настройки uart '''остаются прежними.'''
# Остановить драйвер, опрашивающий порт с устройством (например, wb-mqtt-serial).
# Узнать modbus-адрес устройства и порт, к которому оно подключено.
# Убедиться, что устройство '''точно''' находится в бутлоадере (посмореть на зелёный светодиод).
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
<pre>
<pre>
wb-mcu-fw-updater <порт, на которм находится устройство> -a <modbus адрес устройства> recover --model-name <полное название модели>
wb-mcu-fw-updater recover <порт, на которм находится устройство> -a <modbus адрес устройства>
</pre>
</pre>
# <li value="4">Если modbus-адрес устройства был верным, начнётся процедура прошивки.</li>


==== Восстановление прошивки на устройстве с неизвестным адресом: ==== <!--T:17-->
Устройство находится в режиме бутлоадера (зелёный светодиод мигает 1 раз в секунду) и не может запустить нормальный режим работы. При этом, адрес устройства неизвестен. По завершению восстановления, адрес устройства и настройки uart '''восстановятся к заводским (1, 9600-8-n-2).'''
# Остановить драйвер, опрашивающий порт с устройством (например, wb-mqtt-serial).
# Убедиться, что устройство '''точно''' находится в бутлоадере (посмореть на зелёный светодиод).
# Запустить утилиту wb-mcu-fw-updater со следующими ключами:
<pre>
wb-mcu-fw-updater <порт, на котором находится устройство> recover --model-name <полное название модели>
</pre>
# <li value="4">Согласиться с восстановлением настроек к заводским.</li>
# Дождаться окончания прошивки.
</translate>
</translate>
wb_editors
556

правок