Tool to flash firmware onto any Silicon Labs radio running EmberZNet, CPC multi-PAN, or just a bare Gecko Bootloader
Project description
Universal Silicon Labs Flasher
Automatically communicates with radios over CPC, EZSP, or Spinel to enter the bootloader and then flashes a firmware image with XMODEM.
Installation
$ pip install universal-silabs-flasher
Usage
usage: universal-silabs-flasher [-h] [-v] [--device DEVICE] [--probe-methods PROBE_METHODS]
[--bootloader-reset BOOTLOADER_RESET]
{dump-gbl-metadata,probe,write-ieee,flash} ...
positional arguments:
{dump-gbl-metadata,probe,write-ieee,flash}
options:
-h, --help show this help message and exit
-v, --verbose
--device DEVICE
--probe-methods PROBE_METHODS
Comma-separated list of application type and baudrate pairs to use when probing the device.
Each pair should be in the format '<application_type>:<baudrate>'. Valid application types:
bootloader, cpc, ezsp, spinel, router. Example: 'ezsp:115200,ezsp:460800,spinel:460800'
--bootloader-reset BOOTLOADER_RESET
Reset methods to attempt when triggering bootloader mode. Multiple methods can be chained by
separating them with a comma. Valid values: yellow, ihost, slzb07, rts_dtr, baudrate
For flash, you can also pass --profile to use a predefined device profile.
--profile cannot be combined with --probe-methods or --bootloader-reset.
Flashing firmware
For safety, firmware GBL image files are validated and their checksums verified both before sending, and by the device bootloader itself.
Yellow
The Yellow's bootloader can always be activated with the --bootloader-reset yellow option:
$ universal-silabs-flasher \
--device /dev/ttyAMA1 \
--bootloader-reset yellow \
flash \
--firmware NabuCasa_RCP_v4.1.3_rcp-uart-hw-802154_230400.gbl
SkyConnect
The SkyConnect will be rebooted into its bootloader from the running application: either EmberZNet or CPC.
$ universal-silabs-flasher \
--device /dev/cu.SLAB_USBtoUART \
flash \
--firmware NabuCasa_SkyConnect_EZSP_v7.1.3.0_ncp-uart-hw_115200.gbl
Home Assistant Connect ZBT-2
The Home Assistant Connect ZBT-2 can use the built-in zbt2 profile:
$ universal-silabs-flasher \
--device /dev/ttyACM0 \
flash \
--profile zbt2 \
--firmware zbt2_openthread_rcp_2.4.4.0_GitHub-7074a43e4_gsdk_4.4.4.gbl
Sonoff ZBDongle-E
The Sonoff dongles use the RTS/DTR bootloader reset method:
$ universal-silabs-flasher \
--device /dev/ttyUSB0 \
--bootloader-reset rts_dtr \
flash \
--firmware ncp-uart-hw-v7.4.5.0-zbdonglee-115200.gbl
Writing IEEE address
Ensure a target device running EmberZNet firmware has the correct node IEEE address:
$ universal-silabs-flasher \
--device /dev/cu.SLAB_USBtoUART \
write-ieee \
--ieee 00:3c:84:ff:fe:92:bb:2c
The IEEE address can also be specified without colons: --ieee 003c84fffe92bb2c.
If the current device's IEEE address already matches the provided one, the command will not write it unnecessarily.
Depending on firmware version, writing the IEEE address can be a permanent operation. If this is the case,
you will need to upgrade the firmware on your adapter to a more recent release of EmberZNet or perform the one-time
write with --force.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file universal_silabs_flasher-1.0.2.tar.gz.
File metadata
- Download URL: universal_silabs_flasher-1.0.2.tar.gz
- Upload date:
- Size: 60.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c28fe6e4bc2c1b7250f1945f435b30a67683e516284ec4e80dcb29a6f736f446
|
|
| MD5 |
ed3bf408d915812e49bc22af62f886fb
|
|
| BLAKE2b-256 |
00a55386072630dbd16cee54d4a62c7fef941e5db156caf88d89c598b5df8fac
|
File details
Details for the file universal_silabs_flasher-1.0.2-py3-none-any.whl.
File metadata
- Download URL: universal_silabs_flasher-1.0.2-py3-none-any.whl
- Upload date:
- Size: 52.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b3cadf5f93d8cedb402546c5d3492de507d86bc15e74bfe083577f7ad9473d89
|
|
| MD5 |
f2aec2b5e70f93f054809be657e71ba4
|
|
| BLAKE2b-256 |
d601773ebb448c1c472250068aaa68f233e8fda8d6a6796a719cc582e31b421d
|