InfiniTime/doc/gettingStarted/updating-software.md
2021-11-28 13:42:37 +01:00

5 KiB

Firmware, InfiniTime, Bootloader, Recovery firmware, OTA, DFU... What is it?

You might have already seen these words by reading the announcement, release notes, or the wiki guide and, you may find them confusing if you're not familiar with the project.

Basically, a firmware is just a software running on the embedded hardware of a device, the PineTime in this case. InfiniTime OS is based on 3 distinct firmwares:

  • InfiniTime itself, this is the application firmware running on the PineTime. This is the main firmware which provides most of the functionalities you'll use on a daily basis : bluetooth low-energy (BLE) connectivity, applications, watchfaces,...
  • The bootloader is responsible for safely applying updates of the application firmware, reverting them in case of issues and load the recovery firmware when requested.
  • The recovery firmware is a specific application firmware than can be loaded by the bootloader on user request. This firmware can be useful in case of serious issue, when the main application firmware cannot perform an OTA update correctly. Currently, this recovery firmware is based on InfiniTime 0.14.1.

OTA and DFU refer to the update of the firmware over BLE (Bluetooth Low Energy). OTA means Over The Air, this is a functionality that allows the user to update the firmware how their device using a wireless communication like BLE. When we talk about DFU (Device Firmware Update), we refer to the file format and protocol used to send the update of the firmware to the watch over-the-air. InfiniTime implement the (legacy) DFU protocol from Nordic Semiconductor (NRF).

How to check the version of InfiniTime and the bootloader?

You can check the InfiniTime version by first swiping right on the watchface to open quick settings, tapping the cogwheel to open settings, swipe up until you find an entry named "About" and tap on it.

InfiniTime 1.0 version

PineTimes shipped after June 2021 will be flashed with the new version of the bootloader, the recovery firmware and InfiniTime 1.0.

The bootloader only runs when the watch starts (from an empty battery, for example) or after a reset (after a successful OTA or a manual reset - long push on the button).

The bootloader is easily recognizable with its white pine cone that is progressively drawn in green. It also displays its own version on the bottom (1.0.0 as of now).

Bootloader 1.0

How to update your PineTime?

To update your PineTime, you can use one of the compatible companion applications. Here are the main ones:

  • Amazfish (Desktop Linux, mobile Linux, SailfishOS, runs on the PinebookPro and the Pinephone)
  • Gadgetbridge (Android)
  • Siglo (Linux, GTK based)
  • NRFConnect (closed source, Android & iOS)

We have instructions for updating the software with Gadgetbridge and NRFConnect.

Firmware validation

The bootloader requires a manual validation of the firmware. If the watch reset with an updated firmware that was not validated, the bootloader will consider it as non-functioning and will revert to the previous version of the firmware. This is a safety feature to prevent bricking your device with a faulty firmware.

You can validate your updated firmware on InfiniTime >= 1.0 by following this simple procedure:

  • From the watchface, swipe right to display the quick settings menu
  • Open settings by tapping the cogwheel on the bottom right
  • Swipe up until you find an entry named Firmware and tap on it
  • This app shows the version that is currently running. If the firmware is not validated yet, you can either validate the running firmware, or reset and revert to the previous firmware version

Bootloader

Most of the time, the bootloader just runs without your intervention (update and load the firmware).

However, you can enable 2 functionalities using the push button:

  • Push the button until the pine cone is drawn in blue to force the rollback of the previous version of the firmware, even if you've already validated the updated one
  • Push the button until the pine cone is drawn in red to load the recovery firmware. This recovery firmware only provides BLE connectivity and OTA functionality.

More info about the bootloader in its project page.