libfwupd2-1.8.6-150500.2.2 >  A dRp9|@(gCz u "?kzسYkEhGW/<+jYxF{ A Q_)V|xHM#>i,Cw.1 bG^U;^ v|u>lɋ1)yzN]&+@԰IL9ޒ@5^Hm+ ].i]6+\ڬ pY$H<@Gof^)Ĵ 0bК|A3P)G$4e757ae195fea8aba98670e056d4032db63f19da506fdc5935ac6c2396cb469bafd1054e6c001ddda1cac7f57e722778559b95b6dRp9|yX]P7}[4cVN.`0nVrKpfLqyj|0ynr.-DrMM>iXwUwY"C.EU>3T]t]ܰ~aߝ)HбIa6PsPyJI#l >CA>Y[620 *VNpqB+jklRӍL~6 g )DALs*LB!@?:xaި`t6cvi >p@P?@d   N% ;L_epx |    $A P  ( 8 c9c:c>@FG,H4I<X@AYDA\]^bcdefluvwxyz<Clibfwupd21.8.6150500.2.2Allow session software to update device firmwarefwupd is a daemon to allows session software to update device firmware on the local machine.dR#ibs-power9-12SUSE Linux Enterprise 15SUSE LLC GPL-2.0-or-later AND LGPL-2.1-or-laterhttps://www.suse.com/System/Librarieshttps://fwupd.org/linuxppc64ledRdR06449949058a209c34f03b610d2e8cd9cb3943dadb71abe9dcb0e6818071af46libfwupd.so.2.0.0rootrootrootrootfwupd-1.8.6-150500.2.2.src.rpmlibfwupd.so.2()(64bit)libfwupd.so.2(LIBFWUPD_0.1.1)(64bit)libfwupd.so.2(LIBFWUPD_0.7.0)(64bit)libfwupd.so.2(LIBFWUPD_0.7.1)(64bit)libfwupd.so.2(LIBFWUPD_0.7.3)(64bit)libfwupd.so.2(LIBFWUPD_0.8.0)(64bit)libfwupd.so.2(LIBFWUPD_0.9.2)(64bit)libfwupd.so.2(LIBFWUPD_0.9.3)(64bit)libfwupd.so.2(LIBFWUPD_0.9.4)(64bit)libfwupd.so.2(LIBFWUPD_0.9.5)(64bit)libfwupd.so.2(LIBFWUPD_0.9.6)(64bit)libfwupd.so.2(LIBFWUPD_0.9.7)(64bit)libfwupd.so.2(LIBFWUPD_0.9.8)(64bit)libfwupd.so.2(LIBFWUPD_1.0.0)(64bit)libfwupd.so.2(LIBFWUPD_1.0.3)(64bit)libfwupd.so.2(LIBFWUPD_1.0.4)(64bit)libfwupd.so.2(LIBFWUPD_1.0.7)(64bit)libfwupd.so.2(LIBFWUPD_1.0.8)(64bit)libfwupd.so.2(LIBFWUPD_1.1.0)(64bit)libfwupd.so.2(LIBFWUPD_1.1.1)(64bit)libfwupd.so.2(LIBFWUPD_1.1.2)(64bit)libfwupd.so.2(LIBFWUPD_1.1.3)(64bit)libfwupd.so.2(LIBFWUPD_1.2.1)(64bit)libfwupd.so.2(LIBFWUPD_1.2.10)(64bit)libfwupd.so.2(LIBFWUPD_1.2.2)(64bit)libfwupd.so.2(LIBFWUPD_1.2.4)(64bit)libfwupd.so.2(LIBFWUPD_1.2.5)(64bit)libfwupd.so.2(LIBFWUPD_1.2.6)(64bit)libfwupd.so.2(LIBFWUPD_1.2.7)(64bit)libfwupd.so.2(LIBFWUPD_1.2.8)(64bit)libfwupd.so.2(LIBFWUPD_1.2.9)(64bit)libfwupd.so.2(LIBFWUPD_1.3.1)(64bit)libfwupd.so.2(LIBFWUPD_1.3.2)(64bit)libfwupd.so.2(LIBFWUPD_1.3.3)(64bit)libfwupd.so.2(LIBFWUPD_1.3.4)(64bit)libfwupd.so.2(LIBFWUPD_1.3.6)(64bit)libfwupd.so.2(LIBFWUPD_1.3.7)(64bit)libfwupd.so.2(LIBFWUPD_1.4.0)(64bit)libfwupd.so.2(LIBFWUPD_1.4.1)(64bit)libfwupd.so.2(LIBFWUPD_1.4.5)(64bit)libfwupd.so.2(LIBFWUPD_1.4.6)(64bit)libfwupd.so.2(LIBFWUPD_1.5.0)(64bit)libfwupd.so.2(LIBFWUPD_1.5.1)(64bit)libfwupd.so.2(LIBFWUPD_1.5.2)(64bit)libfwupd.so.2(LIBFWUPD_1.5.3)(64bit)libfwupd.so.2(LIBFWUPD_1.5.5)(64bit)libfwupd.so.2(LIBFWUPD_1.5.6)(64bit)libfwupd.so.2(LIBFWUPD_1.5.8)(64bit)libfwupd.so.2(LIBFWUPD_1.6.0)(64bit)libfwupd.so.2(LIBFWUPD_1.6.1)(64bit)libfwupd.so.2(LIBFWUPD_1.6.2)(64bit)libfwupd.so.2(LIBFWUPD_1.7.0)(64bit)libfwupd.so.2(LIBFWUPD_1.7.1)(64bit)libfwupd.so.2(LIBFWUPD_1.7.2)(64bit)libfwupd.so.2(LIBFWUPD_1.7.3)(64bit)libfwupd.so.2(LIBFWUPD_1.7.4)(64bit)libfwupd.so.2(LIBFWUPD_1.7.6)(64bit)libfwupd.so.2(LIBFWUPD_1.8.0)(64bit)libfwupd.so.2(LIBFWUPD_1.8.1)(64bit)libfwupd.so.2(LIBFWUPD_1.8.2)(64bit)libfwupd.so.2(LIBFWUPD_1.8.3)(64bit)libfwupd.so.2(LIBFWUPD_1.8.4)(64bit)libfwupd.so.2(LIBFWUPD_1.8.6)(64bit)libfwupd2libfwupd2(ppc-64) @@@@@@@@@@@@@@    /sbin/ldconfig/sbin/ldconfigfwupdlibc.so.6()(64bit)libc.so.6(GLIBC_2.17)(64bit)libc.so.6(GLIBC_2.27)(64bit)libcurl.so.4()(64bit)libgio-2.0.so.0()(64bit)libglib-2.0.so.0()(64bit)libgmodule-2.0.so.0()(64bit)libgobject-2.0.so.0()(64bit)libjcat.so.1()(64bit)libjcat.so.1(LIBJCAT_0.1.0)(64bit)libjson-glib-1.0.so.0()(64bit)libjson-glib-1.0.so.0(libjson-glib-1.0.so.0)(64bit)libpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.17)(64bit)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)1.8.63.0.4-14.6.0-14.0-15.2-14.14.3d'@cc@cIO@c6@c,N@bb\@bb[@aaA@aaaaaaim@a^@`e`c`KW`6?`.V_S_м@_$_i_F@__@_O@_"@_"@_"@_@^א^א^1^@^h^)^ @]@]@]c]8H@] \\-@\@\Yz\73\\U@\ @[k@[Q@[\[h@[Xf@[GB[E@Zľ@ZlZ@Z`@Z1@Z1@Z1@Z;@Z8@Z2gYYYX @XX*X*X*X*X*X*X*X*X*Vii@Vii@Vii@Vii@Vii@Vii@Vii@Vii@Vii@Vii@UeU+U+dennis.tseng@suse.comdennis.tseng@suse.combjorn.lie@gmail.combjorn.lie@gmail.combjorn.lie@gmail.comdimstar@opensuse.orggmbr3@opensuse.orgbjorn.lie@gmail.combjorn.lie@gmail.comgmbr3@opensuse.orghpj@urpla.netbjorn.lie@gmail.combjorn.lie@gmail.comjlee@suse.comdimstar@opensuse.orgdimstar@opensuse.orgjsegitz@suse.comjlee@suse.comglin@suse.comglin@suse.comglin@suse.comglin@suse.cominfo@paolostivanin.comglin@suse.comglin@suse.comglin@suse.comglin@suse.comglin@suse.comdimstar@opensuse.orgdimstar@opensuse.orgqkzhu@suse.comdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgyfjiang@suse.comdimstar@opensuse.orgdimstar@opensuse.orgglin@suse.comglin@suse.comhpj@urpla.netstefan.bruens@rwth-aachen.debjorn.lie@gmail.comschwab@suse.debjorn.lie@gmail.comglin@suse.comglin@suse.commpluskal@suse.commaurizio.galli@gmail.comdimstar@opensuse.orgglin@suse.commail@bernhard-voelker.debjorn.lie@gmail.comglin@suse.comschwab@suse.deglin@suse.comndas@suse.denico.kruber@gmail.comjengelh@inai.denico.kruber@gmail.comtchvatal@suse.comoliver@getspam.deoliver@getspam.dedimstar@opensuse.orgmpluskal@suse.comantoine.belvire@opensuse.orgfcrozat@suse.comdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgstefan.bruens@rwth-aachen.defcrozat@suse.comstefan.bruens@rwth-aachen.dedimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgmpluskal@suse.comzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgzaitor@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.orgdimstar@opensuse.org- Change version 1.8.6: + Fix compiling error when building s390x ppc64le - add %ifnarch conditional to spec file + Recover one changelog unexpectedly removed when first pushing fwupd-1.8.6 to 15-SP5 - Thu Feb 24 06:29:53 UTC 2022 - jlee@suse.com - Add fwupd-bsc1193921-nvme-ignore-non-PCI-NVMe-devices.patch to ignore non-PCI NVMe devices (bnc#1193921)- For pushing fwupd-1.8.6 to 15-SP5 (fwupd-1.7.3), sync change log: (jsc#PED-1232) - fwupd-bsc1193921-nvme-ignore-non-PCI-NVMe-devices.patch be merged to fwupd-1.7.3- Update to version 1.8.6: + This release adds the following features: - Reduce the installed package size by more than 30% - Translate more interactive messages + This release fixes the following bugs: - Allow disabling a DFU device when required - Fix a regression when getting the i2c bus number - Fix a small memory leak when reloading the parade-lspcon device - Fix installing the dbx update when using fwupdtool - Improve writing CoSWID and uSWID metadata - Only include the last 5 releases in the installed metainfo file - Only request the BOS descriptor for newer libgusb versions - Prevent high memory usage when loading corrupt SREC files - Try harder when trying to find the default ESP volume - Use a higher compression preset for the UEFI splash images + This release adds support for the following hardware: - Focaltech touchpads - FPC fingerprint readers - Supermicro machines using Redfish - Drop plugin_sover define, and sub-packages libfwupdplugin7 and typelib-1_0-FwupdPlugin-1_0 following upstream changes.- Update to version 1.8.5: + This release adds the following features: - Add a new android-boot plugin to update specific block devices - Add new plugin to display SMU firmware version on AMD APU/CPU - Add support for platform capability descriptors so devices can set quirks - Move the generic Intel Goshen Ridge code out to a new plugin + This release fixes the following bugs: - Allow specifying the ESP when applying the dbx update - Always check the BDP partitions when getting all the possible ESPs - Correctly update Wacom AES devices - Disable changing sleep mode on Ryzen 6000 systems - Do not show the 'may not be usable while updating' message for DBX updates - Expose Pine64 PinePhone Pro MTD as Tow-Boot - Fix a critical warning when issuing Secure Boot modem AT commands - Fix a fuzzing crash when parsing malicious FDT data - Fix aligning up addresses greater than 4GB - Fix a possible crash when dumping VBE firmware - Fix a possible critical warning when parsing cabinet archives - Fix a regression when parsing pixart-rf firmware - Fix a small memory leak when parsing UF2 files - Fix checking for invalid depth requirements - Fix parsing the coSWID firmware ID when encoded as a UUID - Fix parsing uSWID uncompressed metadata - Fix uploading to DFU-CSR devices - Limit the archive size to 25% of the RAM, or 4G - Load coSWID metadata from a uSWID MTD block device - Never save the Redfish auto-generated password to a user-readable file - Only create users using IPMI when we know it's going to work - Write all the CCGX metadata block as intended + This release adds support for the following hardware: - Corsair SABRE RGB PRO Gaming mouse - More Sonix CAM devices - More Intel Goshen Ridge USB-4 docks - Changes from version 1.8.4: + This release adds the following features: - Add a translated title and long description for HSI security attributes - Add support for loading a machine-default BIOS settings policy - Add support for reading and writing BIOS settings - Allow loading BIOS settings for host emulation - Prompt users to fix some BIOS configuration issues + This release fixes the following bugs: - Actually show provided AppStream security issues - Add Quectel secure boot status AT commands - Correctly detect CET IBT - Do not assert when running with no plugins - Do not require UEFI capsule updates for checking TPM PCR0 - Do not show HSI events where we changed the spec result value - Fix applying the latest DBX update - Include vfat in the list of possible BDP partition types - Install all devices with the same composite id in fwupdtool - Only fail the kernel HSI test for specific taint reasons - Only show changed events in fwupdmgr security - Update vulnerable CMSE versions from CSMEVDT data + This release adds support for the following hardware: - Elan non-HID touchpads - Google Prism - LabTop Mk III - ThinkPad Thunderbolt 4 Dock - ThinkPad Universal Smart Dock - Changes from version 1.8.3: + This release adds the following features: - Add resolution flags to each security attribute failures for the user - Allow loading in emulated host profiles for debugging - Check if Intel TME has been disabled by the firmware or platform - Wait for the system to acquiesce after doing each update + This release fixes the following bugs: - Do not use CoD even when advertized on non-aarch64 platforms - Fix a crash when updating the Logitech Bolt radio device - Fix a critical warning when parsing an invalid PHAT record - Fix a critical warning when parsing invalid FDT firmware - Fix fwupdmgr security when plugins are added to the blocklist - Fix parsing SMBIOS data to correct the device hardware IDs - Fix uploading signed reports by sending the correct checksum - Use the correct protocol attribute name when exporting to JSON + This release adds support for the following hardware: - Additional Startech devices - Additional Elan fingerprint readers - Changes from version 1.8.2: + This release adds the following features: - Add startup profiling which allowed us to speed up daemon startup considerably - Add support for OptionROM, CPD and FPT firmware formats for future hardware - Add the HostVendor to the D-Bus interface - Break some internal ABI and add a conversion helper for out-of-tree plugins - Optionally build the quirk files into the daemon binary to reduce installed size + This release fixes the following bugs: - Allow front-end clients to read the percentage property - Allow more quirk entries to add multiple items - Allow to force install Genesys firmware even if the public-key does not match - Allow UFS disks to define the signed status in metadata - Autoconnect the Redfish network device when rebooting the BMC - Copy the instance ID strings when incorporating devices - Do not generate a capsule header for the FMP GUID - Ensure more firmware formats can round-trip to and from XML - Fix a regression for devices using the Atmel FLIP Bootloader - Fix running fwupdtool security with a user-specified plugin allowlist - Handle ENOTTY with the correct error code for ioctl calls - Increase the self tests coverage substantially - Modernize the AMT plugin and split out common MEI functionality - Only move the logitech-bulkcontroller progressbar forwards when writing - Set the device ID on the FwupdRequest to allow better UX - Show the get-details output when the device requirements fail - Simply quirk matching for i2c devices to speed up daemon startup - Support SHA256 fastboot hashes if specified - Use force-detach to bypass the DFU streaming check for camera devices - Use the SCSI target to correctly set the physical ID - Wait for the System76 launch device to re-enumerate if already unlocked + This release adds support for the following hardware: - Corsair HARPOON RGB Wireless mouse - U-Boot devices writing simple FIT images - Genesys M27fd AIM101 - More PixArt wireless devices - More Steelseries HID, Sonic and Fizz devices - System76 launch_2 - Changes from version 1.8.1: + This release adds the following features: - Add archive writing support for devices with composite firmware - Add a way to read device composite firmware in fwupdtool - Allow clients to opt-in to showing updates with user-solvable problems - Allow the device to pause polling when writing firmware - Export the system and device battery levels on the D-Bus interface - Log errors and warnings to the win32 eventlog when required - Add X-UsbReceiver as an update category with icon usb-receiver + This release fixes the following bugs: - Accurately return the last-set status to client tools - Allow dumping flashrom firmware using fwupdtool - Allow specifying a non-file D-Bus transport - Allow to request post actions from fwupdtool - Always be arch-explicit when installing OS deps - Be more resilient when restarting the Redfish BMC - Do not mark all Redfish updates as UPDATABLE - Do not use 'dongle' to describe USB receiver hardware - Download in-process when using fwupdtool - Fix a critical warning on failed modem update - Fix regression when probing PS175 devices - Hardcode the Redfish filedata name to firmware.bin - Set the Bluetooth version if REV has been set - Switch the Windows installer from NSIS to MSI - Use StartServiceCtrlDispatcherA for the daemon on Windows - Use the native certificate store on Windows + This release adds support for the following hardware: - Corsair KATAR PRO XT, SABRE PRO and KATAR PRO Wireless - HP Thunderbolt Dock G4 - Lenovo ThinkPad Universal USB-C Dock - More PixArt wireless devices - More SunplusIT USB cameras - Some UFS devices - Steelseries Aerox 3 Wireless and Rival 3 Wireless - Changes from version 1.8.0: + This release adds the following features: - Add a new attribute for CPUs supported by HSI - Add coSWID and uSWID parsers to libfwupdplugin for initial SBoM support - Add new HSI attributes for the AMD PSP and various other system protections - Add the runtime fwupd-efi version as a firmware requirement - Allow 'fwupdmgr install' to install a specified firmware version - Allow overriding the detected machine type for debugging and development - Restart the BMC after installing BCM updates - Show the device serial number and instance IDs by default - Support dumping the MTD image to a firmware blob - Take a device inhibit when updating a device - Use the CFI manufacturer ID to set the vendor - Use the correct icon automatically for more hardware + This release fixes the following bugs: - Add signed-payload metadata for more devices - Allow Capsule-on-Disk to work in more cases - Allow quirking the detected flashrom flash size - Check for os-release on FWUPD_SYSCONFDIR - Check the alignment when parsing raw firmware - Check the update protocol exists when checking requirements - Convert the build system to use meson tristate features - Correctly probe USB-2 hubs with more than 7 ports - Do not add the Windows compatibility ID to capsule devices - Do not allow the DBX update for specific motherboards - Do not expect KernelCmdline on Windows - Do not export USB4 host controllers as updatable if they don't have unique GUIDs - Do not fallback to audio-card and use a more suitable icon for USB hubs - Do not hardcode the libexecdir to /usr/libexec - Do not leak child processes when canceling - Do not show unconnected or unreachable devices in the client tools - Do not throw away the TPM eventlog when uploading to the LVFS - Do not use /var/run for the socket - Export the version_lowest_raw value correctly - Fix build for MacOS and add to the CI matrix - Fix eventlog replay for Intel TXT machines - Fix several small memory leaks - Fix writing large mtd images than 10kb - Ignore MTD devices that report EPERM on open - Mark the ME region device locked if it is read only - Never send the DeviceChanged signal with old data - Only show the CLI time remaining for predictable status phases - Respect the NO_COLOR env variable - Return the correct error when there is no GPIO device to open - Support the new UPower PENDING device states + This release adds support for the following hardware: - CH341A SPI programmer - Corsair Sabre RGB PRO and Slipstream USB receiver - Genesys GL3521 and GL3590 hubs - Google Servo Dock - Logitech M550, M650 and K650 - More ELAN fingerprint readers - More integrated Wacom panels - More NovaCustom machines - More StaLabs StarLite machines - More Tuxedo laptops - Quectel EM05 - FlatFrog devices - System76 launch_lite_1 - Rebase patches with quilt. - Use ldconfig_scriptlets macro for post(un) handling. - Add shlib_sover define and set it to 2, ease future updates. - Add plugin_sover define and set it to 7, ease future updates, and rename libfwupdplugin5 to libfwupdplugin7 following upstream changes. - Drop gtk-doc and pkgconfig(gtk-doc) BuildRequires: No longer needed nor used. Following this, stop passing docs=gtkdoc to meson, no longer recognized. - Add pkgconfig(gi-docgen), pkgconfig(libcbor), pkgconfig(mm-glib), pkgconfig(mbim-glib), pkgconfig(qmi-glib) and pkgconfig(umockdev-1.0) BuildRequires, and conditional pkgconfig(flashrom) BuildRequires: New dependencies. - Update options passed to meson following upstream changes. - Replace false for plugin_nvme and plugin_redfish with enabled, build nvme and redfish plugins. - Split out developer/api docs in new doc sub-package, add fdupes BuildRequires and macros, remove duplicates.- Update to version 1.7.10 (CVE-2022-3287, boo#1203852): + Always check the BDP partitions when getting all the possible ESPs + Correctly detect CET IBT + Do not show HSI events where we changed the spec result value + Fix aligning up addresses greater than 4GB + Fix applying the latest DBX update on machines with 20200729.x64 installed + Fix checking for invalid depth requirements + Fix getting the new version number of the USI docking hardware + Fix HSI prefix for invalid chassis + Never save the Redfish auto-generated password to a user-readable file (CVE-2022-3287, boo#1203852). + Only create users using IPMI when we've tested the hardware + Only fail the kernel tainted HSI test for specific taint reasons + Only show changed events in the fwupdmgr security output + Recognize CSME version 16 and update vulnerable versions from CSMEVDT data + Write all the CCGX metadata block as intended- Update to version 1.7.9 (boo#1201311): + Do not generate a capsule header for the FMP GUID. + Do not use CoD even when advertized on non-aarch64 platforms. + Fix a critical warning when parsing an invalid PHAT record. + Fix a regression for devices using the Atmel FLIP Bootloader. + Fix parsing SMBIOS data. + Set the device ID on the FwupdRequest. + Use the correct protocol member when converting to JSON. + Wait for the system76-launch device to re-enumerate if unlocked and reset. - Changes from version 1.7.8: + Add the bootloader VID/PID used for the first batch of ColorHug devices. + Also check for os-release in SYSCONFDIR. + Export the version lowest raw value correctly. + Fix a Wacom timeout when parsing very corrupt firmware. + Fix Genesys device enumeration failure by not claiming the interface. + Hardcode the Redfish filedata name to firmware.bin. + Install D-Bus introspection data even if introspection is disabled. + Only set the flashrom BIOS size if not already quirked. + Read the SynapticsMST firmware size in a more safe way. + Restart the BMC after installing BCM updates.- Update to version 1.7.7: * This release adds the following features: + Add CCGX trigger code to support future hardware + Add signed and unsigned payload metadata to more devices + Allow overriding the detected machine type + Allow quirking the flashrom flash size + Do not allow the DBX update for broken firmware versions * This release fixes the following bugs: + Do not add the backup BMC device as it shares the same GUIDs + Do not hardcode the libexecdir to /usr/libexec + Do not leak child processes when canceling + Do not throw away the TPM eventlog when uploading reports to the LVFS + Don't export USB4 host controllers if they do not have unique GUIDs + Fix build for MacOS + Fix the TPM eventlog replay for Intel TXT machines + Fix writing large MTD images + Never send the DeviceChanged signal with invalid data + Return the correct error when there is no GPIO device to open + Show the update message and update image in front end tools + Support the new PENDING upower device states * This release adds support for the following hardware: + Logitech M550, M650 and K650 + More Elan fingerprint readers + More Star Labs StarLite laptops + More Wacom panels found on Lenovo laptops - Split bash and fish completions to separate subpackages - Remove un-needed BRP_PESIGN_FILES - Set GNU_SOURCE so meson detects F_OFD_SETLK in fnctl.h support- Update to version 1.7.6: * This release adds the following features: + Add a flag for UEFI devices that never want a capsule header auto-added + Add a flag to indicate the device has a signed or unsigned payload + Add a plugin to set a GPIO pin for the duration of an update + Add a simple plugin to enumerate (but not update) SCSI hardware + Add two more instance IDs to the MTD devices + Add X-BaseboardManagementController as an update category + Allow assigning issues to devices for known high priority problems + Parse the MTD firmware version using the defined GType * This release fixes the following bugs: + Check the IFD sections have non-zero data length to fix a critical warning + Modify the AT retry behavior to fix getting the firmware branch + Do not run fwupd-refresh automatically in containers + Do not show a warning if the TPM eventlog does not exist + Do not show TSS2 warning messages by default + Fix a critical warning when loading an empty TPM eventlog item + Fix a logic error when adding the community warning in fwupdmgr + Fix loading flashrom devices in coreboot mode + Fix the error handling when updating USB4 retimers + Show the user when devices are not updatable due to inhibits + Skip probing the Dell DA300 device to avoid a warning + Try harder to convert to a version into a correct semver + Use multiple checksums when there are no provided artifacts * This release adds support for the following hardware: + HP M2xfd monitors + Star Lite Mk III- Update to version 1.7.5: * This release adds the following features: + Add a flag to indicate the firmware is not provided by the vendor + Add support for showing dependency versions in JSON format + Allow fwupd to operate in socket mode without a D-Bus daemon + Allow marking a device as End-of-Life by the OEM vendor + Allow specifying the machine Best Known Configuration locally + Fall back to the ARM Device Tree 'compatible' data when required * This release fixes the following bugs: + Be more robust by retrying IPMI transactions on servers + Change the expired Redfish password when required + Fix a ModemManager segfault on startup for some MBIM-QDU devices + Fix a possible dell-dock segfault at startup + Fix compiling with new versions of efivar + Fix the Nordic bootloader type detection + Fix USB4 retimer enumeration + Get the SMBIOS table and host machine ID when running on Windows + Show results when calling get-details if failing requirements + Uninhibit the modem using ModemManager after upgrade * This release adds support for the following hardware: + Future Analogix devices + NovaCustom NV4x - Changes from version 1.7.4: * This release adds the following features: + Add firmware branch support for ModemManager devices + Allow firmware engineers to patch files at known offsets + Show why more devices are not marked as updatable * This release fixes the following bugs: + Allow fwupdtool to be run as the non-root user in more cases + Assign the Logitech bulkcontroller update interface correctly + Do not allow UEFI updates when the laptop lid is closed + Do not autoload ipmi-si to avoid warning on non-server hardware + Do not show a critical warning for a weird TPM event log + Fix waiting for USB devices when using Windows + Ignore non-PCI NVMe devices * This release adds support for the following hardware: + HP USB-C G2 Dock + Many UF2 devices, experimentally + More PixArt devices + Nordic HID devices using MCUBoot + Quectel EG25-G LTE Modem + ThinkPad Thunderbolt 4 Dock- Update to version 1.7.3: * This release adds the following features: + Add a sync-bkc subcommand to ensure a known set of firmware versions + Add FuArchiveFirmware for plugins that use archives as firmware files + Add quirkable page and sector size properties to FuCfiDevice + Make Upower and powerd support optional * This release fixes the following bugs: + Add some sanity checks to the elanfp firmware parser + Add the CFI JEDEC instance ID if using the vendor-extended version + Check the value range when parsing the quirk keys + Do not wait for a USB runtime if will-disappear is set + Enable the MOTD integration when using pam_motd + Fix DFU regression when merging the FuProgress work + Fix running the tests when fwupd is not installed + Fix the GLib error message when inotify max_user_instances is too low + Fix VLI VL820Q7 detection to fix flashing of the Lenovo TBT3 dock + Ignore a USB error for STM32 attach when the device goes away + Make the HSI tests optional for embedded targets + Make the plugin startup order deterministic + Set Thunderbolt ports offline on host controller + Use endian-safe version functions when enumerating Logitech hardware + Use lowercase flag names in intel-spi to prevent a runtime warning + Wait for the System76 Launch device to come back from DFU mode * This release adds support for the following hardware: + Most Nordic Semiconductor nRF Secure devices - Fix build when not on TW: add BR protobuf-c- Fix build issue in spec (references to libfwupdplugin2 -> libfwupdplugin5)- Update to version 1.7.2: * This release adds the following features: + Add a new HSI check that PCR registers 0-7 are not empty + Add several compile flags to reduce the install size by over 300Kb + Allow overriding HwId data from the daemon.conf config file + Allow overriding the firmware GType from a quirk file + Export the component release ID over DBus + Remove support for the SoloKey and ChaosKey devices + Show a daemon warning if quirk flags are malformed + Speed up the daemon startup by ~40% by doing less at startup * This release fixes the following bugs: + Be case insensitive when fixing the device model + Fix a critial warning in ccgx found by the fuzzer + Fix a DFU crash if the attach failed due to a hardware fault + Fix a Redfish crash when specifying a URL without a port + Fix CLI downloads when using fwupdmgr --ipfs + Fix critical warning when /etc/machine-id does not exist + Inhibit thunderbolt devices to correctly use UPDATABLE_HIDDEN + Set SSL_VERIFYHOST=0 when using Redfish to fix OpenBMC auth + Skip UEFI devices that fail coldplug * This release adds support for the following hardware: All exported MTD block devices - Changes from version 1.7.1: * This release adds the following features: + Allow specifying 'fwupdmgr device-test foo --json' for unattended testing + Allow using a filename when using set-approved-firmware + Inhibit ModemManager device in mbim-qdu + Share the Common Flash Memory Interface quirks between plugins + Show changes in HSI attributes when using 'fwupdmgr security' + Show the user a warning if updating may affect full-disk-encryption + Show translated firmware release notes when provided + Support loading remotes from /var/lib/fwupd/remotes.d * This release fixes the following bugs: + Fix a CCGX regression when loading firmware + Fix a potential crash when dumping Parade devices + Fix build error when sys/io.h is not available + Fix building the Synaptics RMI self tests on s390x + Fix the CSME CVE detection for new generations + Handle EPERM when running the self tests on systems with IPMI + Mark as SUPPORTED even if on battery power + Only save the HSI attributes to the database if different + Raise the client timeout value from 25 seconds to fix Redfish startup + Redirect the old HSI links to the correct place + Relax the ITE SuperIO signature checks for new hardware support + Set device time and timezone for logitech bulkcontroller devices + Set the verfmt of the returned device when the daemon device is unset * This release adds support for the following hardware: + Dell Atomic Dock + HP Thunderbolt Dock G4 + More PixArt devices + Steelseries Stratus + Wacom 3rd-gen Intuos BT - Changes from version 1.7.0: * This release adds the following features: + Add FuCfuPayload and FuCfuOffer for future usage + Add support for an 'unreachable' device flag + Add support for Logitech devices supporting the Unified Battery feature + Allow adding GUIDs to each HSI security attribute + Allow installing the LVFS remote, but with it disabled by default + Convert security attributes to JSON and write then to the database + Convert the device test script to a fwupdmgr subcommand + Create Redfish user accounts automatically using IPMI + Use an interactive request to restart some Logitech DFU devices * This release fixes the following bugs: + Abort on invalid SREC files early to avoid a fuzzing timeout + Allow using interrupt transfers for HID devices + Allow waiting for multiple devices to replug + Fix a critical warning on a Unifying flash failure + Fix a regression in flashing the Dell dock + Fix Thunderbolt host controller probing + Forcefully set checksums found in cabinet files to lowercase + Force UX-capsule over full size BGRT + Make the SuperIO ports and timeouts specific to the DMI model + Only probe SynapticsMST devices that have opted-in + Remove support for --ignore-power as it did not work for UEFI firmware + Reset the CMOS as required when changing system firmware branch + Restart the daemon if any of the the plugin config files are modified + Show HSiLevel=0 attributes in JSON security output + Update the child composite ID if the parent changes + Use a per-device global percentage completion + Write the BMP image upside down to avoid using a negative bitmap height * This release adds support for the following hardware: + A huge number of Synaptics CAPE devices + Elan fingerprint readers + Logitech Bolt peripherals, receivers and radio hardware + Logitech devices supporting the bulk controller protocol + More supported PixArt devices + More supported StarBook coreboot devices + Union Point SPI hardware - Add pkgconfig(libprotobuf-c) and pkgconfig(protobuf) BuildRequires: New dependencies. - Refresh patches with quilt. - Drop sub-package fwupdtpmevlog, no longer built. - Update URL in _service, new home.- Update to version 1.6.4: * Allow overriding the quirks directory at runtime * Fix a regression in flashing the Dell dock * Fix probing the Dell TPM * Show HSiLevel=0 attributes in JSON security output * Abort on invalid SREC files early to avoid a fuzzing timeout * This release adds support for the following hardware: + AVer ATLAS CAM/CAM520 Pro2 + Cayenne/Spyder Synaptics MST + VL819 USB devices - Changes from version 1.6.3: * This release adds the following features: Fall back to the parent if the child does not have a battery level set * This release fixes the following bugs: + Disable the uefi_capsule plugin if Redfish coldplug succeeded + Fix an elantp crash when starting the daemon + Fix compiling with old versions of libxmlb + Fix detection of 8Bitdo wireless usb adapter + Fix the 8bitdo N30 Pro 2 install duration + Fix the modem-manager report that failed to get device after update + Fix writing large redfish firmware files * This release adds support for the following hardware: + Poly Studio P21 + Realtek RTD2141B - Switch service to obs_scm, and recompress to buildtime. - Drop automatic changesgenerate, upstream have perfectly fine and human understandable release notes at https://github.com/fwupd/fwupd/releases that should be copied into .changes.- Add requires to udisks2 for dbxtool update. (bnc#1192344)- If the machine we install onto has shim installed, it is likely an EFI based system. Require fwupd-efi in this case (boo#1192206).- Require libfwupdplugin2 by the -devel package: the -devel package installs the .so symlink, thus we must guarantee the target library to be present.- Added hardening to systemd service(s) (bsc#1181400). Added patch(es): * harden_fwupd-offline-update.service.patch * harden_fwupd-refresh.service.patch- Update to version 1.6.2 - The fwupd efi program be separated to fwupd-efi package. - Removed pesign-obs-integration, moved needssslcertforbuild , SBAT and EFI signing stuff to fwupd-efi. - Moved libfwupdplugin1 to libfwupdplugin2 - Change log from upstream: https://github.com/fwupd/fwupd/blob/main/data/org.freedesktop.fwupd.metainfo.xml - This release adds the following features: * Add a plugin to check Lenovo firmware settings * Add initial support for the powerd daemon * Add support for CapsuleOnDisk * Add support for installing UEFI updates from GRUB * Add support for soft-requirements that can be ignored with --force * Allow devices to only accept version upgrades * Allow discovery of Redfish BMCs specified by VID-PID or MAC * Allow the daemon to request interactive action from the end user * Automatically connect the BMC network interface at startup * Show the build timestamp if set on the device * Show the user how to switch out of Wacom tablet Android-mode - This release fixes the following bugs: * Add the alternate vendor name into the 8BitDo allowlist * Allow multiple devices to set WAIT_FOR_REPLUG * Allow the client to watch for more property changes * Always ensure the SuperIO version string is NUL terminated * Automatically clear the update error as required * Disable all UX capsules for Lenovo hardware * Do not assume the metainfo file is NUL-terminated * Do not save invalid files on LVFS server error * Fix a VLI regression in enumerating the PD device * Fix a VLI regression when installing VL820Q7 firmware * Fix enumeration of the Synaptics Prometheus config child * Fix parsing Redfish USB/PCI network VID/PIDs * Fix the fwupdmgr progressbar spinner to actually work * Fix version number for legacy Wacom Bluetooth modules * Ignore virtual M.2 ATA devices * Preserve NEEDS_REBOOT on successful update * Prevent a corrupt PHAT table from allocating lots of memory * Read the Redfish SMBIOS table when required * Remove the vendor string from the device name where required * Save the update state to the database correctly all of the time * Switch from sysctl to ioctl for ESRT on FreeBSD * Try reading from /sys/class/dmi if SMBIOS direct access fails * Watch for children added or removed after setup has been completed * Work around a XCC-ism on Lenovo hardware - This release adds support for the following hardware: * ModemManager devices supporting Firehose or MBIM QDU * More models of RTS54HUB * More Poly DFU devices * Parade LSPCON * PixArt receiver and wireless hardware * Realtek MST with RTD2142 * SuperIO IT5570 * USB4 Dell dock- Remove valgrind from BuildRequires since it's not a hard requirement anymore. (bsc#1184248)- Update to version 1.5.8: New features: * Add a new internal flag to opt-in to GUID matching * Add D501 Baklava device support * Add fu_device_set_battery_level() * Add missing uint64 read and write helpers * Add Qubes wrapper source and create packages * Allow enabling plugins only matching a specific HwId * Prompt for unlock keypress if reset command is blocked * Remove obsolete dell-dock non-passive update flow support * Remove the Hughski public key * Show a warning when parsing invalid quirk files * Support for GATT characteristic signals/notifications * Support more than one protocol for a given device Fixes: * Align the CCGX DMC firmware to 64 byte chunks * Be more strict for custom quirk keys * Check pixart firmware compatibility with hardware before flashing * Correct a thunderbolt assertion if kernel failed FW read * Correctly erase STM32 devices when transfer size is less than sector size * Detect SREC overflow to avoid adding ~4GB of 0xFF padding * Do not show a critical error when flashing footer-less binary files * Don't allow device updates while needing activation * Fix a regression in the elantp defined IAP start address * Fix a regression where activate stopped working * Fix firmware update of pointing device on Lenovo ThinkPad Nano * Fix the HSI plugin 'Disabled' state * Fix the quirk key name for the Lenovo HDMI with power * Fix writing to the GD32VF103 bootloader * Only call elantp->detach() when writing a firmware blob * Updated StarLabs GUIDs * Wait a few ms for the Logitech hardware to settle after detach - Remove GPG-KEY-Hughski-Limited from the filelist - Drop upstreamed patch + fwupd-bsc1182057-fix-sbat-section-copy.patch- Add fwupd-bsc1182057-fix-sbat-section-copy.patch to set the proper section flags for .sbat section so that objcopy can copy it into fwupd*.efi (bsc#1182057)- Update to version 1.5.7: New features: * Add initial support for Bluez bluetooth devices * Add more supported pixart devices * Add support for the RTD21xx HDMI converter Fixes * Convert MBR types to GPT GUIDs to help find the ESP * Do not allow updating a synaptics-mst device with no customer ID * Drop unused heap pages after startup has completed * Ensure SBAT metadata is added correctly * Move the plugin build logic to the plugins themselves * Only allow verify-update for plugins that support CAN_VERIFY - Specify SBAT metadata for openSUSE/SLE (bsc#1182057) - Adjust the meson options + plugin_uefi => plugin_uefi_capsule and plugin_uefi_pk + plugin_synaptics => plugin_synaptics_mst and plugin_synaptics_rmi + Disable Intel AMT plugin in non-x86 systems- Update to 1.5.6: New features: * Add SBAT metadata to the fwupd EFI binary * Add support for GD32VF103 as found in the Longan Nano * Add support for RMI PS2 devices * Add support for the System76 Keyboard * Allow downloading firmware from IPFS * Install the UX data into a single .tar.xz file * Add a plugin to update PixArt RF devices * Add new hardware to use the elantp and rts54hid plugins * Allow specifying more than one VendorID for a device * Detect the AMD TSME encryption state for HSI-4 * Detect the AMI PK test key is not installed for HSI-1 * Add Maple Ridge Thunderbolt firmware parsing support * Add --no-remote-check to ignore checking for download remotes * Allow creating FMAP and Synaptics firmware using builder.xml Fixes: * Add support for the Starlabs LabTop L4 * Allow using an external ESP again * Ask the user to reboot when required if downgrading * Be more paranoid when parsing ASCII buffers and devices * Check if the fwupd BootXXXX entry exists on failure * Clear the pending flag if restarting the system * Do not allow flashing using flashrom if BLE is enabled * Do not allow Lenovo hardware to install multiple capsules * Do not parse the OptionROM image * Do not show Unknown [***] for every client connection * Fix dnload wBlockNum wraparound for ST devices * Fix OOM when using large ArchiveSizeMax values * Fix several crashes spotted by AddressSanitizer * Fix several places where the Goodix MOC plugin could crash * Include the PCR0 to the report metadata * Report the lockdown status from UEFI and SuperIO plugins * Show a console warning if the system clock is not set * Fix flashing a fingerprint reader that is in use * Fix several critical warnings when parsing invalid firmware * Fix updating DFU devices that use DNLOAD_BUSY * Ignore the legacy UEFI OVMF dummy GUID * Make libfwupd more thread safe to fix a crash in gnome-software * Never show unprintable chars from invalid firmware in the logs * Allow using fwupdtool as non-root for firmware commands * Do not trust the Block.HintSystem boolean for ESP filtering * Fix a memory leak when parsing Synaptics firmware * Fix a possible crash when reading the Goodix MOC USB request * Fix crashes when parsing invalid FMAP, DMC, Solokey and Synaptics images - Deprecate fwupd-bsc1179790-disable-hintsystem.patch- Add fwupd-bsc1179790-disable-hintsystem.patch to remove Block.HintSystem from ESP filtering (bsc#1179790)- Update to version 1.5.3: + Lower the CURL version required to fix build in RHEL + Do not use meson ternary operations to avoid bumping the required meson version + Added Lite Mk III + Allow setting the GMainContext when used for sync methods + Fall back to the misc device for serio devices + Actually implement rescan in FuUdevDevice + bcm57xx: Refactor CRC code to remove extra byteswap + bcm57xx: Fix CRC check + synaptics-rmi: Don't crash if calling ->to_string() before - >setup() + Fix a possible critical warning due to missing retval + Add the serio->firmare_id for UDev devices + Export the driver name from FuUdevDevice + Allow the client to send PKCS7 and GPG signatures + Force the remote kind to JCat server-side + Only parse the signature if the remote is JCat + fu-main: Fix sender_features insert with wrong size + make platform integrity plugin optional and disabled by default + Add quirk for Western Digital + Mark more user-visible strings as translatable + modem-manager: validate firmware update method combinations + modem-manager: remove unused byte counts in QMI/PDC update logic + modem-manager: make sure the correct interface number is used for QMI + modem-manager: udev monitoring only if device switches layout + modem-manager: plug udev client leak + Restrict loading component types of firmware - Enable supported_build to clarify that this package is supported (bsc#1179790) - Drop fwupd-platform-integrity.conf since upstream disables the platform integrity module by default now due to incompleteness. - Address fwupd-refresh.service in %preun, %pre, %post, and %postun and provide a rc link for it - Version "Obsoletes: dbxtool" and "Obsoletes: fwupdate"- Update to version 1.5.2: + ata: Add OUI quirk for Toshiba + libfwupd: Restore recognizing gpg and pkcs7 types still + Register the SoupSession gtype when required + Switch from libsoup to libcurl + Fix sync method when called from threads without a context + Move ABI check to Github actions + Enable github workflows + libfwupd: Add fwupd_client_download_file() + libfwupd: Add fwupd_client_get_user_agent() + Only download the remote metadata as required + Add breaks for fwupdate 12-7 (Closes: #960688) + Install modules-load configs in the correct directory + vli: Do not be clever replugging the MSP430 device + vli: Make some trivial debugging more specific to help debug an issue + make gcab optional + Fall back to FAT32 internal partitions for detecting ESP + Add a flag to indicate if packages are supported + uefi: a new option for uefi configuration to use UEFI removable path + Add a section to man page on scripting + synaptics-mst: Improve reliability by waiting 2 seconds after writing data + hailuck: Add an plugin for the Pinebook Pro laptop + Allow setting global flags for FuHidDevice + Set the SMBIOS chassis type to portable if a DT battery exists + colorhug: Don't set the version format to triplet at startup + Allow components to set the icon from the metadata + colorhug: Fix detection of version on older firmware versions + bcm57xx: Fix reading vendor/device ids from firmware. + Remove HSI update and attestation suffixes + trivial: make dbxtool executable to fix snap build + Ignore an invalid vendor-id when adding releases for display + Notify the service manager when idle-quitting - Refresh fwupd-bsc1130056-change-shim-path.patch - Changes in BuildRequires: + Replace pkgconfig(libsoup-2.4) with pkgconfig(libcurl) + Replace pkgconfig(systemd) with pkgconfig(libsystemd) - fwupd-msr.conf and fwupd-platform-integrity.conf are moved to %{_modulesloaddir}.- Obsoletes and Provides dbxtool since fwupd 1.5.0+ now embeds dbxtool in the dbxtool plugin- Amend the spec file (jsc#SLE-16818) + Only enable fish support for Tumbleweed + Only enable the MSR plugin for x86 + Only install dbxtool in the architectures with UEFI support- Update to version 1.5.1: + Use UDisks to find out if swap devices are encrypted. + Show a link to discover more information about a specific plugin failure. + updated fish completions to 1.5.0. + Remove the duplicate parent-child data in FwupdDevice and FuDevice. + Show a less scary fwupdate output for devices without info. + thunderbolt: recognize authorized value of '2' as well. + bcm57xx: Make hotplug more reliable. + Use a different Device ID for the OptionROM devices. + contrib/ci: switch TPM simulator from ibmswtpm to swtpm. + Delete unused EFI variables when deploying firmware. + Fix probe warning for the Logitech Unifying device. + Include the amount of NVRAM size in use in the LVFS failure report. + Add external interface messages.- Update to version 1.5.0: + Add a compatible re-implementation of the rhboot dbxtool. + Add async versions of the library for GUI tools. + Add commands for interacting with the ESP to fwupdtool. + Add firmware-extract subcommand to fwupdtool. + Add FwupdPlugin so we can convey enumerated system errors to the end user. + Add plugin for Goodix fingerprint sensors. + Add plugin that can update the BCM5719 network adapter. + Add plugin to update Elan Touchpads using HID. + Add support for a delayed activation flow for Thunderbolt. + Add support for ChromeOS Quiche and Gingerbread. + Add support for Hyper hardware. + Add support for the Host Security ID. + Add support for ThunderBolt retimers. + Add switch-branch command to fwupdtool and fwupdmgr. + Allow blocking specific firmware releases by checksum. + Allow contructing a firmware with multiple images. + Allow firmware to require specific features from front-end clients. + Allow updating the dbx using the LVFS, validating it is safe to apply. + Include the HSI results and attributes in the uploaded report. + Support loading DMI data from DT systems. + Support LVFS::UpdateImage for GUI clients.- Add fwupd-jscSLE-11766-close-efidir-leap-gap.patch: Set SLE and openSUSE esp os dir at runtime (jsc#SLE-11766) - Drop _multibuild and build option -Defi_os_dir="%{efidir}": with the above patch fwupd can detect esp os dir dynamically - Update the efidir related %post and %postun scripts in spec file- Update to version 1.4.5: * Add XB_QUERY_FLAG_FORCE_NODE_CACHE * Add support for a delayed activation flow for Thunderbolt * Allow firmware to require specific features from front-end clients * Allow multi-byte FuUdevDevice preads and writes * Be more defensive when remotes are missing required keys * Disable the SQLite lookaside cache * ccgx: Add more hybrid dock support * ccgx: Modify readme to remove customer info * ccgx: add new protocol for dmc dock * ccgx: remove verify flag in plugin * modem-manager: read the vendor ID directly from sysfs attribute Fixes: #2209 * thelio-io: Add the DFU instance ID as a counterpart only * thunderbolt: Add a new subclassed thunderbolt firmware update type * thunderbolt: Allow quirks to skip the authentication step * thunderbolt: drop support for force power * tpm-eventlog: fix PCR0 calculation * uefi: check for free space after cleaning up ESP * vli: Add dual-image feature for VL103 backup firmware * vli: Add the project ID shared SPI PD controllers * vli: Allow chained usb hub devices where the parent needs GPIOB reset * vli: Do not modify the class vfuncs depending on device type * vli: Do not use GUID matching for the MSP device * vli: Rename FuVliUsbhubI2cDevice to FuVliUsbhubMsp430Device * vli: Set FuQuirks on the shared SPI object * vli: Set the i2c instance IDs in probe() * vli: Use the GPIOB reset for the MiniDock VL103 * vli: Wait for the root device to be replugged when updating the MSP430- Update to version 1.4.4: * Release fwupd 1.4.4 * Fix regression when checking for downgraded metadata- Update to version 1.4.3: * Release fwupd 1.4.3 * ata: A OUI quirk for Kingston * ccgx: Fix a potential division by zero * Check the device requirements when returning from GetDetails * fu-engine: Allow --plugin-whitelist to use dashes instead of underscores * Always enforce the metadata signature has a valid timestamp * ccgx: modify install duration for dmc device * ccgx: Add support for HP DMC dock devices * dell-dock: prevent updates to occur via synaptics-mst plugin * dell-dock: Capture the dock SKU in metadata * synaptics-prometheus: Force the minor version from 0x02 to 0x01 to make sure the devices can be updated back to 0x01. * Generate a body for github releases (Fixes: #2034)- Build the package separately for openSUSE and SLE using _multibuild (jsc#SLE-11744).- Update to version 1.4.2: * vli: Add no-guid-matching for all VLI devices * vli: Remove a copy-and-paste mistake * Add two OUI quirks * ata: Add WD OUI quirk 000cca * synaptics-rmi: Essentially blacklist Dell K12A * dfu: Avoid communicating when bitManifestationTolerant is off * ata: Add OUI quirk for Western Digital * dfu: Support MATEKF722SE quirk * Fix various build issues with -Wdiscarded-qualifiers * thunderbolt/dell-dock: Delay activation for Thunderbolt updates * Switch the default of EnumerateAllDevices to false * Add OUI quirk for SanDisk * vli: Add two standard USB instance IDs for shared-PD devices * vli: Use GPIOB to reset the VL817 found in two Lenovo products * tpm-eventlog: Correct the display of final calculated PCRs * wacom-raw: fixup switching to bootloader mode- Update to version 1.4.1: * thunderbolt: Don't show safe mode errors for USB4 host controllers * ep963x: Various changes to make the plugin actually work on real hardware * Make tss2-esys conditional * ep963x: Remove some dead code spotted by Coverity * ccgx: Only update the FW2 partition of the ThinkPad USB-C Dock Gen2 * ccgx: Expand the FWImageType for future hardware * Allow specifying the device on the command line by GUID * Fix the DeviceID set by GetDetails * wacom-usb: Fix a theoretical buffer over-read to make GCC happy * vli: Only show the i2c devices on the USB3 hub * Allow devices to be updatable, but only when upgrading a proxy device * Reset the progressbar time estimate if the percentage is invalid * ccgx: Always report 100% when finished writing * Add a device quirk that forces an explicit device-id match * ccgx: Set the device name and summary from quirk files * vli: Only do the APP5 FW bug fix on affected hardware * vli: Show all the buffer when debugging with FWUPD_VLI_USBHUB_VERBOSE * fu-engine: Refresh device name and format before setting supported flag * Allow a device to set the logical or physical ID during ->setup() * ccgx: Split out a trivial helper to set the instance IDs * ccgx: Set the device name to be more useful * ccgx: Set the logical ID as the FwMode * ccgx: Split out a trivial function to set the version * ccgx: Do not reboot the device write after installing * ccgx: Do no show the flash parameters when unknown * Allow devices to match the proxy device by GUID * Do not skip attach() if the device is marked _WILL_DISAPPEAR * dell-dock: Port to using fu_device_get_proxy() * Allow adding a device 'proxy' device that can do actions on it * vli: Do not show the USB 2 recovery devices for USB 3 hubs * vli: Add metadata to identify which is the same physical device * uefi: correctly format firmware version of Dynabook (né Toshiba) X30, X40 and probably others * synaptics-cxaudio: Use the ->attach() device vfunc * synaptics-cxaudio: Wait for the device to reboot after writing firmware * logitech_hidpp: decrease verbosity of messages that hid++ ID is missing * Prefer to update the child first if the order is unspecified * Do not modify the device priority for child devices- Exclude fwupdate from the architectures without UEFI support.- Update to version 1.4.0: * Release fwupd 1.4.0 * Allow removing device flags from quirk files * Use black to format python source in a consistent manner * Define SOURCE_VERSION when building a package * Only set the parent when adopting children * Do not conditionalize attach() and detach() on IS_BOOTLOADER * Do not crash the daemon if a plugin does something dumb * wacom-usb: Add more sanity checks in case the daemon goes crazy * wacom-usb: Use a per-device cleanup function * Add some more device regression tests * wacom-usb: Add a lot of missing metadata about the devices * wacom-usb: Hide a lot of debugging behind FWUPD_WACOM_VERBOSE * Only auto-add counterpart GUIDs when required * ccgx: remove update message * ccgx: add parent guid for hybrid dock * ccgx: Use a smaller timeout for i2c read and write operations * ccgx: Retry the register read and write with a i2c reset * ccgx: Fix buffer overflow when reading out i2c status * ccgx: Retry the HID disconnect up to 5 times * ccgx: Show a better error message on failure * ccgx: Allow forcing firmware of the wrong app_type with fwupdtool * Modularize the hardware tests * Ignore indirect devices that replug during the composite firmware update * Export the device state as part of the D-Bus interface * Fix devices that use CounterpartGuid when more than one device is installed * Use the GUID as a fallback rather than the connection ID * ccgx: Fix critical warning on i2c write failure * logitech-hidpp: Do not add peripheral devices for receiver in BL mode * Install the installed-tests only if tests are enabled * Load the signature to get the aliased CDN-safe version of the metadata * vli: Only reboot the USB hub once * synaptics-cxaudio: Only use the PATCH2 address when the patch level is 2 * add STM32F745 stm dfuse quirk * dfu: Add a way to set the timeout from a quirk * Export the release urgency * Export the release creation time * Check the firmware requirements before adding SUPPORTED * data/motd/fwupd-refresh: Only order after network.target * ccgx: Do not add the HID device that will disconnect * ccgx: Use Silicon ID and Application type to set flash parameters * Add a new daemon configuration option to control EnumerateAllDevices * logitech_hidpp: set the bootloader protocol * Install meson from pip for LGTM * bash: add completion for fwupdtool reinstall * fu-tool: add reinstall command * fu-engine: export fu_engine_get_releases_for_device in header * vli: Wait for the VL103 to timeout to fix detach * ccgx: Show the UpdateMessage in the correct device mode * ccgx: Add extra instance IDs to match specific firmware * Use a static version number * thunderbolt: Rather than hardcoding to PCI slot numbers, use domain in GUID * Revert "thunderbolt: Create a unique GUID including Thunderbolt controller path" * dell-dock: Port to fu_device_retry() * nitrokey: Convert to use FuHidDevice * nitrokey: Port to fu_device_retry() * vli: Port to fu_device_retry() * Add fu_device_retry() helper functionality * ccgx: Implement writing firmware to flash * ccgx: Add i2c status check when reading or writing registers * ccgx: Add 5ms delay between read registers to avoid an i2c error * libfwupdplugin: Use fu_device_locker_close() * synaptics-mst: Use fu_device_locker_close() * Add fu_device_locker_close() * ccgx: Do not store the silicon ID in the image address * ccgx: Add device quirks for the Lenovo Hybrid Dock * ccgx: Switch HID mode to HPI mode at startup * ccgx: Clear the event queue when in startup * ccgx: Wait for hardware to settle when coming out of reset * ccgx: Do not mark the device as updatable when in boot mode * ccgx: Verify the firmware app type when preparing firmware * ccgx: Set the update message when running in backup firmware * ccgx: Read the FwAppType from the hardware * ccgx: Set the HPI version number for the current firmware * ccgx: Get the silicon ID to map the flash parameters * ccgx: Read the HPI device mode at startup * ccgx: Set up the HPI I²C config at startup * ccgx: Create devices when in HID and I2C modes * Add a new ChromeOS CI target to build without GPG and PKCS7 * Use Jcat files in firmware archives and for metadata - Removed fu-keyring-gpg which caused CVE-2020-10759 (boo#1172643) * csr: Allow truncated HID reads * vli: Only consider the high nibble when building the sub-version * csr: Parse the firmware as a DFU file * Add support for EP963x hardware * Add FuHidDevice abstraction * vli: Correctly attach VL103 after a firmware update * ccgx: Parse the metadata block in the firmware image * ccgx: Add a firmare parser for cyacd files * logitech: Correctly set the protocol * Add the optional device-id to the update --help output * Fix a difficult-to-trigger daemon hang when replugging devices * vli: Remove a dock device from the whitelist that is never going to be updated * vli: Add some trivial debugging to help track down a bug * vli: Never add USB hub devices that are not upgradable * uefi: Don't use shim for non-secure boot configurations * Start fwupd-activate.service after snapd.service * dfu: Actually reload the DFU device after upgrade has completed * dfu: Add one more m-stack device requiring a quirk * Apply version format to releases and devices at same time * Ensure that the DeviceID is set for child devices * Fix a daemon crash when removing children * Allow waiting for the parent device when replugging * Add fu_device_get_root() shared API * vli: Fix an error when detaching MSP430 * vli: Fix a critical warning when getting the USB speed * vli: Fix the error enum values for the MSP430 * Do not add blank lines when tokenizing Intel hex files * vli: Fix the version calculation for MSP430 * vli: Ignore one more error when attaching * vli: Always expect the VL103 header at 0x1003 or 0x4000 * vli: Do not fall back to the recovery write for usbhubs * vli: Only show the 2nd header if the device ID is valid * vli: Fix VL103 reboot from ROM mode to FW mode * vli: Add some better comments for writing GPIOs * Add a helper script to add a DFU header * Add 'firmware-convert' subcommand to fwupdtool * fu-engine: Make two passes of requirements checking * fu-engine: Copy the VersionFormat from the CAB if specified in `get-details` * Add a new plugin for CPU microcode * Don't build/install fwupdagent man page if agent build is not requested * Introduce a new VersionFormat for `hex` * Drop UEFI quirks we now inherit from metadata * ci: build Debian using libflashrom * When TPM PCR0 measurements fail, query if secure boot is available and enabled * fix fwupd.shutdown.in according to the movement of fwupdtool to bindir * ata: Add OUI quirk for Western Digital and Intel * improved fish shell completion * vli: Set the MSP430 version format to pair * Always return AppStream markup for remote agreements * ata: Add trivial OUI quirk for Micron * added completion script for fish shell * Do not fail loading in /etc/machine-id is not available * Use xb_builder_source_add_simple_adapter * Create FuCabinet and untangle a lot of legacy code * nvme: Do not try to handle integer version numbers * Allow server metadata to set the version format on some devices * fu-tool: Correctly append the release to devices in `get-details` * For the `get-details` command make sure to always show devices * fu-engine: Copy the version and format from donor device in get-details * fu-engine: Use unknown for version format by default on get-details * Inihbit all power management actions using logind when updating * Decouple the version format from the version itself * Add raw versions for bootloader and lowest * Allow server metadata to set the device name on some devices * Remove support for GCab less than v1.0 * fu-device-list: Check protocol before de-duping devices * Do not allow devices that have no vendor ID to be UPDATABLE * ata: Include a vendor ID for ATA hardware * ata: Switch off the verbose logging by default * Always check for PLAIN when doing vercmp() operations * Discard the reason upgrades aren't available (Fixes: #1678) * Improve the description of `fwupdtpmevlog` for man page * Move `fwupdtpmevlog` into `bindir` * uefi: Move `fwupdate` into `bindir` * Move `fwupdtool` and `fwupdagent` into `bindir` * Use the system provided flashrom on Fedora * Add a plugin vfunc to run after subclassed FuDevice creation * ci: use standalone script to generate build dependencies * Move the daemons from /usr/lib/fwupd to /usr/libexec/fwupd * Use the recently released flashrom v1.2 * Generate an additional UEFI quirk file using the stable LVFS metadata * uefi: Apply capsule update even with single valid capsule * Fix a critical warning when installing some firmware * ebitdo: Fix the endpoint address logged in the error message * uefi: Find the correct lds and crt name when specifying -Defi_ldsdir * upower: Move battery threshold declaration into a configuration file * upower: Decrease minimum battery requirement to 10% - Refresh fwupd-bsc1130056-change-shim-path.patch - Add new dependency: jcat- Update to version 1.3.9: * Release fwupd 1.3.9 * Always check for PLAIN when doing vercmp() operations * improved fish shell completion * vli: Set the MSP430 version format to pair * added completion script for fish shell * Always return AppStream markup for remote agreements * Do not fail loading in /etc/machine-id is not available * fu-engine: Fixup broken-ness from 0c0fada18fc9cb2a0efec351db67f0867bf045cd * Use xb_builder_source_add_simple_adapter * fu-tool: Correctly append the release to devices in `get-details` * For the `get-details` command make sure to always show devices * fu-engine: Copy the version and format from donor device in get-details * fu-engine: Use unknown for version format by default on get-details * Inihbit all power management actions using logind when updating * fu-device-list: Check protocol before de-duping devices * ata: Switch off the verbose logging by default * Discard the reason upgrades aren't available (Fixes: #1678) * Improve the description of `fwupdtpmevlog` for man page * Move `fwupdtpmevlog` into `bindir` * uefi: Move `fwupdate` into `bindir` * Move `fwupdtool` and `fwupdagent` into `bindir` * ci: use standalone script to generate build dependencies * Move the daemons from /usr/lib/fwupd to /usr/libexec/fwupd * Use the recently released flashrom v1.2 * uefi: Apply capsule update even with single valid capsule * Fix a critical warning when installing some firmware * ebitdo: Fix the endpoint address logged in the error message * fu-util: fix a logic error in report uploading introduced in e076d48afb74d1447936d353f12781755f13b047 * uefi: Find the correct lds and crt name when specifying -Defi_ldsdir * upower: Move battery threshold declaration into a configuration file * upower: Decrease minimum battery requirement to 10% - Update to version 1.3.8: * Release fwupd 1.3.8 * Do not use fu_common_vercmp() when the device verfmt is PLAIN * altos: Output raw buffer data when using FWUPD_ALTOS_VERBOSE * altos: Prefix an error to provide more context * altos: Add a trivial _to_string() implementation * synaptics-cxaudio: Make the verfmt match that of the existing Windows tools * synaptics-mst: Allow MST to fall back if no PCI device is marked as parent * Allow specifying a list of subsystems when setting a physical ID * synaptics-mst: Fix trivial thinko caused by the wrong dock connected * vli: Invert the logic to reboot the parent FuCliUsbhubDevice, not the child * vli: Switch around the hub tier values * uefi: Fix a build regression with Fedora 30 * logitech_hidpp: Ignore detach failures (Fixes: #1183) * logitech_hidpp: When detaching to bootloader use non-blocking IO and wait for timeout * vli: Show erase progress when doing a v2 recovery * uefi: Do not remove the 'Linux Firmware Updater' boot entry before update * uefi: Do not rewrite BootOrder in the EFI helper * vli: Add support for the PS186 device * Set up more parent devices for various Lenovo USB hubs * cxaudio: Set the update protocol to prevent a daemon warning * vli: Add support for Lenovo Modularized dock * Add an extra instance ID to disambiguate USB hubs * vli: Remove the unused tierX custom flags for each device * Revert "Correctly delete UEFI variables" * uefi: make debugging output more readable * vli: Fix a potential buffer-overflow when parsing firmware * tpm: Optimize the string parsing and fix the boolean logic * synaptics-rmi: Add a missing error enum value * synaptics-rmi: Correctly identify a checksum failure * synaptics-rmi: Fix Coverity issue that is impossible to hit in reality * solokeys: Parse old versions of the bootloader string * Add a plugin to update PD controllers by Fresco Logic * vli: Set the device progress correctly when erasing a PD device * vli: Use the correct command to get the device firmware version * vli: Correctly reset all VL100 devices * vli: Set all standalone PD devices to not do SPI auto-detection * vli: Mark standalone PD devices as updatable * vli: Set the protocol for FuVliUsbhubPdDevice types * Support the new gnuefi file locations * Cleanup ancient fwupdate-* EFI variables too (Fixes: #1739) * Detect kernel lockdown status * vli: Add the DEV instance ID to all devices * tpm-eventlog: Replay the TPM event log to get the PCRx values * tpm-eventlog: Store the eventlog hashes in binary form - Update to version 1.3.7: * Release fwupd 1.3.7 * Correctly delete UEFI variables * ci: allow working with podman w/o aliases * ci: fedora: force correct rpm package version * src: fu-engine: check version was updated by checking version * Correctly import PKCS-7 remote metadata * Add 'refresh' to fwupdtool * Add 'get-remotes' to fwupdtool * Generate a win32 setup binary * Fix display of UTF-8 characters on Windows * Move MOTD population into the daemon * fu-util: Discourage metadata refreshes more than once per day * Disable the battery percentage checks if UPower is unavailable * Allow getting the list of updates in JSON format from fwupdagent * Revert "trivial: Attempt to fix Debian CI" * fu-remote-list: emit a changed signal when modifying a remote * synaptics-mst: Skip self tests for systems with amdgpu * Allow applying all releases to get to a target version * Split up fu_engine_install() into two halves * logitech_hidpp: use the correct timeout for IO channel writes * Allow quirking devices that always require a version check * Shut down automatically when there is system memory pressure * Show the device parent if there is an interesting child * Allow the client to get the list of FwupdDevice children * Set the FwupdDevice parents in fwupdtool * Don't always get the vendor ID for udev devices using the parent * Add a runtime warning when adding a device without an vendor-id or protocol set * vli: Set more of the firmware max sizes automatically * vli: Add a SpiAutoDetect quirk for some of the PD devices * vli: Use a different protocol ID for i2c devices * vli: Add support for standalone Single PD devices * vli: Move generic SPI functionality into the FuVliDevice base class * vli: Remove the PD emulation code * vli: Use a more standard GUID for the child i²c and shared SPI devices * vli: Allow setting the device kind from a quirk * vli: Make more function names match the docs * vli: Move the SPI command quirking from FuVliUsbhubDevice down to FuVliDevice * vli: Rename FuVliUsbhubPdFirmware to FuVliPdFirmware * vli: Allow the device to specify the PD firmware header offset * vli: Add a FuVliDevice as a subclass to FuVliUsbhubDevice * vli: Define the device GType in the quirk file * vli: Move the CRC calculations out of usbhub scope * vli: Have one 'DeviceKind' for all objects * vli: Rename the `vli_usbhub` plugin to `vli` * Capitalize GNOME - package has grown a few new binaries: fwupdagent, fwupdate, fwupdtool and a tpm event debugging tool, that is packaged separately: fwupdtpmevlog- Drop docbook-utils-minimal build dependency, manpages are generated with gtk-doc.- Update to version 1.3.6: * plugins/coreboot: Add missing fu_hash dependency * trivial: synaptics-cxaudio: Add Google type C <-> 3.5mm adapter * fu-engine: don't expose bootloader version errors to users * trivial: dell-dock: drop unused quirk keyx * trivial: rename synapticsmst to synaptics-mst * trivial: actually set vendor ID for synaptics * fu-remote-list: Drop fallback path behavior * libfwupdplugin: Make sure systemd created environment variables exist * trivial: fu-remotes-list: drop usage of `FU_SELF_TEST_REMOTES_DIR` * trivial: synaptics-rmi: hardcode Vendor string * trivial: Set vendor ID for Dell WD19 to USB:0x413C (Fixes: #1653) * trivial: Document the use of vendor-id in each plugin * superio: Use the baseboard vendor as the vendor ID * uefi: Use the BIOS vendor as the vendor ID * coreboot: Use the BIOS vendor as the vendor ID * flashrom: Use the BIOS vendor as the vendor ID * dell: Hardcode a plausible vendor ID * emmc: Set the correct vendor ID prefix * fu-util-common: correct the default prompt for reboot/shutdown (Fixes: #1617) * Split out the remote loading from FuConfig * vli-usbhub: Fix the quirk for the legacy VIA 813 chip * Clarify error messages when no upgrades available * trivial: Don't handle a vendor-id requirement error that cannot happen * Only check the vendor ID if the device has one set * fu-install-task: Enforce that device protocol matches metadata * Add a new plugin that can parse the TPM event log * Allow other plugins to contribute report metadata * trivial: dell: hardcode the physical device ID for tpm to match the tpm plugin * Add a new plugin that exposes the system TPM device firmware version * Add fu_udev_device_set_flags() * trivial: Render large values of VersionRaw in a more portable way * trivial: wacom-raw: mark all Moffett SKUs as self recovery * Throw exit status 0 (instead of 2) if there is no firmware to be updated * Add a `dell-bios` version format * Add support for multiple LVFS::VersionFormat tags * Do not do semver conversion in fu_common_vercmp() * trivial: Deprecate fu_common_version_parse() * trivial: Support 'plain' in fu_common_version_from_uintXX() * Add the sysfs 'description' as the one-line device summary * trivial: Also print the parent keys when using FU_UDEV_DEVICE_DEBUG * trivial: Add fu_common_version_from_uint64() * trivial: Convert the VersionRaw value to a uint64_t for future use * Allow building on Windows with MinGW * synaptics-prometheus: Allow incremental version major and minor number * Replace 'scheduing' with 'scheduling' * Export the raw device version to the client --verbose output * trivial: Only dlopen the test plugin once * Export the device protocol to the client --verbose output * trivial: installed-tests: try to display journal for failed tests * trivial: ci: debian: enable verbose daemon logging for failure analysis * trivial: installed-tests: explicitly choose webcam device ID * trivial: debian: remove obj-* built files to fix back to back builds * trivial: ci: don't let bad symlinks cause debian build failures * trivial: debian: correct a dependency for libfwupdplugin-dev - Changes from version 1.3.5: * plugins: Fix potential use of NULL pointer in fu_dell_dock_mst_write_register * Fix shifting integer by more than 31 in fu_util_filter_device * synaptics-prometheus: Reload the device version after IOTA update * synaptics-prometheus: Reload the device version after update * trivial: wacom: remove coretronic config from Moffett scope * trivial: Fix a NULL/FALSE confusion * trivial: Add a BR for Fedora * trivial: Fix coreboot commit to fix CI * trivial: libfwupdplugin: clarify name of self test * plugins/coreboot: Improve version detection * plugins/coreboot: Get rid of FU_HWIDS_KEY_BIOS_VENDOR in coldplug * trivial: Move progressbar out of libfwupdplugin * trivial: Unexport fu_test_get_filename() * trivial: Unexport fu_test_compare_lines() * trivial: Unexport fu_test_loop_run_with_timeout() * trivial: Do not include non-introspectable functions in the GIR * trivial: Fix up a few introspection problems in FwupdPlugin * trivial: Include the Fwupd GIR in the FwupdPLugin GIR * trivial: Never add duplicate symbols to the map file * trivial: Properly namespace the defines in the exported header * Install development files for libfwupdplugin * Convert libfwupdprivate to a shared library libfwupdplugin * trivial: Allow building GCab from a subpackage * trivial: Fix under-include to define O_RDONLY * trivial: Allow compiling without * trivial: Do not use FuProgressbar in dfu-tool * synaptics-prometheus: Manually set the bootloader mode when attaching * trivial: Split out a new helper funtion * trivial: Add some optional debugging when hotplugging devices * trivial: Include the correct header for S_IRWXU * Always use the more portable 3-arg form for open() * trivial: Untangle FuHistory from FuPlugin * trivial: Allow compiling without * Revert "synaptics-rmi: Use the build ID as the version number to match the vendor tool" * Add missing documentation from the plugin interface * trivial: fu-udev-device: remove a prototype that was missed in b3d4d2ff * trivial: add missing gtk-doc fields for many files in src/ * trivial: fix compile failure without gudev * synaptics-prometheus: Mirror the _IS_BOOTLOADER from device to config * Allow setting the device flags using GObject properties * vli_usbhub: Set the composite parent at construction time * synaptics-prometheus: Set the composite parent at construction time * Allow plugins to set the parent during construction * vli-usbhub: Whitelist the PD and I²C devices * Set the protocol per-device not per-plugin * synaptics-rmi: Use the build ID as the version number to match the vendor tool * Create a REV_00 instance ID as this may be what the vendor needs to target * fu-util-common: Invert default behavior for reboot and shutdown prompts * trivial: fu-plugin-vfuncs: Add GTK documentation for all vfuncs * Make gudev a compile-time option * trivial: Set the offline trigger using an environment variable * trivial: ci: pull lintian from unstable for now. * trivial: stop including fu-hash.h as part of fu-plugin-vfuncs.h * Fix shebangs on scripts * trivial: Use prefixes for DATADIR in config.h for portability * Allow compiling GUsb as a subproject * trivial: fu-udev-device: add a to_string func for debugging * trivial: Don't assume that plugins end in .so * trivial: optionrom: remove unneeded includes * trivial: debian: ci: ignore library-not-linked-against-libc for more * trivial: remove version-format.md * trivial: Allow compiling without pwrite() * trivial: Allow compiling without * trivial: Allow compiling without realpath() * trivial: Allow compiling without HAVE_LC_MESSAGES * trivial: Allow compiling without getuid() * trivial: Allow compiling without * trivial: Allow compiling without * trivial: Allow compiling without * Ensure the _get_type() gets the same ABI version as the constructor * Use the correct unlocker when using GRWLock * trivial: plugins: only build coreboot when option set * fwupdtool: don't show a warning when calling `get-plugins` - Changes from version 1.3.4: * trivial: Don't force specific linker flash when cross building * dell: Use the more portable g_usleep() * trivial: Fix unused header includes * vli-usbhub: Make erasing less verbose and writing more obvious * vli-usbhub: Correctly print the 24-bit USB3 offset * vli-usbhub: Print the PD firmware offset and size for debugging * vli-usbhub: Open the parent device before attempting to read or write from the child * vli-usbhub: Set the install duration for the PD device * trivial: Fix a failed error prefix string * trivial: wacom-raw: Remove embedded from device name * wacom-raw: Correct HWID support * uefi: Just use a uint16_t for BootNext processing * uefi: Use a simpler entries set algorithm * vli-usbhub: Add support for writing using I2C passthru * vli-usbhub: Support updating PD devices that share the hub flash * vli-usbhub: Support the PD file format * trivial: uefi: correct a NULL pointer dereference * uefi: fall back to `ID_LIKE` when the path for `ID` doesn't exist (Fixes:# 1566) * uefi: Make generate_binary.sh more robust * Tokenize the Intel Hex file before parsing * trivial: Detect the USB version automatically * trivial: fu-util/fu-tool: explicitly block unsupported flags * Add support for matching requirements on device parents * Skip cleanup after device is done updating if `will-disappear` is set (Fixes: #1529) * efi: use a wildcard section copy for final EFI generation * modem-manager: explicitly use plain version format * modem-manager: add quirks for the Foxconn T77W968 modules * Allows confined snaps to activate fwupd via D-Bus * trivial: thunderbolt: clarify error message * Add a new property `Interactive` to the daemon * trivial: contrib/get-version.py: require git less hard * superio: Never read from port offset zero * superio: Fix regression when coldplugging superio devices * trivial: Fix Fedora CI build * trivial: Fix the autobuilt spec file with the new tarball version * Dynamically determine release version * trivial: synapticmst: allow missing `/proc/modules` * synapticsmst: filter invalid chip IDs * trivial: Provide some defines for common image names * Allow aborting early when using fu_archive_iterate() * Add fu_firmware_image_set_version() for future use * modem-manager: increase re-enumeration delay to 20000ms * modem-manager: add counterpart GUID for the DW5821e/eSIM * Add versions formats for the Microsoft Surface devices * usb: make loading vendor/product/serial strings non-fatal * trivial: Fix the protocol ID for VLI usbhub devices * trivial: wacom-raw: add more device IDs for Dell devices * trivial: contrib: don't require TSS for debian archs without EFI * fu-udev-device: Adjust bounds checking to be safer * fu-udev-device: Don't assume all devices have `device_file` * synaptics-rmi: correct an error cleaning up on probe * trivial: fu-udev-device: add some safety checks for fd * udev-device: fix offset of vendor id of hidraw devices * flashrom: switch to upstream source * trivial: fu-plugin: only show an error once "failed to open plugin" was being prefixed twice * trivial: debian: only use mingw-w64-tools in archs with UEFI plugin * fastboot: Fix a regression when updating modem firmware * trivial: conflict with old unifying plugin * Rename unifying plugin to logitech-hidpp (Fixes: #1329) * Add a new contrib script for installing a Dell BIOS from an EXE file * trivial: add-capsule-header: rename to make it easier to import * trivial: simple_client: make it easier to reuse code * trivial: firmware-packager: make it easier to reuse code * trivial: add-capsule-header: make it actually work * trivial: fix some gtkdoc sections * Bump the required gudev version * trivial: Fix a compile error with older versions of gudev * trivial: wacom: add vid/pid for panels in Moffett * trivial: post release version bump - Changes from version 1.3.3 * unifying: notify users to replug when using dfu control (Fixes: #1383) * trivial: 8bitdo: set a transient failure while waiting for user action * libfwupd: Add a new error type for user action needed * trivial: 8bitdo: show the same message for SN30pro and SN30pro+ * trivial: Fix up some typos from codespell * trivial: Ensure config.h is included in all source files * trivial: Fix up some NULL/FALSE confusion * trivial: Add all the _LAST enums that shouldn't be checked for ABI * trivial: Fix a typo that means that UEFI results were never cleared * Always report the update-error correctly for multiple updates * trivial: Fix fwupdmgr get-history if the firmware was not installed from the LVFS * trivial: Do not emit a warning if a child has no version number * Move the file descriptor lifecycle into FuUdevDevice * trivial: Fix some GtkDoc annotations * ebitdo: Modernize the plugin to use FuFirmware * nitrokey: Use fu_common_dump_raw() when debugging * thunderbolt: Create a unique GUID including Thunderbolt controller path * Use device safety flags to show prompts before installing updates * trivial: Use the new possible_plugin support for USB devices too * jabra: Move the Jabra-specific detach out into its own plugin * Ensure the device is open when doing the subclassed prepare() and cleanup() * vli-usbhub: Add support for updating V2 devices * Allow verifying the device image itself from fwupdtool * Use XMLb to query quirks * trivial: ci: disable pulling libxmlb from unstable * synaptics-prometheus: Don't add a config-subdevice in bootloader mode * dfu: Use the VID/PID to identify devices without download capability in runtime * trivial: debian: remove some unneeded lintian * trivial: debian: bump compat version * ebitdo: Add SN30Pro+ to recognized quirk list (Fixes: #1503) * dfu: Add several quirks for Realtek camera hardware * dfu: Always mark devices as UPDATABLE * uefi: use `genpeimg` to mark ASLR and DP/NX on EFI binary * trivial: solokey: correct a typo * trivial: fu-util: fix typo * uefi: rework ESP path detection and lifecycle * trivial: uefi: show more metadata in to_string method * trivial: fu-device: add new method to remove metadata * Add a plugin to update VIA USB hub hardware * trivial: Add fu_common_read_uint8_safe() * trivial: Fix two typos in fu_common_read_uint16_safe() * solokey: Allow parsing firmware with fwupdtool * Allow fwupdtool to dump details of common firmware formats * trivial: Do not do system coldplug when using FU_ENGINE_LOAD_FLAG_NO_ENUMERATE * trivial: fu-self-test: set polling self tests to slow * trivial: fu-tool: Allow `detach`/`attach` to prompt for device * Strip trailing whitespace from USB descriptors * trivial: Add fu_common_read_uint16_safe() * trivial: Add version to the FuFirmware->to_string() output * Add fu_firmware_set_version() * Add a systemd preset file for `fwupd-refresh.service` * trivial: dell: work around a memory leak caught by address sanitizer * ebitdo: if the device has the will disappear flag, don't wait for ack (Fixes: #994) * Add a new plugin for working with eMMC devices (Fixes: #1455) * fu-engine: Check multiple plugins if quirks match * trivial: don't try to enable LVFS from systemd * trivial: coreboot: fix a clang compiler error * fu-util: Add user friendly strings for all device flags * Add new device flags indicating update resilience * plugins: Add coreboot plugin * fu-plugin: Add fu_plugin_get_hwid_replace_value * trivial: Increase verbosity when actually updating devices * trivial: Allow plugins to use WAIT_FOR_REPLUG in prepare and cleanup * Add FuDevice->prepare() and FuDevice->cleanup() vfuncs for future use * dfu: Implement FuDevice->to_string() * trivial: colorhug: fix a crash that occurs when flashing sometimes * trivial: fu-util: break out of automatic reports if one is not automatic * thunderbolt: some more clarifications when using ICL * trivial: fwupd-refresh: activate motd if using systemd v243 or later * trivial: fwupd-refresh: allow exit code 2 for success * trivial: synaptics-cxaudio: Add Google Pixel buds * trivial: arch: ci: Wait some time for tpm_server to start up * Allow a custom FuFirmwareImage->write() in superclassed objects * dfu: Remove two completely unused helpers * dfu: Make DfuFirmware derive from FuFirmware * dfu: Make DfuImage derive from FuFirmwareImage * dfu: Remove private headers that do not need to exist * Fix device flag filtering * trivial: fu-engine: Don't compare device and content checksums * fu-engine: Read all releases and convert versions when comparing * Add new flags `can-verify` and `can-verify-image` * trivial: make verify and verify-update safer * trivial: test: add checksums for "stock" 1.2.2 * trivial: fu-udev-device: use parent udev device to indicate `internal` * trivial: fix TPM2 simulator tests for arch * trivial: uefi: don't add PCRs with all 0's * trivial: Fix a recent regression causing a double-free * synaptics-cxaudio: Support the ThinkPad USB-C Dock Gen2 * trivial: fu-util: add some extra checks around automatic reports * trivial: fu-tool: typo * fu-systemd: Use correct method for stopping units. * trivial: fu-udev-device: Use ID_PCI_CLASS_FROM_DATABASE if name not set * trivial: fu-plugin: quiet down debug output for optionrom plugin * 8bitdo: use will-disappear flag for sf30/sn30 controllers (Fixes: #783) * trivial: ebitdo: don't dump out firmware header unless plugin verbose * trivial: ebitdo: don't use local errors when writing firmware * Add a new device flag for indicating device won't come back * wacom-emr: Fix a regression for EMR devices * Add a generic DFU firmware object for plugins to use * dfu: Use FwupdInstallFlags rather than a DFU-specific version * dfu: Remove functionality for modifying DfuSe files * dfu: Remove functionality you can do now with fwupdtool * dfu: Remove the merge command as it's unused and broken * trivial: Add fu_firmware_parse_file() helper for future use * trivial: Remove the fuzzing details for DfuPatch * trivial: Add klass->to_string for superclassed FuFirmwareImage objects * dfu: Remove DfuPatch as no vendor actually uses this * dfu: Don't wrap provided VID-PID functions * dfu: Use the standard FuDevice custom flags functionality * dfu: Use klass_device->write_firmware() directly * dfu: Use the generic fu_plugin_usb_device_added() function * dfu: Use daemon flags to ignore devices rather than a special flag * dfu: Set the device state directly to avoid proxying signals * dfu: Use the built-in detach() and attach() vfuncs * Read firmware back from the device as a FuFirmware * dfu: Remove a pointless function * dfu: Remove support for the Metadata Store Proposal * dfu: Remove XTEA support * dfu: Remove the SREC and IHEX parsing out of the DFU plugin * ebitdo: Use klass_device->write_firmware like other plugins * trivial: Remove G_BEGIN_DECLS from all private headers * Remove FU_PLUGIN_RULE_REQUIRES_QUIRK as all the plugins now use it * Set all FuUdevDevice plugins to use FU_QUIRKS_PLUGIN * thunderbolt: recognize new 'generation' sysfs attribute * Rename and modernize the udev plugin * synaptics-rmi: Also add the product ID as a GUID without the minor version * synaptics-rmi: Correctly set the payload length rather than hardcoding it * synaptics-rmi: Write the core config correctly * synaptics-rmi: Decode BL7 status failures as actual errors * synaptics-rmi: Add some trivial debugging to help debug a write problem * trivial: uefi: Make efivarvs errors clearer (Fixes: 1330) * trivial: uefi: don't prefix efivar errors * trivial: Remove some now-unused vfuncs * altos: Modernize the plugin to simplify it * Create the custom plugin GType in common code * Reduce more boilerplate in plugins * synaptics-rmi: Check the correct register when querying bootloader mode * trivial: fu-engine: fix never reporting remotes * trivial: fu-util: don't show warnings for no reports to upload * trivial: debian: remove more conffiles from transitions (Closes: #932617) * trivial: debian/control*: Update for fwupdate transition * trivial: Fix a tiny memory leak when starting the daemon * modem-manager: Fix a tiny memory leak when starting the daemon * synaptics-rmi: Copy the behavior of rmi4utils for BL7 detach * synaptics-rmi: Simplify fu_synaptics_rmi_device_read() * synaptics-rmi: Set the version after ->setup has run * synaptics-rmi: Use the correct mask when getting the bootloader mode on BL7 * syanptics-rmi: The build_id is 3 bytes long, not 2 * synaptics-rmi: Read the config partition the same as rmi4utils * Provide a default implementation of common FuDevice actions * thunderbolt-power: avoid checking for bolt support * synaptics-rmi: Add some debugging for BL7 devices * Fix usage of incorrect type for return value * synaptics-rmi: Do as little as possible in device setup * synaptics-rmi: Speed up reading the PDT from 900ms to 30ms * fu-util: add support for a reinstall command * trivial: fu-util/fu-tool: update re-install help text to reinstall * trivial: fu-util: remove double printed message about succesful firmware update * trivial: fu-util: show no updatable devices error for update command * synaptics-rmi: Ignore the ATTN reports from the hardware when reading DATA * synaptics-rmi: Move the fuzzing instructions to the toplevel README * Fuzz the SREC and IHEX file parsers once more * Use parallel fuzzing for the SMBIOS checks too * synaptics-rmi: Fix the packing of the partition table * Add a plugin to update Synaptics RMI4 devices * trivial: Add a parallel fuzzing script * trivial: fu-util: output newline after prompt. * trivial: fix %u output in report upload * Add a --no-domain logging option * trivial: Fix compiler warning for impossible-to-hit condition * Add support for automatically uploading reports * trivial: motd: disable updating motd for now * trivial: fwupd-refresh: fix a clash with fwupd.service (Closes: #941360) * trivial: Fix Fedora CI * trivial: fu-udev-device: fix some assertions * Search up the tree for a vendor name rather than (ab)using the HID_NAME * Add some success messages when CLI tasks have completed * trivial: Put the boolean prompt on the same line as the text * Never show LicenseRef-proprietary to the end user * trivial: snap: correct install hook root directory * Export the instructions for detaching the device * uefi: detect unmounted ESP partitions (Fixes: #1405) * uefi: stop recording efibootmgr output after flash * trivial: post release version bump - Changes from version 1.3.2: * Add support for '' to disambiguate some firmware * thelio-io: Add a plugin to detach the Thelio IO board * trivial: uefi, dell: skip self tests with TPM if non-root (Fixes: #1396) * trivial: dell: quiet the TSS output * trivial: uefi: allow forcing to TPM2 via environment variable * Do not ask the user to upload a report if ReportURI is not set * Do not enumerate physical devices when running the internal self tests * trivial: libfwupd: skip tests if machine-id is empty too * Add a new plugin to update Conexant audio devices * Export the salted machine ID as a daemon property * Fall back to /var/lib/dbus/machine-id when required * trivial: add stalebot (Fixes: #1393) * trivial: dell-dock: correct another write_size error * Align the key values to the text *width* not the number of bytes * trivial: Move dbus directory location for snap too * trivial: Fix some NULL/FALSE confusion * synaptics-prometheus: Fix tiny memory leak when using FuSynapromConfig * trivial: Fix tiny memory leak when using FuSrecFirmware * snap: switch to core18 * trivial: Return the correct property when getting the host product * trivial: fu-util-common: fix description wrapping (Fixes: #1378) * fu-util/fu-tool: Map out changelogs from remotes * fu-util/fu-tool: Better display historical information * fu-history: Update device_modified in sql database during updates * unifying: Use the instance ID to check for supported devices * unifying: Ensure HID++ v2.0 peripheral devices get scanned by the plugin * trivial: Add some more defines to the srec parser * trivial: fix wget command in fu-tool.c * Allow parsing a raw SREC file * trivial: wacom: Add support for second vendor ID * uefi, dell-esrt: Show firmware version when capsule updates unavailable * Add some more debugging to the SREC and IHEX parsers * Print the instance IDs if the GUIDs are unconverted * Add fu_common_bytes_compare_raw() for future usage * Call the set_quirk_kv() vfunc for the superclassed object * uefi: make the TPM optional for runtime again (Fixes: #1362) * trivial: uefi: Make the TCTI output less verbose * Support in AppStream metadata * Include all GUIDs when uploading a report * Do not crash when starting tpm2-abrmd * trivial: Update DBus conf path for example Fedora package * Move D-Bus conf file to datadir/dbus-1/system.d * trivial: Add fu_io_channel_write_byte_array() for future use * trivial: post release version bump - Package new sub-packages typelib-1_0-FwupdPlugin-1_0 and libfwupdplugin1.- Fix file list- Update to version 1.3.1: (jsc#SLE-10751) * Allow disabling all plugins * trivial: Specify the tpm2-tss-devel version in the example spec file * Move to CI Fedora 30 * modem-manager: Fix two build warnings on Fedora 30 * synapticsmst: Add another name quirk for the ThinkPad USB-C Dock * Re-introduce GUID support to fwupdmgr and fwupdtool * uefi-recovery: Add a plugin to add a fake ESRT entry for device recovery * Add a DMI quirk for the Minnowboard Turbot * trivial: Make it easy to disable or enable libflashrom for distros * trivial: Don't use Recommends for RHEL 7 * unifying: fix timeout metadata * ci: arch: minor improvements * unifying: fix timeout * Allow disabling SSL strict mode for broken corporate proxies * trivial: Allow ignoring the daemon version check by using --force * Try to only show DMI product name once * trivial: fu-util-common: Show unknown devices as interesting devices * dell: Use TSS to query and build TPM vendor strings for GUIDs * trivial: dell: show reasons for lack of updates in `UpdateError` * fu-util-common: strip all trailing whitespace in XML description * trivial: fu-common: match all whitespace not just ' ' in `fu_common_strstrip` * fu-util: show release output in get-details again * unifying: use fu_firmware_strparse_uint16 to read be 16bit values * unifying: fix incomplete hex file parsing * fu-util/fu-tool: Print devices, remotes, releases using a tree * Add aliases for `get-upgrades` and `upgrade` * trivial: UEFI skip self tests if library fails to initialize * libfwupd: Add a new private function `fwupd_remote_set_remotes_dir` * trivial: add libtss2-dev into debian/control (Closes: #1324) * trivial: Fix up the GtkDoc Since lines for API only available in 1.3.x * trivial: Post branch version bump * thunderbolt: Add support for kernel safety checks (Fixes: #1312) * Include the kernel release as a runtime version * trivial: fu-util: Drop GUID support from get-devices * synapticsmst: Partially rewrite the plugin (Fixes #1105) * Remove replug flag after the device comes back from reboot * trivial: Fix running the tests on devices with the TPM in v1.2 mode * trivial: fu-util-common: more cleanup related to topology * trivial: fu-util: cleanup fwupdmgr get-details output * trivial: Don't use topology printing in --verbose mode * Make get-devices and get-topology aliases for one another * trivial: Adjust daemon device sorting * Make get-topology more useful by showing all information * trivial: Fix fu_common_string_append_kv() to align properly with idx > 0 * trivial: dell-dock: correct an error preventing write_size from being set * trivial: Do not warn about deprecated declarations * trivial: Update BRs for the example Fedora package * uefi: add test for TPM 2.0 PCR read function * uefi: use tpm2-tss library to read PCR values * fu-common: Use environment variables for systemd managed directories * Use more systemd directives for directories * trivial: fu-util: fix debug output for devices * Allow turning off the timestamp prefix for debugging * Add a ->udev_device_changed plugin vfunc * Add fu_device_rescan() and a FuDevice->rescan() vfunc * Remove the duplicate files in meson.build * Hash the source files when generating the daemon hash * Split up source files in the build script * uefi: add support for tpm2-tools 4.X * trivial: plugins: clarify stance on afuefi.efi * trivial: plugins/: Update README * trivial: disable gtkdoc by default * trivial: update references of hughsie/fwupd to fwupd/fwupd * Publish docs to fwupd.github.io using CircelCI * Add support to integrate into the motd (Fixes: #1270) * Simplify get-devices output to not show un-useful fields * fu-engine/fu-config: Reload metadata store when configuration changes * trivial: If no devices support updates, show messaging (Closes: #1295) * trivial: uefi: set vendor name for system firwmare from DMI data * unifying: update Solaar url * thunderbolt: Fix logic to work properly with ICL thunderbolt controller * Add fu_udev_device_get_device_file() helper * trivial: Fix regression when using fu_device_incorporate() * trivial: Fix a potential crash when using FuPlugin in the self tests * synapticsmst: Make FuSynapticsmstConnection an actual GObject * synapticsmst: Use the same style as other plugins * trivial: Add some helper functions for GByteArray * Do not use FuDevice metadata for the physical and logical IDs * Use fu_common_string_append_kv() in subclassed device * synapticsmst: Use G_DECLARE_FINAL_TYPE to simplify the object * synapticsmst: Add a SynapticsMSTBoardID for another Lenovo dock * trivial: remove unnecessary CUSTOMERID_DELL define * synapticsmst: Add a SynapticsMSTBoardID for a Lenovo dock * synapticsmst: Display the board ID in non-hex form in the error message * synapticsmst: Use a more suitable icon for the device * trivial: Remove unused variable * Never use memcpy() in a possibly unsafe way * Add a ->to_string() vfunc to FuFirmware * Use FuFirmware as a container for firmware images * Allow filtering devices when using the command line tools * Be more accepting when trying to recover a failed database migration * trivial: Add translation for X-ThunderboltController * trivial: fixup standalone installer * modem-manager: add counterpart GUID for the DW5821e * solokey: Release the interface and rebind the kernel driver on close * fu-tool: Port ability to update a single device from fwupdmgr * uefi: Actually write the new device path if different than before * Allow setting custom flags when using fwupdate * trivial: Do not show a critical warning if no firmware is specified * trivial: Fix overzealous search-replace action in user string * Verify we don't break the ABI * Fix a crash when stopping the fwupd service * Relax the certificate time checks in the self tests for the legacy certificate * trivial: add cache directory into systemd unit rw paths * Never show AppStream markup on the console * Do not segfault when trying to quit the downgrade selection * trivial: Update icons for Thunderbolt and MST devices * Add support for the SoloKey Secure * trivial: Allow a device to *clear* a firmware version * trivial: debian: For signed package fill out Built-Using (Closes: #932757) * Allow specifying GUID to check any version exists * trivial: post release version bump * Release fwupd 1.2.10 * Disable the flashrom plugin by default * trivial: thunderbolt: catch failure setting up device * dell-esrt: Improve the experience for the plugin (Closes: #1245) * fu-util: When unlocking prompt for reboot if applicable * remove those PIDs with Bluetooth interface, Wacom updater doesn't support updating from Bluetooth interface * flashrom: Only show DEBUG and DEBUG2 output if using --plugin-verbose=flashrom * flashrom: Only call flashrom_programmer_init() on whitelisted boards * flashrom: Fix no version format set * fu-util: Show devices with an UpdateError in get-devices output * trivial: uefi: use UEFI-dummy for device ID instead of just uefi * trivial: fix error handling for non UEFI case (#1220) * Add a specific error code for the low battery case * Fix Fedora docker build missing directory: dist * uefi: Determine whether running in legacy mode or not (Fixes: #1220) * trivial: ci: debian: Only turn on flashrom when running CI * trivial: Fix typos in error messages * Allow client code to construct objects from GVariant blobs * Export functionality to build an array of objects * flashrom: Use libflashrom * trivial: Fix the version script to pick up boxed types * trivial: Correctly order the map entries according to vercmp rules * trivial: Fix pylint issue in the version script * Add meson target to fix translations * Add support for 8bitdo USB Retro Receiver * Use the newer features of GRWLock rather than reinventing it * Revert "Allow SuperIO updates to be done live" * uefi: Try to find a duplicate using the loadopt name * uefi: Provide a quirk to disable the use of the UX capsule * trivial: uefi: use the path for efibootmgr that was detected * synaptics-prometheus: Fix installing CONFIG firmware updates * synaptics-prometheus: Set the install duration from a quirk * synaptics-prometheus: Don't emit critial warning when updating config firmware * synaptics-prometheus: Fix missing field in the IOTA reply struct * Create SECURITY.md * redfish: Never set NULL device name * modem-manager: Never set NULL device name * ata: Never set NULL device name * trivial: Add some parameter guards to FuDevice * trivial: snap: make polkit directories if they don't exist (Fixes: #1205) * trivial: fu-main: clarify missing PK file error * synapticsmst: fix GUID generation (Closes: #1207) * Lite Mk II flag for use-shim-unique * trivial: circleci: try to fix automatic snap deployment * Allow SuperIO updates to be done live * fu-util-common: Support empty proxy strings (Fixes: #1199) * trivial: uefi: clarify error message * trivial: Fix non-systemd build * trivial: Sync example spec file with downstream * trivial: post release version bump - Drop fwupd-bsc1143905-hash-the-source-files.patch: Applied upstream. - Add pkgconfig(tss2-esys) BuildRequires: New dependency. - Add gtk-doc BuildRequires and pass gtkdoc=true to meson, build api docs even when using source service.- Add fwupd-bsc1143905-hash-the-source-files.patch to hash the source files instead of libfwupdprivate.a to avoid the checksum change due to the random naming LTO profile sections (bsc#1143905)- Update to version 1.2.10: * Disable the flashrom plugin by default * dell-esrt: Improve the experience for the plugin (Closes: #1245) * fu-util: When unlocking prompt for reboot if applicable * remove those PIDs with Bluetooth interface, Wacom updater doesn't support updating from Bluetooth interface * flashrom: Only show DEBUG and DEBUG2 output if using - -plugin-verbose=flashrom * flashrom: Only call flashrom_programmer_init() on whitelisted boards * flashrom: Fix no version format set * fu-util: Show devices with an UpdateError in get-devices output * Add a specific error code for the low battery case * Fix Fedora docker build missing directory: dist * uefi: Determine whether running in legacy mode or not (Fixes: #1220) * Allow client code to construct objects from GVariant blobs * Export functionality to build an array of objects * flashrom: Use libflashrom * Add meson target to fix translations * Add support for 8bitdo USB Retro Receiver * Use the newer features of GRWLock rather than reinventing it * uefi: Try to find a duplicate using the loadopt name * uefi: Provide a quirk to disable the use of the UX capsule * synaptics-prometheus: Fix installing CONFIG firmware updates * synaptics-prometheus: Set the install duration from a quirk * synaptics-prometheus: Don't emit critial warning when updating config firmware * synaptics-prometheus: Fix missing field in the IOTA reply struct * Create SECURITY.md * redfish: Never set NULL device name * modem-manager: Never set NULL device name * ata: Never set NULL device name * synapticsmst: fix GUID generation (Closes: #1207) * Lite Mk II flag for use-shim-unique * fu-util-common: Support empty proxy strings (Fixes: #1199) - Add python3-setuptools to BuildRequires for generate-version-script.py- Update to version 1.2.9: * Release fwupd 1.2.9 * trivial: Add two new translatable strings for new category types * Check if the system is offline during install, rather than at startup * Prompt the user to shutdown if requried when installing by ID * Use the correct file extension for the offline updates cache * trivial: Allow using --force to use the wrong daemon version * trivial: Display the correct expected command * standalone-installer: Be smarter about existing installed fwupd * Add a plugin to update Synaptics Prometheus fingerprint readers * trivial: standalone-installer: rename uninstall argument to cleanup * fu-util: Check the daemon version is at least the client version * fu-util: Check that daemon is started by expected unit * fu-util-common: when stopping a daemon, check for snap too * Allow using --force to trigger a duplicate offline update * trivial: Allow using FuUsbDevice without a GUsbDevice * trivial: Copy the icons if unset for the device child * trivial: Copy the physical ID if unset for the device child * trivial: Ensure the parent ID is up to date if the device ID changes * trivial: Fix typo when setting the parent ID * trivial: Disable the flatpak CI build * Allow handling FORCE for devices that subclass FuDevice * uefi: Fix a libasan failure when reading a UEFI variable * trivial: Fix a memory leak found using libasan * trivial: Fix an libasan failure in the dell plugin * trivial: Fix some dead code spotted by coverity * trivial: Fix a typo spotted by coverity * trivial: Fix a missing config.h include in a new source file * Dynamically read path to use for /system-update * Display the remote warning on the console in an easy-to-read way * ata: Set version format to plain for devices obtained from udev * trivial: Only apply SmbiosManufacturer to release version for internal * trivial: Fix two bugs in the hardware self tests script * Never guess the version format from the version string * Only force a semver when the device opts-in * Export the version-format to clients * Add missing gtk-doc documentation * dfu: Add some trivial, but useful, debugging for AVR DFU devices * dfu: Correctly identify DFU firmware that starts at offset zero * dfu: Don't keep showing trivial debug output * dfu: Reset the forced version during attach and detach * ata/nvme: For devices running Dell firmware, set `VersionFormat` (Fixes: #1169) * fu-engine: Check if VersionFormat is ambiguous when adding devices * trivial: Fix fwupdate --apply * Only use class-based instance IDs for quirk matching * trivial: dell-dock: set minimum board to 6 * trivial: post release version bump- Update to version 1.2.8: * Don't upload reports when the user has configured their system in a broken way * Allow setting the daemon verbose domains at runtime * Allow fwupdmgr to modify the daemon config * Do not compare version formats when the release format is unknown * Do not fall back integers to a plain version format * Use the device version format when converting the release version * Set the VersionFormat using the metadata or the UEFI quirk - Changes from version 1.2.7: * l10n: Create Lithuanian translation file * l10n: Update LINGUAS * Updated: Add support for 8BitDo M30. * modem-manager: increase the timeout to wait for modem after uninhibited * modem-manager: implement qmi pdc active config selection as attach() * fu-engine: When removing activation flag match the correct version * Require --force to install a release with a different version format * Match the old or new version number when setting NEEDS_REBOOT * Make an error message clearer when there are no updates available * Add support for the not-child extension from Logitech * thunderbolt: Set require-ac for Thunderbolt devices (Fixes: gh#hughsie/fwupd#1142) * Fix some typos spotted using codespell * Add a component categories to express the firmware type * fu-tool: Port get-history command to fwupdtool * Recreate the history database if migration failed * Move the core built-in 'fwupd' remote over to the dell-esrt plugin * snap: Add a custom systemd unit to call activation on shutdown (Fixes: gh#hughsie/fwupd#1125) * ata: Flush cache before standby and activate * synapticsmst: blacklist plugin when using amdgpu (Fixes: gh#hughsie/fwupd#1121) * uefi: add a new option to specify the os name * Return the newest device when using fu_history_get_device_by_id() * uefi: More carefully check the output from tpm2_pcrlist * uefi: Don't overwrite CustomFlags if set from a quirk * Shut down the daemon if the on-disk binary is replaced * ata: Correct activation functionality * Fix version comparisons after reboot for some formats * fu-tool: save history from stuff installed with `fwupdtool` - Changes from version 1.2.6: * ata: send ATA standby immediate when activating firmware * offline: Be more graceful when dealing with Plymouth failures * Save the new version in the history database for offline updates * Show the DeviceID when showing the updates list * Allow forcing an offline-only update on a live system using --force * Do not schedule an update on battery power if it requires AC power * superio: Add InstallDuration default value * superio: Add support for writing new e-flash contents * superio: Fix reading the attestation checksum * superio: Add support for reading the device checksum * superio: Use the chipset ID in the device name * superio: Move the device flush before getting the register map * superio: Move all the IT89xx code to a subclassed device object * superio: Move all the IT85xx code to a subclassed device object * superio: Split and export fu_superio_device_ec_writeX() * superio: Remove the port from fu_superio_device_ec_read() * superio: Move the register read/write into the FuSuperioDevice object * superio: Check the IOBAD0 is usable during setup * superio: Use fu_device_set_firmware_size() * superio: Move some constants out to the common header * superio: Use GObject properties in FuSuperioDevice * superio: Convert FuSuperioDevice to be derivable * Update Plymouth when updating pending firmware * Ask to reboot after scheduling an offline firmware update * Do not fail when scheduling more than one update to be run offline * Allow running offline updates when in system-update.target * Fix the location of fwupdoffline in the service file * Add optional vfuncs to allow detaching and attaching verify() * superio: Add list of SPI commands for future usage * Add a verify-update command to fwupdtool * uefi: Actually upload the UPDATE_INFO entry for the UX capsule * superio: Get the chip size from the EC rather than hardcoding * uefi: Check the error code of QueryCapsuleCapabilities() correctly * Update the UEFI UX Capsule Header checksum when needed. * uefi: Copy the shimx64.efi binary for known broken firmware * Correctly get the check the new version for devices that replug * Add a simple script to add a capsule header * Ensure the PKCS-7 client certificate exists at startup * fix makecab directive options * fwpup.service: use display-manager.service instead of gdm.service * Allow signing the fwupd report with the client certificate * Add a D-Bus method to generate a signature using the self-signed client certificate * Allow signing and verifying data using a PKCS-7 self-signed client certificate * Fix a critical warning when loading a PKCS-7 certificate with no DN * Include all device checksums in the LVFS report * modem-manager: Fix a trivial build warning * superio: Fix a trivial build warning * Move out the offline update functionality to a new binary * Do not reboot when failing to start fwupd during offline updates * Do not write the schema version to the db when loading * Do not recreate XbSilo caches when running on a readonly filesystem * Add the fwupdagent binary for use in shell scripts * Allow restricting firmware updates for enterprise use * standalone-installer: new --allow-older and --allow-reinstall options * Show the upgrade and downgrade flags when getting releases for a device * Rename FwupdRelease:trust-flags to FwupdRelease:flags * fu-tool: Save device state to @LOCALSTATEDIR@/lib/fwupd/state.json on actions * modem-manager: implement support for qmi-pdc * Add a plugin to support ModemManager hardware * fu-tool: Don't let failing to find dbus prevent engine from starting * ata: Support delayed activation * dell-dock: Use activation when calling fwupdtool activate * Add a support for delayed activation * uefi: Fix the self tests when running on Fedora SilverBlue * Do not fail to start the daemon if tpm2_pcrlist hangs * po/make-images.sh: quote LOCALEDIR and PYTHON3 * meson: print stderr of python3 command instead of stdout * Revert "contrib/debian: Switch to debian unstable" * Add elogind support - Changes from version 1.2.5: * uefi: fix segfault in fwup_set_update_statuses * Show in Flathub correctly * debian: explicitly depend on shared-mime-info * superio: Implement detach() and attach() * superio: Correct the names of some constants and improve debugging support * dell-dock: Filter the last supported payloads of certain board 4 SKUs * circleci: Manage the lifecycle of the snap * Add support to run snap build in CircleCI * wacom-usb: Use the correct buffer format for the touch module * wacom-usb: Set the install duration for each device type * wacom-usb: Return with an error if there were too many retries * wacom-usb: Make updating less verbose * Convert all child instance IDs when converting the parent * uefi: Allow devices to create more complete fake UEFI devices * unifying: Fix regression when recovering from failed flash * Ensure libxmlb dir exists for LGTM.com * Add C build configuration for LGTM.com * Use G_BEGIN_DECLS correctly for internal headers * standalone-installer: Fix issue found by LGTM * Use '#pragma once' to avoid a lot of boilerplate * Force LGTM to see Python 3 * fwupd: Hide firmware-packager behind meson option` * fu-common-cab: Correct handling of CAB files w/ nested directories and older libgcab * Fix a regression in using the InstanceIDs for quirk matching * thunderbolt: Convert the instance IDs as we never open the device * udev: Manally call fu_device_setup() to convert the instance IDs * fu-tool: Correct a crash caused by calling fwupdtool update * fu-tool: Don't fail if dbus is unavailable * contrib/debian: Switch to debian unstable * wacom-usb: Record the block number when failing * wacom-usb: The touch address is big endian * wacom-usb: Accept a non-binary IHEX file for the touch update * wacom-usb: Only poll when the device status is 'busy' * wacom-usb: Only reboot the device when all composite devices have been updated * wacom-usb: Fix flashing failure with latest Intuos Pro tablet * dfu: Fill holes when reading SREC files * Add fwupd_guid_from_string() to drop dep on uuid * wacom-raw: Check the InstanceID rather than GUID * Defer the InstanceID->GUID hashing until after setup * ata: Check for USB enclosures as well * Do not use efivar just to print a mixed endian GUID * Add fu_device_add_instance_id() and prefer explicit conversion * Report the DeviceInstanceIDs to `fwupdmgr get-updates` * Export some of the GUID functionality * Allow a plugin to set _ANOTHER_WRITE_REQUIRED to run more than one plugin * nvme: Add an extra check for Dell plugins to avoid false positives * ata: Add support for detecting Dell GUIDs * Fix the self tests when using glib2 >=2.59.0 * Add support to call composite prepare and cleanup using fwupdtool * uefi: Disable -Wno-address-of-packed-member * uefi: Don't unconditionally enable Werror for the EFI binary * Disable -Wno-address-of-packed-member - Changes from version 1.2.4: * Remove the autogenerated headers in the gettext files * ata: Default to the non-activation 0xE subcommand * fastboot: Use a much longer timeout as the removal delay * fu-progressbar: be more quiet when running non-interactive * fu-tool: Show UpdateMessage if applicable for install command * dfu: Simplify the SREC parser to avoid a crash with an invalid file * wacom-raw: Use the correct error codes when the panel is not supported * wacom-usb: Add some more information to the README * fu-keyring-utils: Don't fail missing PKI directory when compiled with GPG/PKCS7 * dell: Check that the flash interface command is available * wacom-usb: Fix the plugin name to allow devices to be updated * fastboot: flash the partition after downloading the file * uefi: Add a quirk to use the legacy bootmgr description * ata: Mark all devices as needing a reboot * ata: Add a new plugin to upgrade firmware on ATA/ATAPI hardware * udev-device: Add a utility function for debugging * udev-device: Set the firmware revision automatically * udev-device: Set the serial number automatically * udev-device: Fall back to non-database model and vendor values * udev-device: Fix critical warning if the device has no parent * dell-dock: Add support for a passive flow * Add support for an `UpdateMessage` and display it in tools * fu-tool: Port the `get-updates` command over * When using `directory` remote type automatically generate metadata * libfwupd: Add support for new remote type "directory" * Ensure cabinet archives always have a container checksum * Add support for a per-release source and details URL * When generating a CAB Silo use the prefix "components" * uefi: Add a trivial debugging statement to debug a UX capsule failure * uefi: Use fwup_new0() to allocate the updates table array * nitrokey: Correct Nitrokey Storage invalid firmware version read * dell-dock: Add support for flashing Thunderbolt over I2C * wacom-raw: Add a plugin to update Wacom embedded EMR and AES panels * fu-util/fu-tool: sync up reboot and shutdown behavior * dfu: Ignore the SUB ASCII value * dfu: Fix the parser to support extended segment addresses * dfu: Support ihex files with leading comments don't show an error * uefi: Correct a boot order creation bug (Fixes: gh#hughsie/fwupd#956) * uefi: Remove all variable length arrays * uefi: Fix a logic bug in fwup_search_file() * uefi: Use _cleanup_free in one more place * uefi: Do not pass required attrs to fwup_delete_variable() * uefi: Delete the old Linux-Firmware-Updater boot entry * uefi: Use the GNU-EFI BOOL type * Check if plugin changed after the device attaches or detaches * uefi: Refactor and simplify the EFI loader * Show a console warning if loading an out-of-tree plugin * UEFI: Do the UX checksum calculation in fwupd * wacom-usb: Add two more Intuos tablets * nvme: Add the needs-shutdown quirk to Phison NVMe drives * Add _NEEDS_SHUTDOWN flag for devices * Use GCC __cleanup__ features in the EFI loader * nvme: Add flag to support manually aligning the firmware to the FWUG value * nvme: Support FGUID to get the SKU GUID * nvme: Support FWUG to get the write block size * nvme: Add trivial comment to clarify address bitshifting * uefi: Do not check the BGRT status before uploading a UX capsule * dfu: Fix flashing various Jabra devices * upower: Add support for checking battery percentage * nvme: Check the return code of the admin passthru ioctl * fu-tool: Add support for an 'update' command to fwupdtool * dell-dock: Set minimum board to board 4 * dell-dock: Workaround a manufacturing bug for board level 4 * dell-dock: Wait longer for re-enumeration on TBT SKU * superio: Support IT89xx devices * fu-main: remove incompatible locale error message * Add a new plugin checklist (Fixes: gh#hughsie/fwupd#899) - Dropped obsolete patch: fwupd-bsc1130056-change-esp-os-name.patch (upstream PR: gh#hughsie/fwupd#1119 - Fixed fwupd-bsc1130056-change-shim-path.patch so that it works with the new files - Cleaned up changelog- Stop shipping polkit rules, as we have the distro specific setup in polkit-default-privs (boo#1125428).- Add fwupd-bsc1130056-change-esp-os-name.patch to change the OS directory in ESP (bsc#1130056) - Add fwupd-bsc1130056-change-shim-path.patch to set the default shim binary for openSUSE/SLE (bsc#1130056) - Link fwupd*.efi.signed to fwupd*.efi as requested by fwupd (bsc#1129466)- fwupd.spec: fix shell syntax error in %postun section (boo#1120363).- Update to version 1.2.3: * Correctly migrate the history database - Changes from version 1.2.2: * Log an error if started with an incompatible locale * Fix building with -Wl,-z,defs * ebitdo: Fix the reported version number if the daemon locale is not C.UTF-8 * Add Dell TB18DC to the known devices list * Allow replacing the last byte in the image when using 'dfu-tool replace-data' * Check the device checksum as well as the content checksum during verify * Submit the device firmware checksum and update protocol in the submitted report * Include the device checksum and update protocol in the historydb * uefi: Add the PCR0 value as the device checksum for system firmware * Add new API to get the release protocol from the metadata * Allow plugins to define support for a 'well-known' protocol * uefi: When adding headers set the header size to 4k * uefi: Append the header on capsules without headers from Linux * flashrom: Ensure the quirks database is set on the new object * uefi: Do not add devices with invalid GUIDs * Do not allow a GUID of zero * Add shared functionality for reading and writing with O_NONBLOCK * Only run attach and detach if the device is in the wrong mode * Sanitize the version if the version format has been specified * wacom-usb: Remove the DTH generation hardware as it will not work with fwupd * thunderbolt: Remove a superfluous boundary condition when verifying update * Add a plugin to update hardware that supports fastboot * Fix a regression when doing GetReleases on unsupported hardware * dfu: Require a specific USB class and subclass for DFU mode * Correctly parse format the version numbers correctly using old metadata * amt: Fix a crash if AMT returns an empty response * Check plugins set error on failure * contrib: Add a simple python3 client * installed-tests: Adjust to actually use a remote for installed tests * Add more standard USB identifier GUIDs * wacomhid: Rename to wacom-usb * Provide a way for plugins to decompress a custom archive to ram - Changes from version 1.2.1: * Remove DaemonVersionFormat=quad * Shut down the daemon after 2h of inactivity * Create a silo index to speed up GUID queries * Fix flashing the 8bitdo SF30 * Speed up fwupd startup by loading less thunderbolt firmware * Query the XbSilo when calling fu_plugin_check_supported() * Guess the version format when it is not provided * Fix a use-after-free when using valgrind and --immediate-exit * Add per-release install duration values * Fix showing the custom remote agreements * Be more explicit setting the update state * Include the os-release information in the release metadata - Changes from version 1.2.0: * ebitdo: remove SF30/SN30 pro device ids * dell-dock: Drop delayed MST callback routine * synapticsmst: Adjust EVB board handling * synapticsmst: Remove the content checking of firmware * synapticsmst: Access Board ID through memory instead In firmware images HDCP 2.2 will be enabled by default,so access to flash region will fail.` * contrib: Adjust flatpak build for moving to flathub * dell-dock: Prefer to flash VMM5331 via I2C instead of DP aux * Use HTTPS_PROXY if set * firmware-packager: Make it clearer to use * Sort the firmware sack by component priority * flatpak: Update gnu-efi to latest version * amt: Set the full device version including the BuildNum * fwupdmgr/fwupdtool: Move monitor command to fwupdtool * fwupdmgr/fwupdtool: Move firmware builder from fwupdmgr to fwupdtool * Add version format quirks for several Lenovo machines * uefi: Set the quirks on created devices * dell_dock: Use correct offset for finding version of MST * dell-dock: Add missing unlock call for MST via dell_dock plugin * Support the Intel ME version format * Port from libappstream-glib to libxmlb * Bump requirement to meson 0.46.0 * fu-main: Catch SIGTERM while update is in progress * fu-tool: Stop any running daemon over dbus before loading engine * meson: Bump dependency to 0.44 and adjust sysconfdir handling * dell-dock: If marketing name is invalid don't fail initialization * Readme Updated: Added KDE Discover as one more graphical front-end available for fwupd. * dell-dock: Correct a situation that error wasn't propagating * Don't segfault if a plugin returns FALSE from UpdateFunc with no error set * dell-dock: Use different debug strings for each device type * dell-dock: Don't use the VLA feature in the new dock * Add a plugin for an upcoming Dell USB-C dock * contrib: Add information on how to use debugging scripts * Allow setting the version format from a quirk entry * Don't use AppStream-glib for string helpers * Don't use AppStream-glib for version helpers * Don't use AppStream-glib for the GUID helpers * fu-device: Ensure that parent ID is created before creating quirked children * Update all sub-devices for a composite update * Stop showing the current release during updates in fwupdmgr * uefi: Move the TPM unlocking functionality from the Dell to UEFI plugin * Run the Dell plugin initialization after the UEFI plugin * thunderbolt-power: Fix possible linker problem * Allow firmware files to depend on versions from other devices * fu-debug: Redirect all debugging output to stderr instead of stdout * synapticsmst: Adjust panamera ESM update routine for some reported issues * fu-engine: Optionally wait for replug before updating a device * fu-device-list: Use delayed device removal when removing the tree * thunderbolt: Use replugging from the daemon * Add support for devices to show an estimated flash time * Marked some CL options for translation * ci: Run clang static analysis for Ubuntu build rather than just clang compiler * nvme: Initialize the buffer before reading the contents * contrib: Add a standalone installer creation script * rts54hid: Add support for Realtek USB devices using vendor HID commands * fu-engine: Don't show devices pending a reboot in GetUpgrades * Add FuMutex helper to make various parts of the daemon thread-safe * rts54hub: Add support for Realtek USB devices using vendor HUB commands * uefi: Check the amount of free space on the ESP * fu-tool: Import debugging options from fu-debug like fu-main * superio: Set the physical and logical IDs - Add pkgconfig(xmlb) BuildRequires: New dependency.- Add pesign-obs-integration to BuildRequires and add fwupd*.efi to BRP_PESIGN_FILES to get it signed - Add LC_IMAGES and use efivar only if %{with efi_fw_update} + Also update the version requirement of efivar - Disable Redfish and NVME plugins if %{without efi_fw_update} since those two plugins require efivar - Remove fwup from BuildRequires since fwupdate is already merged into fwupd.- Use gnu-efi only if %{with efi_fw_update}, always use pkgconfig(efivar) - Fix file list- Amend %post and %postun to install/uninstall fwupd*.efi to the EFI system partition + Also add shim to Requires for fwupdx64.efi - Mark fwupdate as obsolete + fwupdate has been merged into fwupd since fwupd 1.1.0.- fwupd is require for thunderbolt firmware update in SLE15-SP1(fate#322681)- Update to version 1.1.2: + New Features: - Add a new device flag "ignore-validation" that will override checks - Add a new plugin to enumerate EC firmware - Add a new plugin to update NVMe hardware - Add a plugin for updating using the flashrom command line tool - Allow the device list to take care of waiting for the device replug - Allow updating just one specific device from the command line - Allow upgrades using a self-signed fwupd.efi binary - Download firmware if the user specifies a URI - Include serial number in daemon device output when trusted - Notify all plugins of device removals through a new vfunc - Use boltd force power API if available + Bugfixes: - Add an install hook for classic snap - Allow forcing installation even if no AC power is applied - Allow using --force to ignore version_lowest - Always use the same HardwareIDs as Windows - Check the device state before assuming a fake DFU runtime - Copy over parent GUIDs from other plugin donors - Detect location of python3 interpreter - Do not add udev devices after a small delay - Don't fail to run if compiled without GPG/PKCS7 - Fix a segfault in fwupdtool caused by cleanup of USB plugins - Implement the systemd recommendations for offline updates - Improve performance when reading keys from the quirk database - Remove children of devices when the parent is removed - Rewrite synapticsmst to use modern error handling - Rewrite the unifying plugin to use the new daemon-provided functionality - Show a time estimate on the progressbar after an update has started- Use noun phrase for summary. Trim request for comments from description.- Update to version 1.1.1: + New Features: - Add support for the Synaptics Panamera hardware - Add validation for Alpine and Titan Ridge - Improve the Redfish plugin to actually work with real hardware + Bugfixes: - Allow different plugins to add the same device - Allow flashing unifying devices in recovery mode - Allow running synapticsmst on non-Dell hardware - Check the ESP for sanity at at startup - Do not hold hidraw devices open forever - Don't override _FORTIFY_SOURCE when building the EFI binary - Don't show passwords in fwupdmgr - Fix a potential segfault in smbios data parsing - Fix encoding the GUID into the capsule EFI variable - Fix various bugs when reading the thunderbolt version number - Reboot synapticsmst devices at the end of flash cycle - Show status messages when the daemon is initializing - Show the correct title when updating devices - Show the reasons that plugins are not run on the CLI - Use localedir in po/make-images- Run %udev_rules_update in post as package install udev rules- Update to version 1.1.0: (FATE#326702) + New Features: - Add a initial Redfish support - Add a tool to mimic the original fwupdate CLI interface - Allow devices to assign a plugin from the quirk subsystem - Change the quirk file structure to be more efficient - Merge fwupdate functionality into fwupd - Run a plugin vfunc before and after all the composite devices are updated - Support more Wacom tablets + Bugfixes: - Add release information for locked devices - Allow building with older meson - Detect the EFI system partition location at runtime - Do not use 8bitdo bootloader commands after a successful flash - Enable accesing downloaded files in flatpak and snap - Fix a potential buffer overflow when applying a DFU patch - Fix downgrading older releases to devices - Fix flashing devices that require a manual replug - Fix several small memory leaks in various places - Fix the retrieval of Redfish version - Fix unifying failure to detach when using a slow host controller - Set the Wacom device status when erasing and writing firmware - Show errors in the CLI if unable to access directory - Use the parent device name for Wacom sub-modules - Removed enable_pkcs7_when_testing_only.patch- Update to version 1.0.8: + New Features (including version 1.0.7): - Add an plugin to update some future Wacom tablets - Add 'fwupdmgr get-topology' to show logical device tree - Add support for creating a flatpak - Add support for creating a snap - Add support for Motorola S-record files - Add the Linux Foundation public GPG keys for firmware and metadata - Show a translated warning when the server is limiting downloads - Add enable-remote and disable-remote commands to fwupdmgr - Add fu_plugin_add_compile_version() for libraries to use - Allow requiring specific versions of libraries for firmware updates - If no remotes are enabled try to enable the LVFS - Show a warning with interactive prompt when enabling a remote + Bugfixes (including version 1.0.7): - Add a firmware diagnostic tool called fwupdtool - Adjust all licensing to LGPL 2.1+ - Allow installing more than one firmware using 'fwupdmgr install' - Allow specifying hwids with OR relationships - Do not call fu_plugin_init() on blacklisted plugins - Do not require libcolorhug to build - Fix a crash in libfwupd where no device ID is set - Fix a potential DoS in libdfu by limiting holes to 1MiB - Fix a segfault that sometimes occurs during cleanup of USB plugins - Fix Hardware-ID{0,1,2,12} compatibility with Microsoft - Hide devices that aren't updatable by default in fwupdmgr - Search all UEFI GUIDs when matching hardware - Stop matching Nintendo Switch Pro in the 8bitdo plugin - Check that EFI system partition is mounted before update - Disable synapticsmst remote control on failure - Don't recoldplug thunderbolt to fix a flashing failure - Fix SQL error when running 'fwupdmgr clear-offline' - Improve the update report message - Only enumerate Dell Docks if the type is known - Only run certtool if a new enough gnutls is present - Prevent a client crash if the daemon somehow sends invalid data - Reboot after scheduling using logind not systemd - Use the right encoding for the label in make-images - Added/backported enable_pkcs7_when_testing_only.patch: + needed to disable pkcs7 test during build (can be removed for fwupd >= 1.0.9)- Update hasbang in installed files from /usr/bin/env python3 to /usr/bin/python3.- Update url - Small packaging cleanup with spec-cleaner- Update to version 1.0.6: + New Features: - Add bash completion for fwupdmgr. - Add support for newest Thunderbolt chips. - Allow all functions that take device arguments to be prompted. - Allow devices to use the runtime version when in bootloader mode. - Allow overriding ESP mount point via conf file. - Delete any old fwupdate capsules and efivars when launching fwupd. - Generate Vala bindings. + Bugfixes: - Allow ctrl-d out of the prompt for devices. - Allow to create package out of provided binary. - Correct handling of unknown Thunderbolt devices. - Correctly detect new remotes that are manually copied. - Fix a crash related to when passing device to downgrade in CLI. - Fix running the self tests when no fwupd is installed. - Fix Unifying signature writing and parsing for Texas bootloader. - Only send success and failure reports to the server. - Use a CNAME to redirect to the correct CDN for metadata. - Use a longer timeout when powering back the Thunderbolt device.- Ensure library package has a dependency on main package, otherwise it won't be usable.- Update to version 1.0.5: + New Features: - Offer to reboot when processing an offline update. - Report the efivar, libsmbios and fwupdate library versions. - Report Thunderbolt safe mode and SecureBoot status. - Show the user a URL when they report a known problem. - Support split cabinet archives as produced by Windows Update. + Bugfixes: - Be more careful deleting and modifying device history. - Clarify which devices don't have upgrades. - Ensure the Thunderbolt version is xx.yy. - Fix a daemon warning when using fwupdmgr get-results. - Fix crasher with MST flashing. - Fix DFU detach with newer releases of libusb. - Include the device VID and PID when generating the device-id. - Set the RemoteId when using GetDetails. - Stop matching 8bitdo DS4 controller VID/PID. - Use help2man for dfu-tool and drop docbook dependencies. - Use ngettext for any strings with plurals. - Use the default value if ArchiveSizeMax is unspecified.- Update to version 1.0.4: + New Features: - Add D-Bus methods to get and modify the history information. - Allow the user to share firmware update success or failure. - Ask the user to refresh metadata when it is very old. - Store firmware update success and failure to a local database. + Bugfixes: - Add a device name for locked UEFI devices. - Allow each plugin to opt-in to the recoldplug action. - Fix firmware downloading using gnome-software. - Fix UX capsule reference to the one specified in efivar. - Never add two devices to the daemon with the same ID. - Rescan supported flags when refreshing metadata. - Add pkgconfig(json-glib-1.0) BuildRequires: new dependency.- Update to version 1.0.3: + New Features: - Add a new plugin to add support for CSR "Driverless DFU". - Add initial SF30/SN30 Pro support. - Support AppStream metadata with relative URLs. + Bugfixes: - Add more metadata to the user-agent string. - Block owned Dell TPM updates. - Choose the correct component from provides matches using requirements. - Do not try to parse huge compressed archive files. - Fix a double-free bug in the Udev code. - Handle Thunderbolt "native" mode. - Use the new functionality in libgcab >= 1.0 to avoid writing temp files.- Unbreak compilation on non-x86, upstream renamed options to disable plugins.- Update to version 1.0.2: + Add a plugin for the Nitrokey Storage device + Add support for the original AVR DFU protocol + Allow different plugins to claim the same device + Allow quirks to set common USB properties + Move a common plugin functionality out to a new shared object + Optionally delay the device removal for better replugging + Set environment variables to allow easy per-plugin debugging + Use a SHA1 hash for the internal DeviceID + Add quirk for AT32UC3B1256 as used in the RubberDucky + Disable the dell plugin if libsmbios fails + Don't register for USB UDev events to later ignore them + Fix a possible buffer overflow when debugging ebitdo devices + Fix critical warning when more than one remote fails to load + Fix DFU attaching AVR32 devices like the XMEGA + Ignore useless Thunderbolt device types + Refactor ColorHug into a much more modern plugin + Release the Steelseries interface if getting the version failed + Remove autoconf-isms from the meson configure options + Show a nicer error message if the requirement fails + Sort the output of GetUpgrades correctly - Changes from version 1.0.1: + Add support for HWID requirements + Add support for programming various AVR32 and XMEGA parts using DFU + Add the various DFU quirks for the Jabra Speak devices + Allow specifying the output file type for 'dfu-tool read' + Move the database of supported devices out into runtime loaded files + Support the IHEX record type 0x05 + Use help2man to generate the man page at build time + Use the new quirk infrastructure for version numbers + Catch invalid Dell dock component requests + Correctly output Intel HEX files with > 16bit offset addresses + Do not try to verify the element write if upload is unsupported + Fix a double-unref when updating any 8Bitdo device + Fix crash when enumerating with Dell dock connected but with no UEFI + Fix uploading large firmware files over DFU + Format the BCD USB revision numbers correctly + Guess the DFU transfer size if it is not specified + Include the reset timeout as wValue to fix some DFU bootloaders + Make the error message clearer when sans fonts are missing + Support devices with truncated DFU interface data + Use the correct remote-specified username and passord when using fwupdmgr + Use the correct wDetachTimeOut when writing DFU firmware + Verify devices with legacy VIDs are actually 8Bitdo controllers - Add help2man as BuildRequires.- Fix dependencies and build options for non-x86 architectures. At least FW updates for USB are arch independent, and EFI FW updates can also be applied on Aarch64.- Update to version 1.0.0: * Add the plugin documentation to the main gtk-doc * Add a waiting-for-auth daemon state * Add fwupd_remote_get_checksum() to use in client programs * Generate the LD script from the GObject Introspection data * Prevent fwupd from mounting filesystems * uefi: Do not use system-specific infomation for PCI devices * uefi: Support uploading the firmware splash image * dell: only set coldplug delay when we know we need it * dell: only run SMI to toggle host MST GPIO on systems with host MST * dell: add functionality to blacklist HW with problems * dell: only run on intended chassis * thunderbolt-power: always run after thunderbolt plugin * Allow plugins to depend on each other * Add support for SMBIOSv3 * dell: prefer to use hwids to get DMI keys and DE table * debian: remove /etc/fwupd.conf on upgrade * unifying: Use fu_plugin_check_supported() * Add fu_plugin_check_supported() * unifying: Use a device whitelist to avoid breaking devices * Fix various printing issues with the progressbar * dell: Fix a trivial whitespace issue * Do not fail to load the daemon if cached metadata is invalid * Do not store the newest release as part of the FuDevice object * Add a method to return a list of upgrades for a specific device * Move the downgrade calculation to the daemon * Make FuDevice derive from FwupdDevice rather than FwupdResult * Add a command 'clear-offline' to fwupdmgr * Merge releases where multiple remotes provide the same firmware * Remove the UniqueID property * uefi: Do not set the release version * udev: Do not match USB devices, even with a GUID set * Use the intel-wmi-thunderbolt kernel module to force power * dell: drop thunderbolt force power code * unifying: Add hardcoded summaries for peripheral kinds * Create CODE_OF_CONDUCT.md * Ensure more devices set the device summary * Add an 'Summary' property to each device * Add a human-readable title for each remote * unifying: Disable if the kernel has no CONFIG_HIDRAW support * Move deprecated symbols to a new header * Introduce an s390x cross compile target to CI * Add ModifyRemote as an easy way to enable and disable remotes like the LVFS * Do not auto-open all USB devices at startup * dfu: Use FuDeviceLocker * unifying: Use FuDeviceLocker * colorhug: Use FuDeviceLocker * ebitdo: Use FuDeviceLocker * altos: Use FuDeviceLocker * steelseries: Use FuDeviceLocker * usb: Use FuDeviceLocker * Add FuDeviceLocker to simplify device open/close lifecycles * dfu: Remove DEVO support * dfu: Remove the now-unused symtab support * Remove the ELF support from libdfu and move the code to the altos plugin * Use -Werror when building in Travis CI * Do not install the libdfu helper library * Parse the SMBIOS DMI table directly * usb: Disable the fallback USB plugin * Test for missing language translations at build time * Fix the libdfu self test failure on s390 and ppc64- Update to version 0.9.8: * Add a command 'clear-offline' to fwupdmgr * Do not fail to load the daemon if cached metadata is invalid * Fix a crash when using fu_plugin_device_add_delay() * Fix the libdfu self test failure on s390 and ppc64 * Format the BCD USB revision numbers correctly * Never fallback to an offline update from client code * Prevent fwupd from mounting filesystems * dfu: Allow flashing when the target does not specify an alt-name * dfu: Do not try to verify the element write if upload is unsupported * dfu: Fix uploading large firmware files * dfu: Include the reset timeout as wValue to fix some hardware * dfu: Set the vendor ID to the runtime USB VID * dfu: Use 0x0101 as an alias for 0x0110 * thunderbolt: move test for mock environment (gh#hughsie/fwupd#280) * udev: Do not match USB devices, even with a GUID set * uefi: Do not set the release version * unifying: Disable if the kernel has no CONFIG_HIDRAW support- Update to version 0.9.7: + 10 months worth of bugfixing, integrating more vendor specific Firmware update paths.- Update to version 0.8.1: + Delete duplicate translations (gh#hughsie/fwupd#89). + Do not hardcode docbook2man path. + Fix fwupdmgr timeout with missing pending database. + Fix compiler warnings. + Fix a crash when enumerating devices on a Dell WLD15. + dell: don't initialize libsmbios on unsupported systems. + Do not fail to start on Dell hardware. + Adjust systemd confinement restrictions. + Do not dlclose modules when running under valgrind. + Really remove the NoNewPrivileges systemd confinement. + Release fwupd 0.8.1.- Update to version 0.8.0: + Show a different error when checking for updates while on + battery power (gh#hughsie/fwupd#68). + Clarify the test in --help and man page related to offline + (gh#hughsie/fwupd#69). + libdfu: Use a heuristic for the start address if the firmware + has no DfuSe footer. + dell: Don't return the address of a stack variable. + dell: Fix a possibly-impossible-to-hit buffer overrun. + close USB devices before error returns (gh#hughsie/fwupd#73). + Make libelf support optional. + Always make sure we're getting a C99 compiler. + Fix redeclaration of polkit autocleanup functions. + Uncomment SystemdService parameter in the dbus service file + (gh#hughsie/fwupd#74). + Make all providers and plugins share a GUsbContext. + Unexport libebitdo. + Move the plugins into plugin-specific directories. + Convert the providers to plugins to simplify code and for + future features. + Add support for Logitech Unifying devices. + Add a set of vfuncs that are run before and after a device + update. + Return the pending UEFI update when not on AC power. + Move the UPower functionality to a plugin. + Fix udev plugin loading. + fix dfu plugin loading. + Disable PrivateNetwork on systemd service. + Use more restrictive settings when running under systemd. + dell: add a new method for forcing a controller to flash mode. + Add VerifyUpdate to update the device checksums server-side. + Move the Option ROM parsing to the Udev plugin. + Move the device add delay to shared code. + Add initial skeleton for Intel Thunderbolt support. + unifying: Use the actual bootloader VID/PIDs when in firmware + mode. + Allow the metadata to match a version of fwupd and the existing + fw version. + Add fwupd_result_get_device_version_bootloader(). + Fix the appstream-glib version guards. + dell: Add coldplug methods to let other plugins turn on + TBT/GPIO. + libdfu: Don't read data from some DfuSe targets. + Add the ability to run a prepare->exec->cleanup on coldplug. + Allow plugins to request that all plugins re-coldplug. + thunderbolt: Detecting new devices and add an actual device to + the daemon. + Add support for flashing the ChaosKey. + thunderbolt: add some guards around empty arrays. + dell: Adjust the coldplug preparation and cleanup sequence. + dell: Fix possible linker problem. + Revert "thunderbolt: add some guards around empty arrays". + Add fu_plugin_set_coldplug_delay() to allow hardware to + initialize if required. + altos: Add error checking when using termios. + ebitdo: Subclass FuDevice like the altos plugin. + altos: Set the flags in the init_real so they work for the + cmdline tool. + unifying: Subclass FuDevice like the altos plugin. + Include all debug messages when run with --verbose. + dell: introduce a standalone (noinst) tool to force mode + flashes. + Introduce plugin for Synaptics MST hubs. + synapticsmst: Add cascade support. + Only register the D-Bus service when all devices have been + added. + synapticsmst: Refactor away the global state. + synapticsmst: fix cascade support in the plugin. + Updates for thunderbolt plugin. + thunderbolt: Add special handling for safe mode on Dell systems + (gh#hughsie/fwupd#84). + synapticsmst: Iterate all nodes rather than hardcoding to 3. + synapticsmst: build GUID using dock type. + Add a new function fu_dell_supported to fu-dell-common. + synapticsmst: add a test suite. + synapticsmst: Fix up some trivial whitespace issues. + Fix a refcounting issue in the udev plugin. - Add rpmlintrc untill security review is resolved- Update to version 0.7.5: + Clean up PO files + Verify devices support updating in mode they are called. + Fix an assert when unlocking the dummy ESRT device + Don't create the UEFI dummy device if the unlock will happen on + next boot + dell: Match on TB16 as well + Fix a -fstack-protector-strong crash when uploading firmware + Enable the stack protection in local builds + dell: If running in test suite, don't try to get product ID + from sysfs + libfdfu: Show a warning when getting the alt-name failed + dfu: Fix listing devices using the ST reference bootloader + Show the nicely formatted target name for DfuSe devices + libdfu: Fix two possible critical warnings for corrupt USB + descriptors + libdfu: Correctly offset addresses when one zone has multiple + sectors + libdfu: Do not do GetStatus on dfuse upload + libdfu: Fix uploading from DfuSe devices + libdfu: Use the device offset when writing DfuSe firmware + libdfu: Add DfuAction enumerated value to represent a device + action + libdfu: Use an animated progress bar when performing DFU + operations + libdfu: Do not do a zero-byte download when in DfuSe mode + libdfu: Fix verification of written DfuSe firmware + libdfu: Ensure the device is open before claiming the interface + libdfu: Ensure the mode is set correctly when faking a runtime + libdfu: Re-get the quirks when the DfuDevice gets a new + GUsbDevice + libdfu: Add quirks for HydraBus as it does not have a DFU + runtime + libdfu: Match the device booloader or runtime VID and PID when + checking firmware + Add a 'replace-data' command to dfu-tool + string + libdfu: Add dfu_sector_get_zone() to get the continuous memory + zone number + libdfu: Wait for DNBUSY to be cleared when checking the DfuSe + status + libdfu: Correctly erase DfuSe devices + Enable hardening flags on more binaries + libdfu: Correctly set the element address when uploading from + DfuSe devices - Add pkgconfig(gmodule-2.0) BuildRequires: Align with what + configure checks for. - Add pkgconfig(libsmbios_c) BuildRequires: Support dell bios. + Unfortunatly, until we have fwup packaged and enabled, this will + not work. - Add disabled pkgconfig(libtbtfwu): For future thunderbolt + support.- Update to version 0.7.4: + Add a fallback for older appstream-glib releases + Write the ELF files with the correct section type + Fix libfwupd self tests when a host-provided fwupd is not + available + Add dfu_firmware_add_symbol() + Add the Altos symbol table to the DfuFirmware + Use the symtab to set the VID/PID from Altos IHEX firmware + images + Show the human-readable version in the 'dfu-tool dump' output + Allow specifying the argument to 'dfu-tool set-release' in + major.minor format. + sections + Support writing the IHEX symbol table + call + Load the symbol table from ELF firmware + Load the Altos USB descriptor from ELF files + Add DFU_CIPHER_KIND_RSA + Fix a possible crash when uploading firmware files using libdfu- Update to version 0.7.3: + build: Fix gtk-doc build when srcdir != builddir + In get-details output, display the blob filename + Ensure the update ID is set when getting local firmware details + Use a private gnupg key store + Add support for installing against multiple devices from a CAB + file + Use the correct firmware blob when installing a composite + device update + in get-details output, display update_name rather than Unknown + Device + statements + Don't make failures critical while checking versions or locked + state + Show a more detailed error when installing firmware on the + wildcard + Add Dell TPM and TB15/WD15 support via new Dell provider. + file + Allow blacklisting devices by their GUID + header file + Add XPS 9250 to Dell TPM modeswitch blacklist + Only display flashes left in results output when it gets low. + Add a small library for talking with 0bitdo hardware + Add another compile warning and fix up any build failures + Embed fwupd version in generated libfwupd and libdfu + documentation + Update fwupdmgr manpage for new commands and arguments + build: Fix gtk-doc build when srcdir != builddir + online not offline + Get the firmware version correctly from 0Bitdo gamepads + Switch to the Amazon S3 CDN for firmware metadata + Fix writing 8Bitdo device firmware + be updated + Show the vendor flashing instructions when installing + Split out the DFU file formats to separate files + Add fwupd_result_remove_device_flag() + Add FU_DEVICE_FLAG_NEEDS_BOOTLOADER + get-updates output + Allow providers to export percentage completion + Add fwupd_client_get_status() + Handle the 8Bitdo bootloader in a better way + Show a progress notification when installing firmware + Add fwupd_result_get_unique_id() + Use the SHA1 hash of the local file data as the component + origin + Use the correct define prefix for FwupdDeviceFlags + libdfu: Fix hang when parsing corrupt IHEX files + Add a set-target-size command to dfu-tool + Support the 'DEVO' cipher kind in libdfu + Add a set-address command to dfu-util + Disable the Dell specific code by default + Conditionally enable all providers based upon what's installed + Add a summary of providers that are enabled from configure + Do not use the deprecated GNOME_COMPILE_WARNINGS + Ignore devices that do not add at least one GUID + Do not attempt to add DFU devices not in runtime mode + Save the unique ID in the pending database + libdfu: Add initial ELF reading and writing support + Add dfu_firmware_format_from_string() + Normalize the DfuFirmwareFormat enums- Update to version 0.7.2: + Allow devices to have multiple assigned GUIDs + Only return updatable devices from GetDevices() + Add fu_device_get_alternate() + Allow metainfo files to match only specific revisions of + devices + Re-read flags for a device after a provider's unlock routine is + done + Test for a locked device when trying to install firmware update + Enforce allowing providers to take away flash abilities + Support returning multiple GUIDs from GetDetails + Add a GetDetailsLocal() method to eventually replace + GetDetails() + break + libdfu: Add DfuVersion enumerated values + libdfu: Show the DFU protocol version in 'dfu-tool list' + Only claim the DFU interface when required- Update to version 0.7.1: + Fix libdfu CRC check for big endian architectures + Add dfu_image_get_element_default() + Fix libdfu CRC check for big endian architectures + Fix big endian issues when reading and writing DFU and DfuSe + files + Remove non-interactive pinentry setting from fu-keyring + Set the system's DMI product name as the DisplayName for UEFI + Re-order output of get-devices to be easier to read + Make the device display name nicer + update version + Return all update descriptions newer than the installed version + Add summary and name field for Rival SteelSeries + Fix a critical warning when restarting the daemon + Add a 'supported' flag to the FuDevice + Add fwupd_client_connect() + Add a 'monitor' debugging command for fwupdmgr + Add device-added, device-removed and device-changed signals + Match the AppStream metadata after a device has been adedd + Re-match devices when the AppStream metadata is updated + Show 'Unknow Device' in fwupdmgr when a device name is not set + Set the device description when parsing local firmware files + Add support for a new device field "Flashes Left". + src/Makefile.am: reshuffle so enableable bits are only + referenced when on + Add support for a --force flag to override provider warnings- Update to version 0.7.0: + Use g_usb_context_wait_for_replug() + Run vendor plugins as required + Add a plugin for SteelSeries hardware + Add fwupd_device_flag_to_string() + Return the device flags when getting firmware details + Show device flags in 'fwupdmgr get-devices' + Add fwupd_trust_flag_to_string() + Export FwupdUpdateState in libfwupd + Export FwupdUpdateFlags in libfwupd + Add FwupdResult to libfwupd + Add a self test framework for libfwupd + Add FwupdClient to libfwupd + Use FwupdClient from libfwupd in fwupdmgr + Use libfwupd inside the daemon + Emit a FwupdClient::changed when the daemon emits this signal + Rename some of the new libfwupd API to align with the D-Bus + names + libdfu: Fix up some NULL/FALSE confusion + libfwup: Fix up some NULL/FALSE confusion + FwupdClient + Allow other checksum kinds in FwupdResult + Allow SHA-256 hashes when verifying + Show the checksum kind in the fwupdmgr output + Add Alienware to the version quirk table + Do not use /tmp for downloaded files + Add fwupd_result_has_device_flag() + Do not return updates that require AC when on battery + Connect to UPower at startup + Test that GPG key import actually was successful (or didn't + change a key already in the keyring) + Use g_auto() in FuKeyring + Return errors of the correct type when using libfwupd + Allow overridding the location of the pending database for + test suite + Allow overriding the location of the provider offline files for + test suite + Validate that the dbus system bus is available before running + libfwupd tests + Update README.md for changes that have happened in the project + Add some basic explanation of how to use fwupd with various + frontends + Split out the libdfu-devel package + Revert "Allow overridding the location of the pending database + for test suite" + Revert "Allow overriding the location of the provider offline + files for test suite" + Allow the test suite to run in %check + Generate gtk-doc documentation for libfwupd- Update to version 0.6.3: + Require AC power before scheduling some types of firmware + update + Install the hardcoded firmware AppStream file + Correct the BCD version number for DFU 1.1 + Add an unlock method for devices + Add ESRT enable method into UEFI provider. + Only read PCI OptionROM firmware when devices are manually + unlocked + Do not use deprecated API from libappstream-glib + Ignore the DFU runtime on the DW1820A + Export the attribute and quirk values in libdfu + Show ignored DFU devices in dfu-util, but not in fwupd + Allow defining update vfuncs with no runtime support + Revert "Allow defining update vfuncs with no runtime support" + Add a simple plugin infrastructure- Update to version 0.6.2: + Add 'Created' and 'Modified' properties on managed devices + Fix get-results for UEFI provider. + Support vendor-specific UEFI version encodings + Move quirks directly into a single table and file.- Update to version 0.6.1: + Only dump the profiling data when run with --verbose + Always persist ColorHug devices after replug + Do not misdetect different ColorHug devices- Update to version 0.6.0: + Add support for updating USB devices with DFU + libdfu: Add support for DfuSe firmware + libdfu: Generate gtk-doc documentation + libdfu: Don't rely on specific hardware to be present + libdfu: Move the VID:PID checks from the tool to DfuDevice + libdfu: Use a custom error domain + Use the same device identification string format as Microsoft + libdfu: Fix crash when setting a target size + libdfu: Allow setting the alternate settings in DfuSe firmware + libdfu: Add a merge command to dfu-tool + libdfu: Allow choosing a different alt-setting when downloading + libdfu: Fix a crash when setting a NULL image name + libdfu: Correctly implement auto-boot in dfu_device_download() + libdfu: Check for extra args to dfu-tool convert + libdfu: Call the progress callback when doing detach + Ignore the DFU device detach:attach when verifying + libdfu: Require a --force flag to flash wildcard firmware + Use new API available in fwup 0.5 + libdfu: Make the element address 32 bits in size + libdfu: Support the ST-specific bitCanAccelerate + libdfu: Only do a Detach notification if we're actually doing to do it + libdfu: Use the progress bar for all uploads and downloads + libdfu: Improve the output of 'dfu-util list' + libdfu: Support download and upload to ST DfuSe devices + libdfu: Fix multi-interface devices like the Neo Freerunner + libdfu: Add a pkgconfig file + libdfu: Use signals to propagate device state + libdfu: Add a context object to handle device hotplug + libdfu: Add an example showing GObject Introspection + libdfu: Do not ref DfuDevice in DfuTarget so the auto-close + logic works + Close DFU devices as soon as possible after the transfer has completed + Emit the changed signal after doing an update + Rescan the DFU device after replug to get the new version + libdfu: Add dfu_context_get_device_by_platform_id() + libdfu: Add dfu_device_get_runtime_release() + libdfu: Add dfu_device_get_display_name() + libdfu: Fix self tests after recent API change + Split out the DFU provider as a new file + libdfu: Copy the platform ID and invalidate the GUsbDevice when removed + libdfu: Accept multiple spaces after the DfuSe sector name + libdfu: Verify the GUsbDevice is set before using it + libdfu: Remove the weak pointer when destroying the DfuTarget + libdfu: Fix dfu_device_wait_for_replug() so it can work with a DfuContext + Export the AppStream ID when returning device results + Rescan the DFU device after firmware has been updated + libdfu: Handle cancellation with ctrl+c in dfu-tool + libdfu: Add a quirk to support DFU runtime-less devices + libdfu: Add an explicit 'attach' method + libdfu: Add dfu_firmware_get_image_by_name() + libdfu: Make reading and writing to targets easier to + understand + Fix compile with --disable-shared + libdfu: Display all the files shown with 'dfu-tool dump' + libdfu: Fix a few crashers found using afl + libdfu: Fix another bug discovered by the fuzzer + libdfu: Add commands to encrypt and decrypt firmware images + libdfu: Show better device errors + libdfu: Add DfuCipher which is a property on a target and a + firmware file + libdfu: Add support for the draft 'DFU Metadata Table + Specification' + libdfu: Only enumerate the DfuContext when required + libdfu: Fix several reported crashes in the inhex32 import code + Release fwupd 0.6.0- Update to version 0.5.4: + Fix compile error against fwupdate git due to dropped + functions. + Use strerror() when printing errors from libfwupdate + Use new API available in fwup 0.5 + Release fwupd 0.5.4- Update to version 0.5.3: + Avoid seeking when reading the file magic during refresh + Do not assume that the compressed XML data will be NUL + terminated + debugging + Use the correct user agent string for fwupdmgr + Release fwupd 0.5.3- Update to version 0.5.2: + Ensure D-Bus remote errors are registered at fwupdmgr startup + Show the dotted-decimal representation of the UEFI version + number + require appstream-glib 0.5.1 + not found + When the version is from the 'FW' extension do not cache the + device + Support cabinet archives files with more than one firmware + Add the update description to the GetDetails results + Add profiling data to debug slow startup times + Fix verify-update to produce components with the correct + provide values + Clear the in-memory firmware store only after parsing a valid + XML file + Release fwupd 0.5.2- Update to version 0.5.1: + Fix the error message when no devices can be updated + offline update: Use glib api for for reading symlinks + Release fwupd 0.5.1- Update to version 0.5.0: + Do not merge the existing firmware metadata with the submitted + files + Raise the dep on GLib to support and use g_autoptr() + Do not reboot if racing with the PackageKit offline update + mechanism + Release fwupd 0.5.0- Update to version 0.1.6: + Install fwupd and fwsignd into /usr/lib/$(triplet)/fwupd + instead. + Use the new secure metadata URI + Update the offline update service to invoke right command + Don't apply firmware if something else is processing the + offline update + Remove fwsignd, we have the LVFS now + Depend on appstream-glib >= 0.5.0 + Add application metadata when getting the updates list + Simplify the version properties on devices to avoid complexity + and bugs + Release fwupd 0.1.6- Update to version 0.1.5: + Allow fwupd to be autostarted by systemd + Sign the test binary with the correct key + Do not pre-convert the update description from AppStream XML + Devices with option ROM are always internal + Prefer the GUID from the firmware than the device + Allow no arguments to 'fwupdmgr verify-update' and use sane + defaults + Add the ability to remove a vendor on the LVFS site + Fix validation of written firmware + Move the verification and metadata matching phase to the daemon + Add a simple config file to store the correct LVFS download URI + Make parsing the option ROM runtime optional + Add a Raspberry Pi firmware provider + Use the AppStream 0.9 firmware specification by default + Generate the ColorHug test files at runtime + Release fwupd 0.1.5- Update to version 0.1.4: + man/Makefile.am: Add --sgml to docbook2man invocation + Make statements about storing private keys stronger. + Provide a way for clients to add new firmware metadata to the + system cache + Fix fwupd-offline-update.service + Revert "man/Makefile.am: Add --sgml to docbook2man invocation" + Add a Udev firmware provider + Extract the version string from the ROM in PCI devices + Add a 'verify' command that verifies the cryptographic hash of + device firmware + Make the ROM parsing more robust and add self tests + Get the version number out from Intel VBIOS too + Provide a way to dump the option ROM using the command line + build: gusb is required even without colorhug + remove unused variables + Do not return NULL as a gboolean + Fix Intel VBIOS detection on Dell hardware + Do not use the subsystem information when constructing the fake + GUID + Actually parse the PCI option ROM + Accept multiple files at one time when using fwupdmgr dump-rom + verify run + Add a 'verify-update' command to fwupdmgr + Fix trivial bug when parsing firmware versions + Keep hitting the hardware until it gives us enough ROM + Make the version parsing more resilient to corrupt firmware + Fix the example .inf file to reflect reality + Fix ROM PPID searching to work for all ROMs + Move the LVFS website to the fwupd project + Add the ability to create detached signatures + Allow cab files to be saved + Add a simple signing server that operates on .cab files + Automatically download metadata using fwupdmgr if required + Don't call efibootmgr after fwupdate. + Associate the contact email address directly with the vendor + key + Use the actual LVFS GPG key + Allow running fwsignd as the non-root user + metadata + Do not merge existing LVFS metadata + Do not use the file hash when storing the LVFS submitted + firmwares + Move GetUpdates to the daemon + Change the DBus method for installing firmware to 'Install' + Allow installing an offline UEFI update without --offline + Add a 'fwupdmgr update' command to update all devices to latest + versions + 'update' command + Increase the size limit of firmware to 50Mb + Only sign files when the entire file has been copied + Fallback to offline install when calling the update argument. + Reload appstream data after refreshing. + Release fwupd 0.1.4- Update to version 0.1.3: + Coldplug the devices before acquiring the well known name + Add an UNKNOWN status so we can return meaningful enum values + Run the offline actions using systemd when required + Get the firmware version from the device descriptors + Added syntax highlighting + More markup + Support OpenHardware devices using the fwupd vendor extensions + Move boolean properties on the device to a set of flags + Release fwupd 0.1.3- Update to version 0.1.2: + More markup + Fixed typos and markup for executable + Add slovak translation + Add helper code to validate public key signatures + Decompress any firmware signatures in the .cab file + Verify firmware if a detached signature is present + Show the firmware trust status when doing GetDetails() + Only allow signed firmware to be upgraded without a password + Add some guidelines for vendors to README + Small grammar fix + Extract the .cat file alongside the firmware + Release fwupd 0.1.2- Update to version fwupd_0_1_1: + Do not crash when there are no devices to return + Add a 'get-updates' command to fwupdmgr + Add and document the offline-update lifecycle + Create runtime directories if they do not exist + Create a libfwupd shared library + Export the status as an enumerated value rather than a string + Release fwupd 0.1.1- Initial package./sbin/ldconfig/sbin/ldconfigibs-power9-12 16831429471.8.6-150500.2.21.8.6-150500.2.2libfwupd.so.2libfwupd.so.2.0.0/usr/lib64/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:SLE-15-SP5:GA/standard/306a67461ec7e7079f3fde558ba16602-fwupdcpioxz5ppc64le-suse-linuxELF 64-bit LSB shared object, 64-bit PowerPC or cisco 7500, version 1 (SYSV), dynamically linked, BuildID[sha1]=6a9faa147607e77c70c0536476e3c4afcacf5947, strippedPPPPPPPPPPPPPPPP P P P P P P P P P PPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPP P P!P!P"P"P#P#P$P$P%P%P&P&P'P'P(P(P)P)P*P*P+P+P,P,P-P-P.P.P/P/P0P0P1P1P2P2P3P3P4P4P5P5P6P6P7P7P8P8P9P9P:P:P;P;PP>PRRR RRRR RR R R RRRE'M utf-8a26606d19263c9ddd07fb31df9daaf719c7a02f7159b6a3a2c7a51c5a9182027?7zXZ !t/\] cr$x#H~4 q}Mښlt)06&fo^$hXIw6%!x}5RbN$VC4.<8qO&2 `{h.6 5> _xz\1>dׯ88s: ,,j&V%gQggSE xo)ڜm@xEl偘a qƘt&_a(-e֍oK7;0,aJc+}_VEn][0O*{-:a4Q_+lrt-#/ {l AV_ü-ⲅ"=b.6HM5ݖsn/!3#™*h-'0 }T2׷LCf-H\kzuz)_:[>Z2>"Ɲ߰\FHĄ'$&)k8v]eaMCJ|^mKԘ7w,p]s>6=@eQss'Q.a~Ec6~=l#M1ة n1^Cmrcd ȃι"=ūVNUD"A%5 ჷP(!D(7ٟDe<>mUyB$"9 W`.m9;9^}2'@Hg#UM 08/3gTJ@F憙w@?T} g4oni])\rEߕٓ| !oJ;b Ô囜 g4W! \KG?esn}v h e*lJW֖IzȨ!LʋdUSN^i)0~sH&:*(?Dα9A{v V $D[( sP%ȐZ6 u(F疟Hԋ<(g34ap }\\>i4/]XȿȩtRTl@b4CYa nm%E)9w8a˧&]IN}*^vsYLh"T\V0)LH8o 06\LB7sC?@gE_ww 6͆,GHX3_s(xq AMC>!@! KAY9(^Gor2xt"qH\aٿIVE=.91P-1}U)j^" XbpI`W&4J#@fJOPlQi r۰T"YWD'D#AŽ,ۛGJJ0~͑S"O%>H͗׉$z~E%(l?VAHHןjѐPMXSD#k'f4`T;YTp3'SLLĝ+YU#AM+{O6-=1b"_|P qfDc)-ݓ/NfNHխ*3ҴX^6zh5 ƥL2Q] dCtU!JFWfEPހ=W]>֙Ϳ25|gީ^n #Yb?'9ŗFG'>t6( ԉ+[> sMCͻz6U|SNI3;Y9Ӛl/Jܘ.n i}=PP_,!`Q:f^mVYq]?nw )T91=*EHA^hyDx&A >JSqԣkWca*Ew(DGd.]iQ&dYMMr]aj/S8\!V:.)k}5 @}1ia#엀)&4'R,ϋ1Z>R(R.4lo2?{MfTNE_ܠ^0N]^,{kx6]2ǫ8b:Zg@QYak0:+džZ*֑E2zNo6M+l54u"\h tLbB8T6W,4lI ~$Kj2ѵ%ؑ:vyI;2klMLsoFƟ}+&XWde\(!y,8 `[.Ķ"]&0*e/c5'&$JT) ^yJm8{eӦ 8ŇBvԶ:h C6B3Jh!N7輸e{'yC F +N"5w JjrTXlݸMv>W4_t8ؠ8b4*tyYmz^U6gqpJNZ>ȶnpߎ٦GEPmR$盫d_6xĺ|V"/\(vgۢSrI߮)[.;BeFrk06F(k;T1jTGhF0^뛦22R&FӟWAύLC D%ƳMXor=wuxɻЪJʼnnzjau~Ds(ԫUgѵ-yN}l/iŔ )?@ z(Z!Mjr{i!Q V9E bǖny/ssZo* ڲ44Y 0&)Z gXyY;te*pa,Ϻw $/ >]! [4V)h@AY+d9pń"Iʀno~'ͷh3 r5ް}m@)M=1'o:gܡģ?ϹZh}kS=[׺{ky7-i j*Q&zϞF*W,D)MWZgڨҜDQ‘Q2V/U_Ԕk(f<㖖ܠCjYYtɳgi)D(H5~ E*"{¯Tz_ܞ$7tK'Qf\^B ]8(P:Cb[թ:Maěfg-o'N)v|ƃ FPQъ_V<ےM#8,b #eSe̞Iy{X"dL@b GL1+N-[+0/<\ :xJYi,Qh\9L)YO`~6= M6I #+sA0㾶&gZU{ri ڷԜm {e"[&Jl(!f]Mn#˞:dw^1,_=fLL,i=!!3>T}8ͤwP-Q6f{^h\%'Q5m|.h Úb`>;.5lq [73ޗOIP:Y[; X7{[`g&oD+)P7o3p@eJ!*ԏPO9Id=-$oLxȭ$#,l3G(*YbJ'UU O{8Pz,)$+Rg2NiMNtSp]"w[o+^bΞpx:/_~prM%~DpI/W&EEsYე2T{K#qTŽ*:涪*FdB;/ص 寧1Äm=NM+0dX("E>]K੺W $UHUooč1}^5Hth}<_.F_RB< qwcW܃3N&p1$MMqjY7ۛM7VbOww.c &giQ&!!7٨/jIOfOVR<-9sr兮MN.#-$~jZrKM86Thw2/* l(V *DWZ )CL%0`,IrdbH q&d¯LG;؅K ofMBzPh ׆ {};/bƋԞWRzQŸ\uˍ0чO*.+DXu"z JX=I}#MW3xb[TgD7JJ k2?mNBlim̅)ݲOw SѶ:+n:O;gΆیC"f Nj"7ѠUDζ~]:Iݞh~|yB:V9ej@Jڋ]|;I6M,7)]n^2~}=v 3NoG;dYŻ}=fm:Kh>30П\IYftDĵ 9gˆ _xpTP |Ut _;b.rdMlEhu\z% T:ܘK|tc[/#4h$L?)9$궚m7WvۂM=M_lq_"N_VV#\D%v>,[}qz\]ϮsoVxtJH["ZZ&hTՎe^*lcX]4|b'X(Ra{I(ʹ]@mݰ37Q ,)UOɕb5e1ɀ´7Ir=@>Q><2roM ]uw(Lw}XSj }퀢w~:a #+T Zjb7 lg4.7 F #ve1Mf9FSe#ruȕƍf:,eE#+(SԊ;aڥHB7;H|¼,8j_Ѩk@/G@GFudZSS?3^9$+eM ,[bǙAQT zco\]6gw5)d:J%.xeĮ]O3ZeADuO;#kb+qL1g>*BY KÊ}4!_=RKˮlZ ^-iaH7!QxaniTJ[|U[.#@<Q`>ݿU蚵UJʖxaSJ9]y~oNb yr`Ղo39Ψ9,ÉiL"M__lM )%: xL &i]@ΟS TmO@9=~rҗJrWpv jf^ {wyFaSu=6B[ I?[]DB?acU2#s ~8*1վ]Ѣk/I Ż 3j%AHzUM Rt(wJ1z.Q2LdqS j߮TiW/pZPl.~?ԆhUSXƪ7{ᬦQ"*#Bٹ(OP綶c=C!Z7; Xr<] %:(ʎ }IkX B`6,>p K-=pDK_ @Tyg+{L2住p 1*g, `da^` 9٣MLd<9atC2޻&` 1GRm-1_ 0# ^GGV3Kc͔Kځf[n0q?^D߆sw?0SiKr_w6:X+.=3:sؾfò-E8L48܃ i)*%T03KOILh5Q5i,a4^r3>upI4,}Yތ܋v7:²)q 0oz ,[V?CDCFDXX\9P_<ܸ wNXq6+v+ᦚ^ XR§y.d(\{ND(<72N/ ԭQWgB|uیWA _N"J.~yIH^s&uDa/g -m<2E f *!}kᓋIK S tIЄ7ߨ}gBz^Sqd:,|_  "?Pi[,BM2dukׇ'ꂻo]>t.qϩҺR B6{gA}͓RsucaUQ n;̉,BlRnKap{ dc߾BwsXIlԾjӌăi~QfP H}&^ #_( %k]wP-y+v2ȳ8r90λ_+VWOR;Cl.6K E!K[i6Ù $% eEn)ǑMg8e4rw2)d$ƈQ`f=0يTYY)?ZIÇuׅz D79V >_"(Ys]Ű@ǯr!dV}pp˯r(ylİ)Ucǃei]*H}hom"~rP/Jm@J퍃q=-m%FGΌ}Ow/4Du rE$=_<.>2 w'_&M]4Z6sVp>:uԨN ^uN !`4J^f{0£Fgs> ղ 0c*C#h܇(ˊ$ä^hGiz?Z،H2 = m7`k(o6?(:HuH :S_g p ^(`♝vpuixPKue7ʈFCT"%*!<z sCvګP0gg[jM,#`P$L^+[=T\ok}e q\E6ԙR+>-: д0y=r>62Q~U+r\/~Y{!Q֍d=9e\&nܶb:w 91 E.?5_ A5FaO[@EgTbY ;= gMs3 lM(&ܳ#[ͯCr+e'd]6ki~B0f-x,Nˉ{\;4nSI:* i#WR>9<tУX_bf5OaҪO"̫^{VեW2%`ڎ]yr?:m̦\ȗ\ CH\}kJ\?"/ʢC@1)EWf LAV9,XW\AVX3p8/!(ufpyJAhe&|O6voUNqJᨪa181k=I|O͒T+^_;?|^P ÓyD c)%-rmAÜEĬ3` T@F j|/ԧzwqPvoAL;hE{k[XZaI`]V+"6fౙJ c\ h;c,{>9F#M/"֙8 [e RB.F^}`騲~ޟ +e{xCž|O?l;6q6F\!-ҫMv6,}жZoP+*(E)nF@6郪QL4Ew.`7i ]FC7E BO;Mŏ)`A eZ&1w+V뉯-Nr{![Z{~% (Z\n֦%k ֏~|L/>.H,vٖXn!*Ie@0 .Bx+S1>B$ jxDkZ8;Ɔ^1KDK꿇nΧ&g@d꘧̷OV>Albٮ&V_7 CqcKBi*1_D~YQ%!o,>Ϲ!dXM_G6Sܖfըr$g鏧@~1zҥd/;\e:!]2.&y$;#݄wV~QРh43 t]pűs[,M_iR]3UƵ[J*vIHlj (znEӆ"C gyS~ jaV=ab۱Jo>[{Lg 52#_s"5f+6bdҕ8=}jQqe8J(]B %d xI2--B.9!t{̀RԆ"Wr7~r Q^3c (MjNhu|sJpYQ;:|86;3aPN ]:bi]xM'QLS,& &pڍ.W<^NVH\YubLo\ӝ]'#g+-J?JN 'kvpq\{S-% 1qJתψm< R;T0c{ ҙOzhx5W# e%ynX%p!N R ZW XCX8ń?,QCLHԟv/ԥp:|9"}Wl?{mYarsis <>Bl7RY`9;K Ǜs%Ja#Q7u?@Ju}'MPziعfvzI|t?7y$M,=[hm̋=-fY~5\]FRLj)y[J$˲gtUTcV:>1"?[?ޤ&]F2C'³³bM4! ?Vw]<柽/ZR'ٌ ܎|VH%2u;P^6":3y B(w,x)JEsS?j~T*#Qh2_~Un#6"NUPӷC!; -G-E|0cmGSGKc?T,Bcgѹ4˰(L)o8Iw]'s4Pֲ3thm9(j(> ?R.zE3r"\M0` -ݠ} %7'2r]dr{;"I)J>gG. ,%ތ}ۗķ+Snb\8B5 ܓ PJY Q$*R轆/J#$hƁ 1V͝gB-yp}!!*N7xODXwy >.H潺5UO9 N_4[~+\*2Gjw:&o0Q}ΩɮȂt~8dxtѫCkk k=a*q+du!_]]mD D볔i,+}`~GJQ܏/ j|yuC&#.0F<"'Tpr.Ws48^̞74~EʟL <ǧA\5]5yeO sdt<Ҕ؅``wɣe`̡96BxE_qMd_NSj!> #{3˦2!%ߙvwĻe5ګd?&U50,w y}e2. Xr(a;qeHzp/8k ;Mp(v !} %l#y d=m3N VK^]IHhFmNdΟ+]Zb +>iZu]R51x7C4;F͙4Sޤ8\K.➷CLh6`̾ Ҳc%cSIZe:Ҏ8%=k}tOujn8X>hnLr 66'{w%oHc'"H{]Hd_' ý׽F2ףlZ@>zJm9C~z3u ,>0)^7 DUqpiZcE$a/yʲb+FN*VZ "X$YrSwTb* 8nfc*gRz[8\zi t܅<ǑltAŊJ|Ah^_ԓ1ĀEL1T K+ԅ͕4 W7];ٚ|5#5?X#,Rʮ8Wl,vt@h\^-zWUkI=a_T"jYxRN >U[%diM6 z*-}!0' &7Jv ьv]xĴjޞZ<d'WCJ(0N\v0ɫ(:$jlT˞(H@=Gq3j ]6j>@oSRӯRbR˿>pnp@)(%p? gK̵V¸Ýnfc,l?T^#)U f.iaտ)RX]dXL#SD9QSO} Ս3U[jqrȇ&rZ1FA5_0`4;f^l,#SzY'2Bm 8o 4u O *t^g/I3w ;[zB qnj: 6_DE,Uv -g"˷\Y2FVz&"!3Ћ58CkawjWFgW0A-CV35Lj);B| aj")6xW2x6dJÒ$H%'H~5HyuP^B-EYQOr{;J_K#v.?zHc- a#X|Q̵B">>[rZҖbCcy3`~~LzAjVwa`N, g'+Orqۼj3|RO^`[ AqXA3veRber rN0 FҰX´"Tiţg0xP i960Я42HOe2S[ w6vLBztLؚU|e5fID`/u+!}lR#&-oIijB#'SĠUضof`G^I̋ꚐݥfdXم`v{G)k\Yn-x q!H?3*&榹 2dl.h R;=ikP)Rx fg&l^)qGQETY@pUʰ"ms/bޚ :/|SJHx`Epz«F%Ǽ>͇xeSj|`1Ժk7GzAil{enp.@3Ɵ fY^!x_|k6Ǒ9JKOBy|jIR{A`xCgkYA=[Y'ޔS}3z߳6i<zWA0>dkA&;DxCVbCo6G`/#H ّFuh++ɓD #@c#)ctӼ+ L8_H۹FdzCF^RSnӍSAӋ} '!ZKmP MV5I!! Gک.mVeMSk6pT-:3(Eq]H;se#Y7A/j(/ag+yq쉽)54}r\ EߦY*?T2i > Mr\ jnÕahܻB*K x``Z4t==߁v|.:% ެ BD uHa7TaCtQu 1 : )L"*s" g ;A0 R1>idww"M>H:SR gZ*$ 9: `:a?愚_@;iwԝu zTh<ʗ\hA͸Tˡװrڌ5E=t 7؃\Leuǒ+x.o?-_6_G7@dB62-!'(l`23 pjbao%6Px|5 t5&{?Sx_N:Vl1QLӥG`d ^+5b5w@VMsDd­^ կ&qy#Ld`}a A`dꋔ Ýu vb#)gk[J@2OZY[@VvVDc^7_Z`˔Ւma ,#MT`dv[ PX0S8G7:v =xߪzyP:J\7iY^øli ɂ]拫?Lw7='4 ̄GO3~gp@[͌6Nq$@cJg`Ёix5{X0fw ӥ4|Nr[àިYo$$ݵHQF$<Ve[%A{{tr, jx==Rb|ܒN ^~pFy@ :حVlk=m1 cta(H=dž̹yUyMȔhzq ]8#ViMQPiIsDΊLptPBKO^e[8GH rnڇs~Rև ˈZ>HވKz":" ΆCN??&ZhxuFAHa@{CdIGuم C|S aFTvnuMPʴs݉D+^ :r[Nk`; ff? 3["5-yJ}/ɤ򀺑Ojy9/\ /G_=ل Mt-]E-D}ZmC4 v^Ӭ*%\Nn%W>~q6K>=ZU\qfܐHڪCD31I@ahP0>MgjdI)f$p(oRB:qJSwwb򜃸y"_KԜ(I5yn8oJ9q"gmc-nyV/2èo3j ?=6ؚ RCs/Vi<&K`0zIC ԘV|}Wx6.V?(',^8 6jo+LNኀ%0V$%y2@JwMX"a;*],hZwGa y&mF7T"gs$*;#gmGV) AxmMv椈ھpw^nf =ZIuņ=<>*Lj@bGxp:٤AOem]=R[[dAD8jPu6P޼&:+ n8qm5c K @\vg jN=qh"m @ {$TdD< ]R-8Q9 OgpvdèCVC A&^'D}ûWjPJMPգxUN#b_CZdlY4e&lT0~4$u,@82r7%)㿼3p-Sg&4t/`T NQ=֏+x1Lmę`#0G*A\ |xU3v -Hz ŶfLyVݵ>dM=,G&>eF(? G+Zc̭?ĕ]$IPXwãFoW`b9Oqi Cx8  PSl,2+X7S\}#R)fQD.E.ʍ}|&LNA& |rܶ|kGOTXqnNwH|OUjp˸u=ODuz̾Tٺ2imE=M=&O"7?< t<vTL$g !nzcÄJ^⊷3RcL'ʁ0+&Usr0 0ĚķI:л ҃亦9֤aav@33N)gaC;^8;*zhrikb=Yf̗w!cTE#<~f) -XɅLxWSP]lz'܁AZk,Jn!'Pf$)~du6jO] pG'c 1hIM W`1-Ǒ<s[DYH oa4ՅϯG^ȁv( y4ve72ShQ!!Ӝ{RQ P^D [FqcJ ֟VCM@̿{\Vs`L L:X-ndW\ѷN9>gw JRYd"1}d 3#_Ԁd8לx<^yXK (tjۑ$+9EƯsBɌyzor}B9w7+ \Y[ *챐Љَ*͒lBUai|;Al)I`_j $fkaRv I|!0׸4|o`wgfWrCye3(1xlG=ƜI[g۩ypRQk~{)r|8aݤt_ߧ/w F;tq?uLzPc vYɨvm_ͯSſB!W.5e€ut;tcFW;vԂZH/Gp(2HdM29_V3当2oc5 VbY=&3Rٷmꘄ(_e'G7,1jH ij5۲N3R Rh׿hJ#vCL["(st\inYO9e!i6TO p%5p@ @I`LStÈ~Zh:.ٱ:87FR046*VJ[,!rS5As nM +V>m($<2RH.寽y&UG)pLŦ#H'ϟ_h-Ɲ Y[1qJJ1$yqEO7xa;V@4u۠='ڥWrujeYWg$Qtݴо9IJxnH3S(DF|9xbSGRˣ6^d ӇI'<4Dru+VAļoL;k5c엶GU?~Uߑ  ./rFCDrF1O7&XR-+;24șr/9 ePx "<]-E! n؜ש/|AELw8XU/)a +)ɵcwPpmkYf U|Lf7S~w^ݱ1Qi3}zK *^XAˎ$ƾHWK0Gr߃j̺j)O%| $R'2GDr'sX@̲; 3Dp|rNA?ƇLtmxԵSf~o,b &X9O![ yspiJwֱgJ00IY߶"]/@򽛗bY-hM[}]SP6([k&uτ9=S჋@8>KTre'Rj1'& F4^kH|JDsS/tU5{F@+0 | nh!#*~sQy{̜,?~[Vx1w4[`>IHf~4@oY_in5S,ǂOe %h^?d;B~3h1ݴ C\Ćz{*}0EtoRH |7q[\ƨ:N Ʉ'K݄V.B%[B1y g4yuWࠝjŝU/N[sIEnrL<?߄ Q.m \Zrت>adj1J;L}x0!wM[%S֭Đл_'VI,nH8y\-ij$ C^T zs/yx=)P4i!"Մ)~Nw-Wc긾΍2Pk_Or?h n5vhI,l,q y2Ys^ҝ$֊Uֱ ֦ura2u%,TNzlEVIBJD>ni90|̣RGT-f1|iT_|,8Z,#tr>s󬛙:'B,ؖ%ejٶ4p1jh@^ bE~Q7F!D0<#_'[4FgKʧN ž^&ߪ8WP2L^K7I& E- oV~;lV8L@fJKC1)9)95|INI]LЂ:fUxyusc'a%~҆ؼ-%sx]~H&Qc_ڧ&5}rg"]r%mTy^9q t{Iyug!=6V*  V=}.nt[o,OdͰjs->5Z5]G=Uݼ.䠟3y*Z#>0wqxcF7y*M(xx@ MP HG&щZw$m|Bh] ْPJ}34r85+ێ/;bcԚV25LoSmQ'>"P7lvk(17SlNBRyc)`)p7"D f,vP1α(q_c3K=$l! N2vmxd! G̺%_go{`(\,QZFm ^fi&=r@(H1"nr#_GSC؅dWPfeT2ԌQI{T8 dz]RKɭH ' xlp\i !&QR9Rp͎R[MlN+vi !䘡e3.xl 0"@ eVLA2bѸ4`_%>Up `w/9~r~wVaof\E$o-0}>hLij.ia+f,yhj 潞r\xAut^8.Gl> 0xO!%D&@Ѳ}'t5͟Li$i UgR2a|q{&F<rlS ApS\KjATL+oFy!ԽYW'V)^"89?wroiնvY6,Qy]Ksz!P< ÉDi Bϒ*+RB"\2 é PZ1c @cwCbd:UT6\ޒwznF9pG@r+s5"" a:x@((($`[g[ܷ&zz tw!36n)Woލ)+GvWꆋo$zTꚳNgcYkCf7W9S~թ HiPG>Pz*7 Apn\<|3!%2pJ-Tw|zw4z76vLv㚫Z)j3:C9f4f<;Ktxϣp+c!6wiKF{0QX E;tKIy ;QT h{׺eBx%qU.AǿXmVGA K 8[7 ࣊XT5h`ٜE { -Iq}bQ&cdX)d# ?hY/Yj"q>pu&gr~[̢ːAlz~zsaG)~jL6VI2P\"Z8ř7;[2`blhAh|G `;}|B Spek5Ŀs';&/R_cK%umgRY*Waǩ^~щt4 fBڈ52fGO9]@j3 9YM%f;)3r.x/|gf =[-ʕglc(`sݡfp7ߵoE~-IP+t=o+8 KE7]z]Sܽ&G` ~\tCcw3T=5&0UG&m)fˡ.tƨ[4+Dv!~A1'@ s 2q(>ƠP&q KoSm!&v 0?y&p_ֻ5o{>ϑd]t!Xs'A )܇h v4^tHwU K /sm#2) $XhȾoA2$UkdˤN-+*H5:+no- Y%6fbr_`j :͸ ,Cc޶>y U&R?HIX͇fiH n+M\d_AW+r0x |Cxe֡Dҫ^*HL=gE)紹m)G!rnu oSCD>@\LelσC2A{2V)D[~Qx,ɗ[EVQYb΂D{r\y!;ig-ަa KN̷>in!!#H;rWμ]6'H Җ+E]2CGm)&2]FCz7) 1#|1@2!Hla3짆"" %ua\y;!r*'ItIqunpMCy3O] a4V%wG(eIP] )XաK(1C:];-m(ٟ̓S>U*>foR6eʾBHZ/v(ūƙi$aē~UAC TIJg/+7])d"ņ[t5W`sm+WV#Jj~OCoBSž3ϩ5Py eVOM%1z'ط 8_ljhAl'y%܍՜ î/4h!i[9*zxtب49COhd5(qJuaѯB*dŧ^*7"?6LII^1@&#V{N ZFY}".FoMHCc8iI[a[JמQvxZ:_;MO%t}wcC"sWKs`E1G&$/',:P=p@õ+ŻoŖ?+mhv #G]T}D&&1C[C܋ՃMYK؆u܍rT/!npJ;1ܙָ܃K>o)S_W+X"IzyUq+,/<) ( ?u]|/䔮.\sA@t(;ޖbL;DDLNbIHy9p'k TEq#;jp7Q2; |Ɩ!7X\L8'zla]x~Id»Qw a3Ӓ޷zzXj`#V:?0tZ홦QiGU!%U޷|u6 Si̜@]&3N*^nJ$2W'H|xSd;,Vsb;nTܪ/z2ϋ]TSɩ,Q"Ӕ$iuߣ~wà4ŵ <^+q%` P?ޮB2b㑋X?exs8Զ[zzJ%f9JU[-'jFۓHo<<ߠ(Fu ij.Xf>eTQ"z%&y6hҭO]jRh=EQ-H<r+OӴWUw ^{@W>FDDn 'l0'0,<OV-2 Vh9uWi06gD7a\˯7Om<ݥ/@EsުKR|:hG`x?;ޏdJ#~ [dmרaBh# l6E7[tT$q9I6S`Y_xwralaNg9=΄$8dHVM?2oCo'9ZljUycQ,H3!%<¸"߿-$qڭE8ßL3iH??rtQpe B+!_Ti-d9<^Ke *kKK覨 !~ìmS\B,̫f>]yFi?OXRAE^Z[bO]}ڒ.{vEzZVtw""]xDhDCZ">!S70zDlLق"FDo=7-mtAh,=akiX9xpO!lP9 :h΂wfy y;^ڋ*Cu_U$v2t=^ +o3A;ۊwW9ȀDLwCg<&Xw5-ˈ''6|l%'OebT r9oțMd69o&/r p̺Ʋwz"HFxˬ˴;=F)!Y=w!8wI -2%}h1(l ⫞cH%7W||핯TM;E- <Tܵgԟ6st qPeߣ锾fhNLhuκȡ3 8.^!DI\%K=FԶ:?̚h\e8]^$8`-4_Xz-xsq?LM(iǦJn;Ȅ[M 5dfUL[+5jͱ!-\*[hGSJĞo*\UHtRcP@+!2ӗt/fFjq*JKNH~ِ %EK\bc`:]A#q#٫o\_fÉ4qnøL̑MLVe-S!9Q}Oڲ|>lb{x vƵp=soڬsEҼmҩ_ c8 c^lb=zs섛 ݐ!ZZ:$ϥÉ^Mr֟EBFKC}H0f埘MնKg&ZC6d-fX?G)]Zlt7k{27ӽS#@U9 1TKt`cJ;:C%V{01kXH9fDF,0$OgZ?=MSf1}L, ۦD?# ~}t9-(^1Q:LR1A<+_bPxV K( Wjb,Ł$#^H Ayg-4X_uBT\Ktb%ELy ®OU2 a' W >FfPIu.FZh u3NGDa/򬦔J~OA5Sn=wrBo*v[4er ȋc]QTV6frTX&fWͪ$~C4s]S-a 3y#w͈5Kn8t-s 5C4L*Hj*pKC@Zy\,?2e\q;cOCP!̦:`LL$cqId iՙvB!Gbk%gPcHq3pcĥf(qC+wZ&U{U#Չ3[w}w%ZK팧I;=\o"C<ሶhÅjf4Oݝr i%.PHd|N!u>/ڥGj8PQ:!rXv:<)AaiɲQl\S{`x'u U{a7B5֪`;j ǡo?($D5#Dڞ=.j7>jןXKA Wx }R+7mZ vaj7oD˖਼r,F(5*H]{Ád?`/YvYqrE.л0x#X!/!Dۅn ZJtKq ];L%fMϑ#Z"Mxx wYԝ#!{v'ШRyC{KҞ')MaMa׉ˑ57jooJSRI_r뺾;S{Xn1ad UHPuw5`.`H8S|e&& Ld;>P%r;{ɕ_RJ^EԬ$58C}#̑1TE|YH 1:9z+Mizqϫy=NJ 1xxi u >_DN$K3~ms ~ߤy,~Ie{Miʢ!l@ΔO&2.4 h LN*0iҀtt >L&$ Z3>9ri;U<̻` cS5j6Qs~vWrXrCKl*{&YওӛZ3WF*IyT)V1R6TTnSZxI*"/mQWy 7E8]3w[-4`Toۇ|ĒxF6XHPBCjpY8QCŋ.ο "x'ƻݗ= |*[̧T!L*\| DuPD^4dR>/M29w;ݸՌ?Ӗl/$RF/w0`N@M#77UaJZjAZ jIxynlAq{>vJ 'pLZ_s[=!QڹSп7\0jgrdBPw Uq\+vK4ڑuڊPcqQ:64p13] AFrL=Ӷ;:gH+6T lXOBQ$Cv0g {1p 9['g&0e8+?u2`WZdj[\_hn(*K~+IOooTO gB9 [ AXi3 V9;@P)?Kg™ܻ,;"w[#W ޶,rStwg b?塯W5IJ>kGJмU]5}K`.}MKΒSVimٺijTB'˴K{Yץmt ?+Dwai~ܰ˹GlH:,9B6st:< %l1MU &?JIuvO>4Q)l ,~#`J߆=JB6P::jDyd46ZkMԿ!x@B3w&@{Vl#UxzLUN-f;Rz: rM\j^}sDܨb;E 8I6}Rt ި'ƙmw-hOLa LuȾ < %OU5Qjeˬ,'EvEMpKVyC[DXw/pK 6~&ʎ9Zk6Æ)[ $˥DX'lO @Gk#@`!~4bHu%,qWZ5VŌcUD pv!vL "++~PO!ϘhZh㾧OETo/¦ gxVjaKh%rQ7E59xJZؔP~HiDz9! :mi!D΃䜰lĦ*u5M$]x^*L"(J ߪoꝃlnzľz P#Fyt%HnW]eQtyP+A+#i"LnK[Ge1Q(-ѷqNMUlhߜ϶;Ap 1m@e//4&qܫXW:,Ѱ+{TpqxI%ԕ Y!2#%vi, (ܭ~(.9V1+/)W)?DMV Q6'YoH`7RBJ_T'JFK`/FNYoL pL+HwS<SJG:=0ajtP-8 ^ 4#hf9LI-hEٺBrG*bu{77.ǯJҵ1a7X^b}~,ÈD/; 3g0p5ݚn Y=/Q7j Mw Z]VF [SX 6L`'CRrYTSZ^BxAIu^|•?6/$?pe>`ן"-9V Ք?63Ω`E3 QQݗ^ Nٍ9 5u1.ݵʇ|J}(4 [^fK0񜌘Ce @ji")]+Ccv< cXCVb]`-y6?yV1܇r.?!;լ\R2a8}6'"uF?#CJ_4P+Q}khG3F ۸?Fv8[a")QHQv|NZc(D P9=OW'!^H^8z*`Kg!K=2E@A:)g6}5dJg$Ú]b.>Zw?I5ju+hF]16ab被zS1xO\t*t!k 8G27xY~ߴibG^Xnz )bN (洝՗ cݳלAԜn԰ّrz~C}$![J1aIj2kYSFճ2ĶXu [h&wJy<_mhћ0V (BzOzA4ޤSg~0|U\6n($! ɍDG"u\3ٛϺӑYpUXK_?>ͼ 0ƕ*)e%^ >R՞xT av0K]w ȳ eѲq5'([&E"3yS+xu\{biD֏siPTsqQ'x41) `Shb2!NnǸZA+CS&.Z(/ٱ8`$Oph߯8Vb "#"ЃN׺04"_⫮pƽǚqqp?QST4n+ KtNkdWA1,tEO"YfQT2Z (ФAoꔦQZ ?N p"P5w`)Z%_>ȡ5 t>~ {A @g ~C2ף!;۾0".+1wfE&_‰ӻ c1IB9?9k#fnFϩ&kd\z)}P]xքj_iRQ&R@"4LC\ZDraTqd7Z`4~veŨ**]E3MN]H[r4எ6k_6.$I3cid$z`vI k*nnd+يfS@}Ak[p6V%F"q8ͯ*pN8b=FHf·?i>K:,Px SmyxeaR$ z:c8t{ 'ED]*,%Bx1iu^ ;5C"F1jaS؛z ؐ'xqi+Ѫ^k6^%25=)H5w"*'e$R)g3XfۙƗ׼$9^)ܶ ZUIx&ʿ'SLz'3~%J> Q.~?(Try!¦t j#+x'wnh/.IX]x~fLpgsEH5)ImE-QV\ KYU*eYlzBÐBV.gS.S9<[L@b$i=68F,: Bs.:EYfkYXb.O'NH2BEY;Qd .$yCH; i)5"GA=oxfpgaJ~ y R?8ѩi3M3GF~ e@HʠUyku/tIvȀtT/P6~>" ΣU>2y {Io-u5}ؕ'bQg|l⹙}"ݻ7@7Vm?TkYbo!P{ g*F U=)Y4z*ј"F2hΊ=a(xYfkێgsdhލ_!A,A}n5:(MeK; . ;2E;<)|Eynѡ!9wEqyX={  cDP֯1}J!u^qH"S*ā*BsO1 !.ˣI=jl[@NJ3˺’"ޫk}%ZȨZ.rX_Fj#e6:ͯ/`vSxKҾC{>[vOdWR"Πco LJn ^Ϩv^OW4`z 6fqO]叀qRwkjֹ@,=as ZwOqPE[nզXS?F0%S<7D/#j2$u=CG`HϠ-K~_9yK_*#; 5J[6 |gH $ i:W/C cT(,*]Ӎ 璍^dclW<,Dw{Ф"v'ڬO_uU I.dh^neҍ]oW|! k0Lڴy3W78||5՛j1f)gHmhXן>Y%hFH~V; HlyA05L*lZy6*ٻS\b+#prFM{Ikv!;kFQ'<=hyZl$,oL1gio2Sw󛚫=&:$6IgFGI9J>TC$ƂH >[ߦ_0 2@w~"AE,lv/y&؜'N Ҽٱq{o;F\Vv˺;{N(fL(pߕ|jH- N>qcv>P߶O.sig=SDFa3oRDG* ]ZTjѣdBO}goc=48τ?Į2(rY³8*v2lo|2Qs>lV'AjlϤh -rҡiƖ õD-lc<*lZ}?΍eQ^`ל44F)FoԶ8ckb}2A4'F?m5iBC7_6)," I-}ģL*h Dc We$;vr6Eez@$8y:R(7\ѥ>vZKQu־"n6jr f[Y"\u+U_5$/?[7PQ1L[lsd&Yd(e @_YҒ ԧ1#/]z4][BmdD*3uf^6(F[׺*BJ;"1f9Ri`ܷpDcqd` 5=."M/J c5|]EZQNغWJ l55~ @p{<_bae* ڝ>y.٣RlG$*MEwޒC]3h]C[ d%)$.tOؙPMƓqDHauM ?>f7qQ>sth-<(_Ox(<`I( #PΏԪ"js4k:y' ]߰}PVcuЖv2d?]V " !%sH$3}39Խ {<7Yfy]qPvD *4d[e\Qu#@!.?vwo9G2^[kD:UR&@kpm+ &k6`.(߱WY~Ε cc\IهDA,8֋%4t12S"ˎ]Ƚ&F$r` i<~%LdFunda0*sʃ U=h ?>ըJZHWLek p1ͼTFu ^_c"D4:S 㾼!9%*Imree&[b% (Xa><!%ЗƙAg~rڕ^+[vI)s O^zLtKO^/h O-RZxXCf֕rKh"{K?jL0GbUi`d5@4'?Yd,i)A'IF!dEgSraSZP$8>t$jXɟD7-@dNI.uie~' @95ڶ=(>օ75B3E݈F4J}%B8"Ksr 8 s]^6Vҧ)MoiFژ-mD2yaulh߂lp*U禹XHfmW/} $i =%w>V/D˼d |]@ }ɝ:QnwjVļdȖh-e-˓U( Iݎ1eao&鏿(OV; DNxG_Pͯͼ.mXd !|]>gޣIs\K P`zc^=;BEA^Y݀?Ϭ|_T \O/u:_#W8ˏ(_ [`z=3gipo̧47́is`U ^j~2 LjLtg|E4R':-YCzҼ|?.b;f+o3-6h}ƃ0\$/.V-7!pAMY1!q݉ [8e|ٺp/BgӜ)Oph"\kDq'.tO%$a![rҒ[7؛ nbui\"Sz<*H}akyB8!R[N ֙urP|z0{lsWpj| Kؗ@읥:{PPwR’v23 4D2)muW_q%=zƯ),CۇvO񅼆3@PhLݪ\%>4uL~eJ>u R奏gyMR)zpup? XB4> (Mvk,J!/҉*}MT"}M~l[sKBkvر$6Ȯ=6UwWF@V;_!\mm@!jSatӊv& jT{yA(NYS}h% !y# g6 ( #4T;ADm*wk) )%;AH\l6F]W:" YX˞-l^" +WD(90]e INv5@yz(o""qjPK@, v !HZPE+G8ٙXG ial?M 1bÜ /OQ67aZ|dҫWWyoď{3=d8Fȟ 8Ubv޵L_, @Q h"ѥnӥ^t,j6K?@&|SRl)}Diyre`k]3:s}IxyЍUvNI+y jJi6 cI"ms&% Nvא0 Qwp-U#@G-N:c16L_Hd/hx}+% `ίrw⡤' R\c,ڇ cHKNVh~6!f /u'_fv@byÕZΨ!cɄs Xuj[" ͕un.vfQl5χAͫn.M7'LH-DNΧGes>Ǹ$btӫ_u/4k5n>ɠү)}N,E!>X|Kϰ}yEl @Yƒi~\Wݿr =pKSٯ~㰋%;X TīiL:EWjs٘+ww*^&D6:EXM:%[Wh$($LN߳kYs*@~ֹ]ڬaƁ9t@8l-; j̫# sݿn`ܫ<Bgd|IWWda6bg7*b;4Î;fC`5w`\1NÜo:s )zm}GO$il>z CoRSTHZ)Ab0p89KՇ4vY/-&" uX`4w+ Jn "d3[%<<7'>v) 9T#Ȑ%KQ!]I(MObn _LsKE2(G6 H ? HJB P2xgP>%96!'5s][1$ҩf7JN~Dh nƩuFq/v./ծdu %Ix4%u.9fFV* ('x]/<_!q>JyBy^iZ%rp͂c$P<#QBiT FP3Y->/˖ Xs\\Vءu8$n JlVF@ZzLV߶_jYB Pw0\MV⥓_uAcϡD3ݚUh=_@SP]Xs rO@n("!+-G۽H~#s~ ϊd'd`m )n9Av0.Yx ciTǓ&xCB틈Fv|m),n$OJ,1.M\HGYIk*OA}ƛGt+c=Y: H՚ #Ά7'# 1SN_%~C?U)w4o;ѝVO?zw'@3w$e97ёAgய~_&z,\4)_Cc7+MBNN@u|r2["#>qS _Ak e-C) K!]t.lҪwl$sd?`E&tsQѵmi !39:'c8|@.,h7s`Jd^i.E!R{ݩ *CIE%Mx0 Y۹KRױi)'R['AmZ돾 @/|QGqQ7N2XDf &+Tp&5GK%p>'('7A؜"W5 IK (Tw#3z8v5`'ou,<-^>`K`.K_ Rה&%|jb I4^n ON)':+7T'c1+?{!Eg,Ɂ֒`}JNNiE% -^GK{6GJ]J/vwi' tM:"j&/{i)MzDR&"xt#9Oӈ ءЅLtI؍ޢlFq)mk7ꇭq3V/NF͐3rӁ¼PëjU?G01N;o0W5q2K?z0.EhayMJ_ּ7ݑVz u q?)\To?PFZ}$aOoE4eT+Lk m$Ƹ!s@õWL ɸy;P B R/؂΂YV>|#'q@f ̡!ft/^071?( TE3-!?J\5מx̐y翱A5*4&A*ַr!-Xb)߫6QQQS4@˳D;T Xp8c3겱G̾GM v.\!D4u.f}fҲKaM5pe29cRrmR- y}y5D?lӴ1K}PMZ\R]LJs}}Vͅb~Y6ڍ9Q" =Sr'i.}[|͝EcR:s]עvE:=c(#^:EYXzuZ/~T)z9mdXMX*].Є%,,gK'ms/ !,+~R(s扼m_i PxҾpƇP@inڬ0?1ZVt|% >FS8o]qd g.!8^<1n۱mjl-^5BGvSv&&ګ~q[N.;Ѧxjh(kEL0:nT"HHsW~M`\9b1p{-}ًJ°WbZqz3j] 66M+~UJx9/ζO-xD-zJVJ@Y='@Oz9 +2jyIO2,N~|޾/̈]Hf'bʍc /Wygh.ʮ8.ݍ^{Ũ#2|PiYT"+k%ŅgĀ(3DŲw[_ z@!)q!KE/5x}QI (,>]R[>6#~f,]삢`OsԭNoIh&p-]--!u%jƹm {Tl[:LR /1bEeSW9$,ϾH)B ؞xM* 奶GJ=H=iZLuXؓ)ӁvQ'ӇT9aδG_OYJO1O`Zi[[8o<܆$ӵdD򙨠lj7#oC]͚9Nxn?02WQm[V='kp~C [Ednpv{ ;q~R LkNg~B";td%0Ff!Hό+2E"swA\ "lSj}/nQ7:b|7` dG"ܾSn31XJC֣@/iJ:%xVԵ:TxvqaWX>)M=1Ȑ5kRp ]i.\{e4%1D>fe@@!͏py-HJUC Kғi%mn[OjH7Ztt4D{it<և^ܕ[*Oi__-hѡH_ d LD bC{NbHVA3@E".A{.q 8Bӻ7P,afnbUb}l2GZ9H[ HKqM_]DOUX+{E1PgJ~bl-Sus5>HC5h\S}.U.79;.1!,ɬfy܏$<͠/$KA<íL֧vi2G/%^ y^Zncm {s9‘UoI˳5>.CNT qo[lz l7;n%)3RXwO# Mu~5`ZpZp": 0" 4mԈFΈP"B+iz@i8:>U["/5>Ɔ7Y79 kjvoHf)r.cȼp' iӟRsmky&#OѴ4Noᰚ_^p[/9|/NI:d[>ƍuBPˢKbd/%K5p&*,{a)lJ=87c(D:뢮Klv,ln+uՃ ۧՑ5RT.( KlDʹlrX/ 5_X c2Zшv[42sғH2iM'A녦E6Zb,L'_\fC@jQEyrE.1݄+C:(cN'#҅>3+i{9 j;oˉw3UnIՖX#Z6[`>A OId߆yqޔW4~Dq)9TCi"۹9H{, J`aF</Mĉ痀tc0hCx{rLORHG,}6#4"d!=ɞIvTU;T-B*!P5|H8oԀ:~]NeH cuU V. oJ0bi}(aL|E2^T,@7(q|*&,$v=LƯ;-NvɱG5/p!3 lޙ'ހBUTb+D #6>?pϷ ]gx[ԞtT P}TřM/xw;h3{u #6hXl8`Ԣ3buһ/zFal# $OwfBQ*bᨓ|e XN D ȺRB-(W9Qal_!uTkzS%:ٝNx<|7R͠ވ!wD`dūgz@ƜIcދ˰DqBO# Ѣ]!q["}aC}'^phJdHkӃ)YVS8CO?h)e]Ɲ|OUo> us͑behA$ jդR'FBb='A9!`n|? 36G2þ/p_EXR$~AKSAt@^i."kgeEO?yXxfBy>uJ,d Q2frֳmʫ_{ F\QWoK8+*!f| M'!]¸!M)۰؆SL#a9>fCQ &P'uQg-)ZM PK\Zn%`cst*Y@g7&ȒKė40VeJj|&&Ч]v W6: 02LP-g{WbT&>t =v=G*EkyǯKi5"ZXJוY9[B4z +k\d"S*T|T!e\7-RLan3!S·:pO^ ‘dn+iF=[ϕ!ͶAlh-/4_c0mC/>pȦp#VRC# J%wc+n1p{T07Ke.%q+#|ZBF%y5!Vw/ݬP>:0-MAfjFx2 ^4:,F (~ٞZm~wXg)W/C۹ȒU]f~T2)4V14 _ r-2>&'- ߺ6jC.ױ-s$HMSgO0Y= X{ǵ蠴B]?lm\9;:b9& 'L C8P[Pj^q:*fI  i#?,KOΚO:03ybt>!#w.+ZJ)O6;Y(!&_1tajrh*/_Y>/rܛ85Ѱ'y(g pW}ni{f Ip]3rp޸y \6Com~ 7M" R$uhI YS'@H@$ G@!,]];jQcsUνL߹-)L6^x-&O,=a>t7Qi"mG%t"B$]ҘYou(tԋas7w@ąKG/`mS睦`1Ӷ}e1PSX=#1̗1?ufr6|C [hK ן#%e˙hjܬKa,sZ~ O[Q8};Y }>|:Ne"A%D192@q9?dF8\#0j5ֽ9 I)9bÅȾRF6Pe}̾nU6^9j +;{!6&dƻ I؅m5# RLۙꀱ>䴑#;ftg^_g\fLHoܠ=yPT~J2? rي!{ FU9H+]9f^son ;#\i Xqg7sPE 7Vo ;d!Jpw1T_ y*CS)bbϪ8m.`pv&{@V* 7s )$1tۿZ/$:CUOTju*guj`^!gWP8+wi4_ 9 .n+GؕbOM:9o w]ɼF`8:~q7"W<]}K8]-Z)dL®Hr+O$Cڢ3#?edMBKqȧt# "?bO4OZ:Ͻ EľTbl. '8dW4ZnU;'\cq|$(VyǕ=A泿G7l(A<<}*$t L*:1ZǝIo]Ƙ/# cmUȣ"0I+?[r>yZ#ϺfbTMKFgamȏÖF|ט5+Ȃ9_wzA:?橭٤LOL+j>Uᇃq9 (%ԎDSBQ5[W $G⽵h{O.%z~3Q}r·H;oMn³)Ѫ:3G$v#$gxt{!b/9-|?0Hcnɝy|faOPqQJ ME*zj.jժuZa*>3zEB'}s@$3mfه(&}FtX>Y$eɺNj}8hГk=;)vV7$JnξLThٜck"y|F|\Q3X>x-HGgg $ٴcϴ-%[MŸ%CU]1&^E\Lj36lzh?7?jD-#Px|w<]3de-"(5KPU<}ȌU ;zkyʾdi"$1)flz‘5T̹R8̓)B-)olRƍs -dXrKPѵrN>&YޮرmFӚ2-e~} 2uovh YoY2#67R]XcOLrty=Fp[P87,cTp_?\A"mǖjJpfY2JGB[,6:/-wbK# bV+Nԡ , Nz.<1+~TATR4VT8krǸ{3)\|z5y"F-V=!2RϪHͫg2Zu֬r4Ck-/!H6.<Ĕ4{Ȝ'ZG6ʹM !B0<' ) @0˼$#@ٚng :e L"f@Em2B, QGL%r åK*vOьWt/lZN <3Fөſ*NgL89L}Y}7oh=n*"I7 `hB`qH(Ef/ K|QasH×mXP@whר8JW։K]Z:S'G+|+<ؐg/2:>^=lE^_+^Pz0Q(8x4 &f[C" oio}Rz]hҸIP|(Y_:s3EHN=]yF37|+xhxt{*w=@Uى*Nkx bhI2 qV⼶FڌؑB %}t_%ל2T)MOeZ7sޔg{]Dٻu2+QKtNucPcP+OSdI|xTcBBȉa֖1s$`%] >MdO)p|uCG}S# NFweY1i}lt,xd/gK&Z+E|gXNs԰_bVǾi|tY{hVLX'+a w•]32!f/Ԭ1*qyNX+@tՍ؁m6pI"8\yPe{'w@.pg|UfՈE.YzĿKmHv t.J 5~s Z7cɥZas $Im+(_<#~8Qk^ֽC|F~* {i ċ ~ _ wG^ko.-Yye;sM+SebT?+;~hh(x)j2'H| C. %ڽ2q.yFN> #Ol.2m9nם%2'g([2ӈ] SI>t YЎb~`Pȍ <fK˼T޺ཛྷx>;wzy^(W%bWɔzYg634篩h2}gv_{Vl! "OVD ]ӻ 8lfF5OZO^>M8 3 ;Q)2`uy[$确AT3<)n xz`ٟ*~iYe/P<ݳ*o0wEY aDg)b+LRU4V̧aku59^AmvoHZO0g AZJY'q'U;z~OY! +j'5,]5(!Lj=+;t!w4"-_cC`6S,^Z~#mFp\}ln !|O,E`YN19^5CdXė 4 Ǜ(B3" Q,(aF+<=c0S""iyrbǸwI_Ϝ;aaܶ?7v/^-my$kCan@ju;/?W܄qMleevLD5! [r8ﷃԳ;^P>;u@kc e{XKK5>APNMq G&_Y^P%$_^RjO. ` },6לVx762&0l5#x%?/,^<2UrR!X~ 5x?uihBɀ+,,-b遘jA7>F(d_"}F) S-fᡩbI4L!B Uw}v1kOk^&,>R Q!XL9)-  AYO]qN9*W G xmV2`#< ,n1G5@oљٞwx{>jfPf#R^avC׺YbJkou2iO>d9g]88 -TK5< &Bļ !z sVlJYwTxbGӆ4;!;o"zMU4Qef|Ye$V<Xbn=3v.9o+hA*o}{rI QQx4hajR\0M\B~vڄYr fnV[mȡh4Aң <epV[q&M5Np&^aZ%gB A3%{: (\ \r y][.,y,Ԟ 5aZvoWZcP|\3np- Gd3rڗ:RPi@8 u|='3I7\iЇp}u)Cn Vl-ʝr-)4/p&sJO qc22 %A3Y"' *)(ZkĘT?Ir O 1*ۙA]sv-c]nRF3h A1sMf3JjD5<=_J i00=Q2MY]waH-ٻrUva6wӵ#X^-AE{pHI}z $/L$:{65+0ޙÌ\;AS7n &>LsE I&$9UPR6bu3>]u[13݇Q^$}1/xҶ.Zf!nh"]!pTG OdzN;IS_ima?qukEsm%,TO.}=VV$Fhkx CޘGai(ՙhI9,f)6@$(v1 DУ^NJU{˼z!. ,΁&WjBv|_μ|OQ8n5ŀYg { 2[GIpayF$7X::_6*RFB;>Ny[\%1prM;XI@|oB ~70zɣ@lY, 65[VCm5L<˒%QwhWcLA/v{ЭKun杗dN"2ory]K;w :hBmHg]om{{#q4/E-o+46/TK= եgIuTmkngY( 3>+~e=e_W\_4oD~$A_ҩulI-<3΢!ۓyR|+`:w$x晬Xm1'e#BSY9Ih߶4}J<1-C-d6Yp՛禪_MoZy~ 2 ~{[VB ה0_~hN­`7]o&PZq}rO vd]B  x-쥓=cËj:a9"=zEO՜_-|x?½'= atY#~2,1N]&❫|Y0AjqdFf ԠK8zyYpz[*=1Y #Q{su/l,R(@FD J8s(((]gcM?.:l(U*"e8W 3 1Yy'ZԿ\@-k~ݨ ՞jURYƮ: HL#;|)SF*լh1D(5* <\0>[AwݒފvsG"Gv0_p}}ܼsG(Zg0!{<ٮuH@XL͹.?xzĂN8BҦ^ɗ#q'YV@e'CsS`4r%7c~`gȳ((Ѳ$2E€Yh l]]VV ]d]L+ohN4|GK9FC)Pߚ,TuV"N༧͆s/iݓ1{XF,G#,9pHk~ij^}Ud!eP\ŒN{3qzpAX"("^v ARtpR#ߦ4W׺ywSk@9|F K*i]ڙū._C"4`6cCLfׇsCg/|?=dۿu(#uQk$BQSV57\*j`BSc/|!ACoK ۷32/&74ۜ'J&f;).m}@l8snwd筆%8*<JKn6ezgoɡYh*O(I26=ۣ0<ۆ x^5:h?14 S`6w4.j7p J'^ ș%n.0TxЖ@#%<Εd- ӊ˻GJ*T\NU PpN*d NRU>Pӕ|^mI},h2('ζOu~ )AǍS#E`OpS\<֧'p42k:J.r qM&4^  I G+b`{7)B5 եO)MLbqUO&j{_zb4A|Wsv'OR\uXeGGSFHzKe. P*%LŸGYw$ZVg{U8fCCSs˩,O^ESF?QS)vVfE=K ]=iL$+I2))OwAX9` pEz|e7߇@m<׸3_0, o.Gr\[q{é.՞U9̎)Q3i WG/g=;ApUp\]&pӴbYN+ctIő1'D _lQՊ f$ }OY?C %?7Y܂8zjL'9hv"FRρ  j%Q20=Kk` zbk_IJV(/4AJf^K22̏rH7Aχᅵ&v7Yܞ>bn+e℆JW;]lXFRhSL,eYDl~Q[ :A,OzS<_eR`\5qn>ݤP]+6Iŋ+"vm9,hAgU 7nwnjJAF?wᎏ>iӛ&#Rnb#?Fd!BzB\ u#\ NySKk[,LVұ$Cw$V/_T4/>xGt\d0=g1PVTwA)΄_F4?wQ[&JL"5[Kcs>A{Ɠ;m%/3lW;/ KL3|A9fؕnJ- jQ ;0rI%`[]6u z N^n[L4/U=3_(ƭRƓZFWkt:,vP#Jq[JmT ;PtMvͩ-+6B %Ȑ ,LjDY[^uGp<  H= l8\>kBr] fƲx5~+Z_3/;C]]p{5{]̼t(ٰWN4:)gV62eֆ-V%}S"H29-؍v/9:椋 ùlq9/N(UFtD !Zɔ`*@),xasֵj3'Włe$`P:zVi%a uO^aܷ=pxOz>xϟ#9 "AϽ>6tB{.W!YsQ(vH/_\?,0?6ݡq(@kL?IJI-RYLϝ $D.QW/H HըKtuFPS kȧSsx+iaCL2^rxJ}/AuphV^:2?5>+h>؎B%َHhm)1j7QZxVT@t`@*BTУ}s?R~8h8 "\@(DlImg%w",2f9%W ?މ̩ˋj0{2YG8fD;&PPX6\1V99VkQOv=P!H҉PNp<-us)YC[gӵ1ƨV'(r7Q8e]r I??8j-mJhqg">JI8#~ 3dޞ4@)%/&2Rsk6Od=! ?qCL~${VXGBm]'޷kءv::r;J'*Gdui(;^L˳~oc^WEE+s7Z &¶90k"Be6HƒQUf/Qx?L#~{l{aϭ%ѺXxxaS Qd`@ ڈ=#^&uL_Tm2]p*C,![P'?i%BmزS3} *Pmdtv0+dᩢCw&hROثDHIؔO )aK/&^9c#FE`+'UJJSv-[.( B|HbQݢtQL3lYu,WN'-X#T#> <AN5Tw)/Hw͖aZ0?jXq«ASTvjB3(737B//";KvSoWa[/~J wx0+˙LfZڑPͳ-i \"ˉxrBH Wg YdRUX,a_o$=w}9 5>+PG|/C0 [M9grrR$歜. yB_ jgmhW_q&8'HR$jVK{%O4\vk 7ťº4/'%k|%h߆h]1Ɨxy :fULfQ +UPxÕʭ<@LhM 1⟮S{u9x:g6g&nq e5A 7<v $PqXU`GQt놬{;coXmoN(  pg4M@#ث8|HУ==)dFLhܓ@Ag9&o0TfFcǾ,F/V6%4}OK*/nP2l>yD׉ln%G@ %jAݒԒkEy|D*/4~H aٵc:wf QOK;4v0ZD-|=jֳpUDDD ТŒ_5gS+ iر9'B [*`H]VELx:yn8|,P#=SXB$7"\޶=yHo6Sλ/:؜$AI+CnxH'3" |lh$u._>V@>фdME#"1; \"4Dzq Se9-M`#aӲ\jc|'br:uŠ.LQo>ݿ~%0O, f NFTL ЉvQKQ^7[QL,ʩh2諎_=5R[XTħHg/j֢ 17rb0BƜ" m쟻KXFЖ,7/'0;OE:?$;gu& qx*%3M/ȖCxVgzW<`fO;)3i~<9k=j^ƑfЭ[iAP GҷzVpn:@{C}^W]!ԢW҅m$>\NR~. SϿ/<-Qtp k,=+5xޮtq65Sj&sӸh)vpWi >gFΊ:Ez`EomEA遌 lUnd-0P?Nu"eq%V9,gJR×M|􂨜JES&!Vm8wDNot32rA5$8t>Xk^=,^&XO1aNT"jԺ?cQj/?*Y+zݬ3EX:|'Z~@܊_Rs`±.#Ι*$,i۴Ua#1aֹ]Xa1mVj<7<\i}7PN"[?X=]dvwpv/ؙD !F0( оuN1Nc:NY_L c^0+@xVB)T;CH{ּm$Xؓ]?{ G+8pFA~"Li{!Dph3r4iZ3@ '_v?k5s*e xh{CvT)6uN>XCZ+iZMY1e2i//ސ9wEA+]TO9R)&F 6j?YOƒ6< ZJ32|W IԐC:&мoH 2;GP}'IK*!D.gqt:nucHFidҋzn;;'ssOpoX#?(&6o6 t,$(ZPMyNt-eUkX`V*!GmI$4ރk;v; Yݺ6$NNO@]9NA[YЗG)Lf?"-6Z/\LH<>J_fZS+smtFљQ$XK^ RV6 0J7# fwC?u֛I4,0R,{D2F"SKUό(ʢl\H]iL[ ~}:g;9ei<̇zMe݃9PdWi)}Mx3sb "l)eԆ@`Xx_PzOg-{n/)g1!N[haA$ёy PtӞ,)w o$}X|4?; `K8Q6dKgwi=24@3-?mF/`LVu BYJ(W Io3|+?tm8쎛nwLG 4OA {$ Q%bC蝉,5xMgmMGGuf8C59,,^Ikawc/h"ay!x5w ӛa {M5sȮwƋBa4 η*}on 2۠Deޚ-4 4uw#ф'°Nޫet$t"gh: -qleoKfnL6"9Fcب6ɧ,V}IDbmgYXHEw*\|zhjRȺN1?Pxqj ;3Z[Ph1Px* -Nu0}QqGKLq7Y1U Dҟ۴$KfM%u; | Qs?!3mdߞQ IlTqW5j 8qKldz$^>9bXFO-a5%j=ph(@XxY=&랞{`v.n2.IH.A#LQ HaHQmؚMB-)Pc heH4VRD'Wz6w{F\g^7e:˹:׉PgEcDT Y?|bRx"X@fXj;Y q8HY\w["R1et.csp{ozv8>e㱛FfNC8s)^C*dZypd}2"p1mŇS|"$)$½n~RJ'[+;҅U?R y"y/ 9%l67א[f:klsZhRuh^a~Bm?qIRrRЪ12uV7:5PWdCO6|h]9,}Hqv2,@("O~Rq7[B'Jpm =MȂ\ѥ$0q5˥)ԙw]UMRt'DU_R8w8m5\Siهjm~CFj_WPbC@*ɦVIʅG1bFkq@쎴dï{(ON&2]2,&pQscxP$#efmT 9% qH~)z`'dNn>v3L,P4. IT4}Y=;!\|f6dLZ2tY^5l!Z)H4Jb ܺ2.\&0RXvAd)Cbȡ0l6Wk ]+䢍lh`Ƭ %+Jy0 tqQ=.rY`UY^|82ޯ(bPf~-N?foS;EM^EP/Xv܉aF}*nz~Jyޗ&}ǚ Ka |"{M:ip׎@9e[>mdncdo+ sWޱ3F7*,w9R+xnW<ܚYif]|u"`VpaNʃ՝sWҺs zwޮ?ZFRRxI{ -{yy.leG`\[mbhCiH#>q.D89Q+cCmiMڿM20gɀѮ 26 [Q@~WbC }bp"<_\J=.. Cq'~l|)"Ѭʙ:tyaœe(|m̽/t>Z(ꠠyw^d=1e }< 2Hn.`ɀ 5J\۽6Ms=B=<=Y|8eB ρ]X`<*FRiS$4ёFi9 Eu|Ih Qqt2E&^[1>#Enlwf9.+"J߀$gV7=ZZMGz2QMԨČzK%;-;Z.:9V`3OU02w`P6e'0G%뻂: eZj7)nnrn]۰ҀdE4ˌ!,:oL_kU%;;X28<._21Ifܲ6pVhgA +A["ttL^@tzlgIU~ ]5< gE/(J[ k~uY oLUd\@x6;ei$!Zo d`]HhL~m;! {>n'7/ *XmL9G.H9z [ `;)h|F i[_1pLp\PZVW2[ݛc#w,!4ܴ ڵQGRʁmⴍ@>3j60uBb_| 8t{#EVCh^Hp;/tkFO/)᫋K[NwhGy:m؀Y)c-^cn)lݏɔj٦ qJzM( %0JP˕z Tf9T*u)zHyܛås-p)]VQ6i='t~7J("jLJz_U :̬9?s}ub A~Cy (\]?c)R , -CB(D"V>\{\.J;2+w8b+GX+(6M[k}t`M)Ε2k-_>bc]qz$#ya4DՄVÑS20Fl%2܁ })K Gs(hݡjgƾ,P`ػ{^|aQ]JqAcs Ch=D0 ϑ.5Sn++"h@TlN9mؼ{&T٦]T0kL蓗oTo0yoI\Pv!=?$`vGƜ,!ri_bm az}s(g' G>Ҕ Am})K]}KNnР+"v$X(Xc -7 Oc, QwNxpGp{/ /5^9r";f>7K/R1Y{Oo(<:pz(0bC/y.K)> N囟O`OJ"mɽ&j8=DxƧ(\#IM63؍>/`0 $IMjUZ7dgO~ɜ䅲_Ǟ5sZ jS&g Vg`K+~$tH`"lK頭N00 dᤌh%dMZT LWjnV֑"Ten_t`*SfZKzrJ77컑n"|bǂƒ+)EnZLv>?צ5ʏrxE"sc f}mjs˫C;Ͷ3Q+4K.(NkӪcJ{3 ]vfwx?M+λ/&2'i(e.k>zCuᨙiEY!B"۟P.NtF#$];}`Vf׼b\NYlCjVk0K X`^)&V* &} ӋL8P( f6FGdG`={̺do㋆9M sE?ys*[)Y Cu\bh0}m2V|ojZ+ J߃q(zi,̒MKCc UUa[oGl|m'g"%;쨇|ivq!֥&0Pf`⵼9;w+=F>atwa!0A.4˞6:Y3_zycɵt5%Ā#stbpvzPC[ςᝩ+㏍4{C)MLyWJzCƭw24FC{pkp} kK'8[3^=? fJ9ԫz8C"/i=%Q;㱅!/=eך$4-e e9M &h@%\չwZr/Nqr)=]Xoh"Hꠝ;.] q=8MU@~v]\'"IDR_kda{?࿛Fq^3y'c}*`I ԓ)jOD4yMEF<%{? ( ?kıxބE+ 7J6ύvh GE*X6D1.P=pȨ=N%C\-#SA6#ᣝ߃^H1ѓm*I ;618-"%htVuY*znxw#KC94>5y? fvuӿya!MZ,?^a=kbe :1ٽ e܃}Kn5,<p3vC8%=qyCc2m:뉯>'"4h vc0DBNދ9Eml~1|Xz͗!ФwQ' .!. C궟Z;yo+ngq$ri?,L׌vO9$Sm1'Z8SwU72`RÖPV!ᝐfK*tV`tm;1A', ϳ~=@MժǮ6(v"gR qnqFXG O 3$TZ/jnvWz`މwKk#|$ӨQ+[)DC(1&>Ijd[V }aѲ"[V}?B4M'΍Xn!R'nڔӓ&e91o׷ St@h&-ї`m>yX .o_6{RnCP~pu)בAQ~x_$dhILPxHƋ/$0>?! 8ԛk {VtCt,Oꕦ0pzۆ*"·S%ϠxgPqmoݱ7w_Vֲg`OV3/tl~܄+!JǽLςXnpP)ͭDqYMf^lյok#ǖb(?̈ &Vi]K#wiRE8yDx[k}!+A,PȐ`{}v<-*E,4%^_ٴK$2ד xmw.+.6RUg->I|UE!I,,aqPxr)mTCUݻ&x+Vyt>Gd2R>\ 'rmVyH-q3y@ehpVS #+xÕB!=s~!'m+ΞߖU⹜88(caLXU4@k|aEqDSe[ ESYm`刃m.R 1ІAޜ64Vo/^<7 > KSm'xocИho%߿/%]f1 0o;07b0>xqQ*>s~jqoE9PUsS%;U=v57$N=\m ۀNg #@H^h8&)fuSV'qk*l%iXl}jD9&`ُ@E)!'w1#ﳙ*P\D$W,X KbʀCd#U ݍ@e*jOpXAx>XS'+Vyť .6B ٝTGAVa)4 ~q} 5 U~w|)_b/ CX30S1r%"P&9Yce>EQizHi/F9SN]=9ZUԹ#ܫ43< B4a\Їܥlc^Q"I+ "ҙ 䬔b0߃qpdih2\J b)::Mp!1˗lҿh7NEq'%cEXMȌ>gܩ2S }FCzI4yG #i{sdAU[hcQ5#\î`Sʹ$E)*ZdFf0{D .6QPdͮ3V[HOW( UW< t9HO?Ş'㈔W`6#k*C./MBi? k+I@ v.sV8iBK7gÉi˛,MW')X>ܐ>]!-98<F@d5[p)cVfEE4: o[4ofαR枪?/twHk}x[f +-U耬X+jZgT+`4jx0VO2m%s^Z5;^f\ lIUu>[KՑF22Hx^5|68*[=x:.26ŗؘFSH U =:em[p?{{{eTc|Mo)aɎ@U?=X3#NURjV F4~qUsN0P.kSJ)^Cp W~WwD-qiC4-zK!/O)ۺD. &"& :-T+urޱA2G}KVvӍ1VmxO. qu'CMn?v al'HEHLXn:&1WSoḋ44=Bl&O"+-Y3c_SEmEW$oAJqA/rk}"YuV9NDz*2H &.Ta/m-oDo&ㄞy-0 b.#72c#`7=Q?+2żu?FF-fdK(2#._58>Nd31]$E^/WZ̪L.qnFk4wHe2mԢ-Oyhd缔V8]<s)Zmԟ@@U]xPG+ NM_9v#4)9F&rqd \JJ]e/n,rO至9IN>YD܌G% ao*qӾq /p~{a宒/`,V8[ɇ>RW:ma[",.AU<8lݳOhommZ&RHsXvqyIjXԶu=t{w[=={};NCJG2ל2y_LehjړբT3Ѣԩ /%8-Sբwuob^ʛU?Y0~mhc$cԲp yA F4BSsX{hŵ| 4%T]\=FW9Z)dpܦ+aiesJ)Ĝ6Tym Kzp5eOMua}.@f;z>|uIv,XUFQ#[CCGg (5Z쯙HR[5B{ӛvJF-4M JEloPx9-5 G梠 |[D+A>ttU#B-fnʍX\;{k"c%DO"*!Ge-'|8o_Q L6qlKos~x޲r#zuǛ;fmyJ :K${Q N|XOǧ)W)5K5{8,#7 R|}U)N( #UiFn3 Y-`#&"(*ܮ3U  .{z^zS]PY k Kc /]͈$#Z.Lwt4a0YiO葿ccFi|fYc>oggZ-cI\hy:ʖOٞLʁ]4K+>S JpnQ~œ,j4S?hhLqĚ0HfInmOڧ\&]rUOvp/訬1e+ t;vl9)b;`pDs:Jhf6X|Zڞ%̒5)<ÞpBwZb LI(-zmE$Yg݇*? 6joOT?ngP,`彖owe2D5 ,(@ P1jڊM-!E9*L4X^c~a4?=Aloh(҈5ew0PY:jx!(`0F\@}(\'@ ׏tw F[gWx"l,Dmbo3$ϒxwiNYf%Y|#XcsTy8c}[ϻqjChqp*΋9g}:~ 7 <z_Kz8/7O~duD25}C䎼ɽXL k̈k 77>t{ݪ4{k N:q.'i;Ogj%+dMIfPO!pW c \!E4SO"Νn컈2$N\w &b zn~PP<[lГ*.͒=9f}忁eTj8-R3doD7Ju"'6MMġѫaIg\ljM/ F7 /;ҴA'|oիtCxOj.RlF${>JDP61YL3ѳbyD`C i@ ȥ<);_5J Ikٶ׏W$,c3Rc'>UשY0잿6m@l:(* <"iJ90J4?I eOW9G76swsM @# ]} Lқ A,BF-yPwhS!~1B`1)meS1Ҷ*_":CHŸl첀u%&?P)*g7ea/xt;1p9SUlq8.E Ѫ|+Ty8SQy@mT(Iw8w#:qH;F Πi+30B8JtQ.jôP9wr5LMy-бˎa皏kzH g3?B-]8;5KWlew8 Æv)-͙to+GNnO~9]v,Eȶ"2Gu+k#W"gQQW oGfxn>nAF9V5/YJuC9Y~89-(Q2>d ΄27͗?zЮn> wL8U!=?7mӚ1PoBSFЋzB۝HIRNoFj |}HLN0_Em򄆲G PWĺ"BFQU-Ӯ{oJ)ƌ1-.Stl}l?|:n֕,@b6V)p4ԥEUZэLy06rf_t~k 6qtf$rɿ|^!SoQ ݢ={R;.~P7my1}Ցpwjkk~I5nOl#>׾7\!V0(pCl˛i]%z=cta(T$e ^q8כpyاGAz#Z/`Pӟea*b )\:Rt*TK bsH+el:Ί1-M=(B'QOCo)%bQY[c1__=3/8WEN⺣VVp7UUÒWzbbFwGczX-ؤ]}%X& B=hX*hf14ܷߜzDlgFBZz"Cv8*^㪴" YAs^)n)y K_ `9x^71ˎWႺt*B艹?zPɞZ= X\Rw4EYPf乤8T%Aڽv0ՑWZ&t\4f"س:yp4nd ]N ˗M _4 U[Q$T!'˂]^^FMF[ހٴv2Dm-[F/ΫL(g[mPx`U+|)=pn$xo'l- Bb83.b&jƅ<)lwTy!ߖOqpu6A^p M6%O,'梃}ʯw0#l [ZԿ(`ߙ;ŕrM*֯l㵑-{SD5 XHUmpmx[[wo^ _D[5aXi=ͤ[<%5x(IsslMTj:ʥYN Jϫ9׭ߣ8"zx.Z?GB1 P~EIzx郮q#q~Ruh&E l]V!i%puÈk?OoS-Q> {sxk%=:/%NNL k3o|Q4,EMm;F &ڧj&'R9%aM9U?Y` jq'~HLg WM_j}:D[#Uz/0"Kµsף T YZ