fwupd/plugins/uefi-dbx/fu-plugin-uefi-dbx.c
Richard Hughes e6b487e762 Add FuProgress to ->startup() and ->coldplug()
This allows us to profile the daemon startup so we can find any plugins
taking an inordinate amount of time to start.
2022-06-04 20:21:50 +01:00

55 lines
1.4 KiB
C

/*
* Copyright (C) 2020 Richard Hughes <richard@hughsie.com>
*
* SPDX-License-Identifier: LGPL-2.1+
*/
#include "config.h"
#include <fwupdplugin.h>
#include "fu-uefi-dbx-device.h"
static void
fu_plugin_uefi_dbx_init(FuPlugin *plugin)
{
fu_plugin_add_rule(plugin, FU_PLUGIN_RULE_METADATA_SOURCE, "uefi_capsule");
fu_plugin_add_firmware_gtype(plugin, NULL, FU_TYPE_EFI_SIGNATURE_LIST);
}
static gboolean
fu_plugin_uefi_dbx_coldplug(FuPlugin *plugin, FuProgress *progress, GError **error)
{
FuContext *ctx = fu_plugin_get_context(plugin);
g_autoptr(FuUefiDbxDevice) device = fu_uefi_dbx_device_new(ctx);
/* progress */
fu_progress_set_id(progress, G_STRLOC);
fu_progress_add_step(progress, FWUPD_STATUS_LOADING, 99, "probe");
fu_progress_add_step(progress, FWUPD_STATUS_LOADING, 1, "setup");
if (!fu_device_probe(FU_DEVICE(device), error))
return FALSE;
fu_progress_step_done(progress);
if (!fu_device_setup(FU_DEVICE(device), error))
return FALSE;
fu_progress_step_done(progress);
if (fu_context_has_hwid_flag(fu_plugin_get_context(plugin), "no-dbx-updates")) {
fu_device_inhibit(FU_DEVICE(device),
"no-dbx",
"System firmware cannot accept DBX updates");
}
fu_plugin_device_add(plugin, FU_DEVICE(device));
return TRUE;
}
void
fu_plugin_init_vfuncs(FuPluginVfuncs *vfuncs)
{
vfuncs->build_hash = FU_BUILD_HASH;
vfuncs->init = fu_plugin_uefi_dbx_init;
vfuncs->coldplug = fu_plugin_uefi_dbx_coldplug;
}