mirror of
https://git.proxmox.com/git/fwupd
synced 2025-10-24 15:52:26 +00:00
55 lines
1.5 KiB
Markdown
55 lines
1.5 KiB
Markdown
# 8BitDo
|
|
|
|
## Introduction
|
|
|
|
This plugin can flash the firmware on the 8BitDo game pads.
|
|
|
|
Ebitdo support is supported directly by this project with the embedded libebitdo
|
|
library and is possible thanks to the vendor open sourcing the flashing tool.
|
|
|
|
The 8BitDo devices share legacy USB VID/PIDs with other projects and so we have
|
|
to be a bit careful to not claim other devices as our own.
|
|
|
|
## Firmware Format
|
|
|
|
The daemon will decompress the cabinet archive and extract a firmware blob in
|
|
an unspecified binary file format. The binary file has a vendor-specific header
|
|
that is used when flashing the image.
|
|
|
|
This plugin supports the following protocol ID:
|
|
|
|
* com.8bitdo
|
|
|
|
## GUID Generation
|
|
|
|
These devices use the standard USB DeviceInstanceId values, e.g.
|
|
|
|
* `USB\VID_2DC8&PID_AB11&REV_0001`
|
|
* `USB\VID_2DC8&PID_AB11`
|
|
* `USB\VID_2DC8`
|
|
|
|
## Update Behavior
|
|
|
|
The device usually presents in runtime mode, but on detach re-enumerates with a
|
|
different USB VID and PID in a bootloader mode. On attach the device again
|
|
re-enumerates back to the runtime mode.
|
|
|
|
For this reason the `REPLUG_MATCH_GUID` internal device flag is used so that
|
|
the bootloader and runtime modes are treated as the same device.
|
|
|
|
## Vendor ID Security
|
|
|
|
The vendor ID is set from the USB vendor, which is set to various different
|
|
values depending on the model and device mode. The list of USB VIDs used is:
|
|
|
|
* `USB:0x2DC8`
|
|
* `USB:0x0483`
|
|
* `USB:0x1002`
|
|
* `USB:0x1235`
|
|
* `USB:0x2002`
|
|
* `USB:0x8000`
|
|
|
|
## External Interface Access
|
|
|
|
This plugin requires read/write access to `/dev/bus/usb`.
|