Skip to main content

Python USB firmware update library.

Project description

pyfu-usb: Python USB Firmware Updater

License: MIT

A small library for firmware updates over USB with devices that support the DFU and DfuSe protocols. Specifically, pyfu-usb supports listing DFU capable devices and downloading binary files to them.

Compared to dfu-util

dfu-util is the popular host side tool for interacting with DFU/DfuSe devices. pyfu-usb has only a small sliver the functionality contained in dfu-util: Listing and downloading binary files. The reason you would use pyfu-usb over dfu-util is if you have a Python project that needs firmware update capabilities and don't want an external (non-Python) dependency.

Compared to pydfu.py

pydfu.py is a tool in the OpenMV project that solves the exact problem described above, but it is only for DfuSe devices (e.g. STM32) and also hard codes a number of parameters including device address and max transfer size. It also appears to only work with .dfu files, which require an extra conversion step. Since binary files can be directly generated by many embedded toolchains using them is simpler, although less portable.

The code in this package originates from pydfu.py and the OpenMV license agreement has been copied into the repository. Along with refactoring the code and adding support for "classic" DFU devices, several modernizations were added:

  • Colored logs and progress bar with rich
  • Using logging instead of print for output messages
  • Consistent style and linting with ruff

Dependencies

Even though this package may appear pure Python, by relying on pyusb we rely on libusb being installed. See the pyusb docs for more details on platform support.

User Guide

Install with pip:

pip install pyfu-usb

List connected DFU devices:

pyfu-usb --list

Download a file to a DfuSe capable device, specifying a start address in hex:

pyfu-usb --download <filename> -a <start_address>

Download a file to a DFU capable device:

pyfu-usb --download <filename>

Use the --device argument to specify the vid:pid of the device in hex if multiple are connected. See the examples directory for more detailed examples.

Developer Guide

This project uses uv for Python tooling. It also uses just to simplify running project specific specific commands.

To install pre-commit hooks (e.g. style, linting):

just setup

To run pre-commit hooks:

just lint

To run unit tests:

just test

To view code coverage:

just coverage

To build the package:

uv build

Contributing

Please see the documentation prior to contributing.

License

Licensed under the MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyfu_usb-2.0.2.tar.gz (858.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyfu_usb-2.0.2-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file pyfu_usb-2.0.2.tar.gz.

File metadata

  • Download URL: pyfu_usb-2.0.2.tar.gz
  • Upload date:
  • Size: 858.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for pyfu_usb-2.0.2.tar.gz
Algorithm Hash digest
SHA256 0e5f81602aefa5373a2301e90fcdf6c285702bfe9f1f9105d5a0ca843231e465
MD5 d376987303d5ff97fcd69bf4e6162d0b
BLAKE2b-256 982a229eabbd3788954e6bfcf20c0bad36439c2757ace0ef9685ac55b5043881

See more details on using hashes here.

File details

Details for the file pyfu_usb-2.0.2-py3-none-any.whl.

File metadata

  • Download URL: pyfu_usb-2.0.2-py3-none-any.whl
  • Upload date:
  • Size: 11.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for pyfu_usb-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e98ad0ac90ba4ddf20ed2959e80eae42186822660f7365a9e194763555b76de9
MD5 a6eab4ff1cb6135d3f88942a03fa6da0
BLAKE2b-256 8a03f5d94c9168ceb2d77f51b3f719872f0614d7f78ea7be8b989b084bad2827

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page