* libfwupd: export new property HostProduct
* clients: Use this property for setting the title of trees
Before:
```
○
├─XPS 13 7390 TPM 2.0:
│ Device ID: c56e9f77cfee65151bdef90310776f9d62827f5a
│ Summary: Platform TPM device
│ Current version: 7.2.1.0
│ Vendor: Dell Inc.
│ Update Error: Updating disabled due to TPM ownership
│ Flags: internal|require-ac|registered
└─XPS 13 7390 System Firmware:
Device ID: b6c08fb9e5384d9d101853cc1ca20cf0ce2df2e2
Current version: 0.1.1.1
Minimum Version: 0.1.1.1
Vendor: Dell Inc.
Flags: internal|updatable|require-ac|registered|needs-reboot
```
After:
```
XPS 13 7390
│
├─TPM 2.0:
│ Device ID: c56e9f77cfee65151bdef90310776f9d62827f5a
│ Summary: Platform TPM device
│ Current version: 7.2.1.0
│ Vendor: Dell Inc.
│ Update Error: Updating disabled due to TPM ownership
│ Flags: internal|require-ac|registered
└─System Firmware:
Device ID: b6c08fb9e5384d9d101853cc1ca20cf0ce2df2e2
Current version: 0.1.1.1
Minimum Version: 0.1.1.1
Vendor: Dell Inc.
Flags: internal|updatable|require-ac|registered|needs-reboot
```
|
||
|---|---|---|
| .. | ||
| altos | ||
| amt | ||
| ata | ||
| colorhug | ||
| csr | ||
| dell | ||
| dell-dock | ||
| dell-esrt | ||
| dfu | ||
| ebitdo | ||
| fastboot | ||
| flashrom | ||
| modem-manager | ||
| nitrokey | ||
| nvme | ||
| redfish | ||
| rts54hid | ||
| rts54hub | ||
| solokey | ||
| steelseries | ||
| superio | ||
| synaptics-prometheus | ||
| synapticsmst | ||
| test | ||
| thunderbolt | ||
| thunderbolt-power | ||
| udev | ||
| uefi | ||
| unifying | ||
| upower | ||
| wacom-raw | ||
| wacom-usb | ||
| meson.build | ||
| README.md | ||
Adding a new plugin
An extensible architecture allows for providing new plugin types (for reading and writing different firmware) as well as ways quirk their behavior.
You can find more information about the architecture in the developers section of the fwupd website.
You can use the fwupd developer documentation to assist with APIs available to write the plugin.
If you have a firmware specification and would like to see support in this project, please file an issue and share the spec. Patches are also welcome.
We will not accept plugins that upgrade hardware using a proprietary Linux executable, proprietary UEFI executable, proprietary library, or DBus interface.
Plugin interaction
Some plugins may be able to influence the behavior of other plugins. This includes things like one plugin turning on a device, or providing missing metadata to another plugin.
The ABI for these interactions is defined in: https://github.com/fwupd/fwupd/blob/master/src/fu-device-metadata.h
All interactions between plugins should have the interface defined in that file.