fwupd/plugins/unifying
Richard Hughes 99f33c7414 Move some common code down into LuDeviceBootloader
This is common API shared by the nordic and texas bootloaders.
2017-12-05 16:11:50 +00:00
..
data Add support for Logitech Unifying devices 2016-12-12 15:36:53 +00:00
fu-plugin-unifying.c Set the progress and state on the FuDevice, not the FuPlugin 2017-11-30 20:51:52 +00:00
lu-common.c unifying: Ignore spaces in the version prefix 2017-05-03 10:24:59 +01:00
lu-common.h unifying: Add support for DFU features 2017-05-02 21:30:50 +01:00
lu-context.c unifying: Use fu_plugin_check_supported() 2017-09-19 16:11:27 +01:00
lu-context.h unifying: Use fu_plugin_check_supported() 2017-09-19 16:11:27 +01:00
lu-device-bootloader-nordic.c Move some common code down into LuDeviceBootloader 2017-12-05 16:11:50 +00:00
lu-device-bootloader-nordic.h unifying: Refactor the plugin now we have some more information about the hardware 2017-04-12 17:54:50 +01:00
lu-device-bootloader-texas.c Move some common code down into LuDeviceBootloader 2017-12-05 16:11:50 +00:00
lu-device-bootloader-texas.h unifying: Refactor the plugin now we have some more information about the hardware 2017-04-12 17:54:50 +01:00
lu-device-bootloader.c Move some common code down into LuDeviceBootloader 2017-12-05 16:11:50 +00:00
lu-device-bootloader.h Move some common code down into LuDeviceBootloader 2017-12-05 16:11:50 +00:00
lu-device-peripheral.c unifying: Add hardcoded summaries for peripheral kinds 2017-09-12 16:40:40 +01:00
lu-device-peripheral.h unifying: Add hardcoded summaries for peripheral kinds 2017-09-12 16:40:40 +01:00
lu-device-runtime.c Fix build with newer versions of libgudev 2017-09-01 14:53:14 +01:00
lu-device-runtime.h unifying: Refactor the plugin now we have some more information about the hardware 2017-04-12 17:54:50 +01:00
lu-device.c Set environment variables to allow easy per-plugin debugging 2017-11-14 14:22:02 +00:00
lu-device.h unifying: Use fu_plugin_check_supported() 2017-09-19 16:11:27 +01:00
lu-hidpp-msg.c Remove autoconf-isms from the meson configure options 2017-11-27 18:07:53 +00:00
lu-hidpp-msg.h unifying: Split up the HID++2.0 and HID++1.0 functionality 2017-07-04 13:19:09 +01:00
lu-hidpp.h unifying: Split up the HID++2.0 and HID++1.0 functionality 2017-07-04 13:19:09 +01:00
lu-self-test.c unifying: Ignore spaces in the version prefix 2017-05-03 10:24:59 +01:00
lu-tool.c trivial: C99ify more for-loops 2017-09-28 09:23:52 +01:00
meson.build Remove autoconf-isms from the meson configure options 2017-11-27 18:07:53 +00:00
README.md unifying: Refactor the plugin now we have some more information about the hardware 2017-04-12 17:54:50 +01:00

Unifying Support

Introduction

This plugin can flash the firmware on Logitech Unifying dongles, both the Nordic (U0007) device and the Texas Instruments (U0008) version.

This plugin will not work with the different "Nano" dongle (U0010) as it does not use the Unifying protocol.

Some bootloader protocol infomation was taken from the Mousejack[1] project, specifically logitech-usb-restore.py and unifying.py. Other documentation was supplied by Logitech.

Additional constants were taken from the Solaar[2] project.

Design Notes

When a dongle is detected in bootloader mode we detach the hidraw driver from the kernel and use raw control transfers. This ensures that we don't accidentally corrupt the uploading firmware. For application firmware we use hidraw which means the hardware keeps working while probing, and also allows us to detect paired devices.

Verification

If you do not have Unifying hardware you can emulate writing firmware using:

unifying-tool write file.hex -v --emulate=bootloader-nordic

This can also be used to produce protocol data to the command line to compare against USB dumps. This plugin should interact with the hardware exactly like the Logitech-provided flashing tool, although only a few devices have been tested.

[1] https://www.mousejack.com/ [2] https://pwr.github.io/Solaar/