blob: 0f8972db50e9f0beb02186dd1c667cc461b626d9 [file] [log] [blame] [view]
# CHIP ESP32 OTA Requestor Example
A prototype application that demonstrates OTA Requestor capabilities.
Please
[setup ESP-IDF and CHIP Environment](../../../docs/platforms/esp32/setup_idf_chip.md)
and refer
[building and commissioning](../../../docs/platforms/esp32/build_app_and_commission.md)
guides to get started.
---
- [Prerequisite](#prerequisite)
- [Query for an OTA Image](#query-for-an-ota-image)
- [ESP32 OTA Requestor with Linux OTA Provider](#esp32-ota-requestor-with-linux-ota-provider)
- [RPC console and Device Tracing](../../../docs/platforms/esp32/rpc_console.md)
---
## Prerequisite
Before moving ahead, make sure you have
[OTA Provider](../../ota-provider-app/esp32) is commissioned and running.
### Query for an OTA Image
After commissioning is successful, announce OTA provider's presence using
chip-tool. On receiving this command OTA requestor will query for OTA image.
```
./out/debug/chip-tool otasoftwareupdaterequestor announce-otaprovider <PROVIDER NODE ID> 0 0 0 <REQUESTOR NODE ID> 0
```
Once the transfer is complete, OTA requestor sends ApplyUpdateRequest command to
OTA provider for applying the image. Device will restart on successful
application of OTA image.
### ESP32 OTA Requestor with Linux OTA Provider
- Build the [Linux OTA Provider](../../ota-provider-app/linux/README.md)
- Run the Linux OTA Provider with OTA image.
```
./out/debug/chip-ota-provider-app -f hello-world.bin
```
- Provision the Linux OTA Provider using chip-tool
```
./out/debug/chip-tool pairing onnetwork 12345 20202021
```
### Note
While trying out example ota-requestor-app bump the software version from
`CMakeList.txt` and not from `idf.py menuconfig`. And software version of the
image which is being ota should be greater than current software version.