Skip to content

OTA updates

Thomas E. Horner edited this page Mar 18, 2019 · 20 revisions

About this

The OTA update mechanism allows a device to update itself based on data received via a network connection while the normal firmware is running.

OTA support in Lua RTOS requires to use an OTA enabled firmware.

Key concepts

By default the last firmware is obtained from https://ota.whitecatboard.org, and the OTA process is started only if the firmware installed in the board differs from the last published firmware in the OTA server. You can customize Lua RTOS and change the default OTA server to use your own server, this is done through Kconfig under the "Component config -> Lua RTOS -> OTA" category.

For security reasons only OTA servers with SSL enabled are supported.

The url to obtain the last firmware is http://ota.whitecatboard.org/?firmware=FIRMWARE_ID&commit=COMMIT, that must be posted to the OTA server, where:

  • FIRMWARE_ID is the firmware id installed in the board, that is formed by [brand-]board type[-board subtype]. Some examples for valid FIRMWARE_ID available in the default OTA server are:

    • N1ESP32

    • N1ESP32-OTA

    • ESP32THING

    • ESP32THING-OTA

    You can obtain the information about your board in the following way:

    board_type, board_subtype, brand = os.board()
  • COMMIT is the current commit for the installed firmware in the board.

When posting the url http://ota.whitecatboard.org/?firmware=FIRMWARE_ID&commit=COMMIT, the server response with one of the following:

  • HTTP 200 response code, when a new firmware is available, meaning that your board has to upgrade.

    In this chase the firmware binary is received after the HTTP headers as an application/octet-stream mime type.

  • HTTP 470 response code, when some of the argument values are invalid or are missed.

  • HTTP 471 response code, when a new firmware is not available, meaning that your board has the last firmware.

How to use

To upgrade your board via OTA yo must do the following:

  • Setup and start a network connection (WiFi or Ethernet):

    net.wf.setup(net.wf.mode.STA, your ssid, your password)
    net.wf.start()
  • Launch the OTA process

    net.ota()

The programmer can do a factory reset calling the os.factoryreset() function to revert previously OTA updates and back to the factory app.

os.factoryreset()

net.ota([server[, project[, reboot[, verify]])

Upgrade the board via OTA.

Arguments:

  • server (optional): the ota server to use, e.g. http://ota.whitecatboard.org/
  • project (optional): a hint for the ota server on which project the firmware is for
  • reboot (optional): boolean that states if the device should be rebooted after a successful ota
  • verify (optional): boolean that states if the ota partition should be verfied after downloading and writing it

Returns: nothing, an exception, or does not return

/ > net.ota(nil, "myproject", false, true)
Connecting to https://sdkconfig-ota-server.tld ...
Current firmware commit is 09d7592cf183fdc138428c756e0ec124ea043a01
Running from ota_0 at offset 0x000a0000
Writing to   ota_1 at offset 0x00250000 - capacity is 1.69 MB
Starting OTA update, downloading partition image with 1.14 MB
Writing chunk at 0x00373d50... (100 %)
OTA update finished
Successfully changed boot partition
/ > 
Clone this wiki locally