Blame SOURCES/0001-Do-not-make-any-of-the-HWIDs-setup-failures-fatal.patch

df6117
From 90e5a58736645cdd37bf4c63f9a4056951dfb3f2 Mon Sep 17 00:00:00 2001
df6117
From: Richard Hughes <richard@hughsie.com>
df6117
Date: Tue, 24 Jan 2023 09:52:17 +0000
df6117
Subject: [PATCH] Do not make any of the HWIDs setup failures fatal
df6117
df6117
It's perfectly okay to have no HWIDs defined.
df6117
df6117
Should help with https://github.com/fwupd/fwupd/issues/5402
df6117
---
df6117
 libfwupdplugin/fu-context.c | 73 +++++++++++--------------------------
df6117
 1 file changed, 21 insertions(+), 52 deletions(-)
df6117
df6117
diff --git a/libfwupdplugin/fu-context.c b/libfwupdplugin/fu-context.c
df6117
index 08618b435..11b4b1b38 100644
df6117
--- a/libfwupdplugin/fu-context.c
df6117
+++ b/libfwupdplugin/fu-context.c
df6117
@@ -767,6 +767,8 @@ fu_context_security_changed(FuContext *self)
df6117
 	g_signal_emit(self, signals[SIGNAL_SECURITY_CHANGED], 0);
df6117
 }
df6117
 
df6117
+typedef gboolean (*FuContextHwidsSetupFunc)(FuContext *self, FuHwids *hwids, GError **error);
df6117
+
df6117
 /**
df6117
  * fu_context_load_hwinfo:
df6117
  * @self: a #FuContext
df6117
@@ -786,62 +788,29 @@ fu_context_load_hwinfo(FuContext *self, FuContextHwidFlags flags, GError **error
df6117
 	GPtrArray *guids;
df6117
 	g_autoptr(GError) error_hwids = NULL;
df6117
 	g_autoptr(GError) error_bios_settings = NULL;
df6117
+	struct {
df6117
+		const gchar *name;
df6117
+		FuContextHwidFlags flag;
df6117
+		FuContextHwidsSetupFunc func;
df6117
+	} hwids_setup_map[] = {{"config", FU_CONTEXT_HWID_FLAG_LOAD_CONFIG, fu_hwids_config_setup},
df6117
+			       {"smbios", FU_CONTEXT_HWID_FLAG_LOAD_SMBIOS, fu_hwids_smbios_setup},
df6117
+			       {"fdt", FU_CONTEXT_HWID_FLAG_LOAD_FDT, fu_hwids_fdt_setup},
df6117
+			       {"kenv", FU_CONTEXT_HWID_FLAG_LOAD_KENV, fu_hwids_kenv_setup},
df6117
+			       {"dmi", FU_CONTEXT_HWID_FLAG_LOAD_DMI, fu_hwids_dmi_setup},
df6117
+			       {NULL, FU_CONTEXT_HWID_FLAG_NONE, NULL}};
df6117
 
df6117
 	g_return_val_if_fail(FU_IS_CONTEXT(self), FALSE);
df6117
 	g_return_val_if_fail(error == NULL || *error == NULL, FALSE);
df6117
 
df6117
-	if ((flags & FU_CONTEXT_HWID_FLAG_LOAD_CONFIG) > 0) {
df6117
-		g_autoptr(GError) error_local = NULL;
df6117
-		if (!fu_hwids_config_setup(self, priv->hwids, &error_local)) {
df6117
-			if (!g_error_matches(error_local, FWUPD_ERROR, FWUPD_ERROR_NOT_SUPPORTED)) {
df6117
-				g_propagate_prefixed_error(error,
df6117
-							   g_steal_pointer(&error_local),
df6117
-							   "Failed to load HWIDs config: ");
df6117
-				return FALSE;
df6117
-			}
df6117
-		}
df6117
-	}
df6117
-	if ((flags & FU_CONTEXT_HWID_FLAG_LOAD_DMI) > 0) {
df6117
-		g_autoptr(GError) error_local = NULL;
df6117
-		if (!fu_hwids_dmi_setup(self, priv->hwids, &error_local)) {
df6117
-			if (!g_error_matches(error_local, FWUPD_ERROR, FWUPD_ERROR_NOT_SUPPORTED)) {
df6117
-				g_propagate_prefixed_error(error,
df6117
-							   g_steal_pointer(&error_local),
df6117
-							   "Failed to load HWIDs DMI: ");
df6117
-				return FALSE;
df6117
-			}
df6117
-		}
df6117
-	}
df6117
-	if ((flags & FU_CONTEXT_HWID_FLAG_LOAD_FDT) > 0) {
df6117
-		g_autoptr(GError) error_local = NULL;
df6117
-		if (!fu_hwids_fdt_setup(self, priv->hwids, &error_local)) {
df6117
-			if (!g_error_matches(error_local, FWUPD_ERROR, FWUPD_ERROR_NOT_SUPPORTED)) {
df6117
-				g_propagate_prefixed_error(error,
df6117
-							   g_steal_pointer(&error_local),
df6117
-							   "Failed to load HWIDs FDT: ");
df6117
-				return FALSE;
df6117
-			}
df6117
-		}
df6117
-	}
df6117
-	if ((flags & FU_CONTEXT_HWID_FLAG_LOAD_KENV) > 0) {
df6117
-		g_autoptr(GError) error_local = NULL;
df6117
-		if (!fu_hwids_kenv_setup(self, priv->hwids, &error_local)) {
df6117
-			if (!g_error_matches(error_local, FWUPD_ERROR, FWUPD_ERROR_NOT_SUPPORTED)) {
df6117
-				g_propagate_prefixed_error(error,
df6117
-							   g_steal_pointer(&error_local),
df6117
-							   "Failed to load HWIDs kenv: ");
df6117
-				return FALSE;
df6117
-			}
df6117
-		}
df6117
-	}
df6117
-	if ((flags & FU_CONTEXT_HWID_FLAG_LOAD_SMBIOS) > 0) {
df6117
-		g_autoptr(GError) error_local = NULL;
df6117
-		if (!fu_hwids_smbios_setup(self, priv->hwids, &error_local)) {
df6117
-			if (!g_error_matches(error_local, FWUPD_ERROR, FWUPD_ERROR_NOT_SUPPORTED)) {
df6117
-				g_propagate_prefixed_error(error,
df6117
-							   g_steal_pointer(&error_local),
df6117
-							   "Failed to load SMBIOS: ");
df6117
-				return FALSE;
df6117
+	/* run all the HWID setup funcs */
df6117
+	for (guint i = 0; hwids_setup_map[i].name != NULL; i++) {
df6117
+		if ((flags & hwids_setup_map[i].flag) > 0) {
df6117
+			g_autoptr(GError) error_local = NULL;
df6117
+			if (!hwids_setup_map[i].func(self, priv->hwids, &error_local)) {
df6117
+				g_debug("failed to load %s: %s",
df6117
+					hwids_setup_map[i].name,
df6117
+					error_local->message);
df6117
+				break;
df6117
 			}
df6117
 		}
df6117
 	}
df6117
-- 
df6117
2.39.1
df6117