mirror of
https://git.proxmox.com/git/fwupd
synced 2025-06-05 03:37:10 +00:00

We were calling g_module_symbol() 2703 times, which is actually more expensive than you'd think. It also means the plugins are actually what we tell people they are: A set of vfuncs that get run. The reality before that they were dlsym'd functions that get called at pretty random times.
45 lines
1.1 KiB
C
45 lines
1.1 KiB
C
/*
|
|
* Copyright (C) 2021 Richard Hughes <richard@hughsie.com>
|
|
*
|
|
* SPDX-License-Identifier: LGPL-2.1+
|
|
*/
|
|
|
|
#include "config.h"
|
|
|
|
#include <fwupdplugin.h>
|
|
|
|
#include "fu-intel-spi-device.h"
|
|
|
|
static void
|
|
fu_plugin_intel_spi_init(FuPlugin *plugin)
|
|
{
|
|
FuContext *ctx = fu_plugin_get_context(plugin);
|
|
fu_plugin_add_udev_subsystem(plugin, "pci");
|
|
fu_context_add_quirk_key(ctx, "IntelSpiKind");
|
|
fu_context_add_quirk_key(ctx, "IntelSpiBar");
|
|
fu_context_add_quirk_key(ctx, "IntelSpiBarProxy");
|
|
fu_context_add_quirk_key(ctx, "IntelSpiBiosCntl");
|
|
fu_plugin_add_device_gtype(plugin, FU_TYPE_INTEL_SPI_DEVICE);
|
|
}
|
|
|
|
static gboolean
|
|
fu_plugin_intel_spi_startup(FuPlugin *plugin, GError **error)
|
|
{
|
|
if (fu_common_kernel_locked_down()) {
|
|
g_set_error_literal(error,
|
|
FWUPD_ERROR,
|
|
FWUPD_ERROR_NOT_SUPPORTED,
|
|
"not supported when kernel locked down");
|
|
return FALSE;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
void
|
|
fu_plugin_init_vfuncs(FuPluginVfuncs *vfuncs)
|
|
{
|
|
vfuncs->build_hash = FU_BUILD_HASH;
|
|
vfuncs->init = fu_plugin_intel_spi_init;
|
|
vfuncs->startup = fu_plugin_intel_spi_startup;
|
|
}
|