[RFC,PATCH 1/4] fwts: Add fwts_firmware_has_feature

Jeremy Kerr jk at ozlabs.org
Thu Apr 24 08:18:24 UTC 2014


Add a function to indicate whether a firmware has a particular feature.
This can be used by tests to skip non-relevant tests.

Signed-off-by: Jeremy Kerr <jk at ozlabs.org>

---
 src/lib/include/fwts_firmware.h |    7 +++++++
 src/lib/src/fwts_firmware.c     |   20 ++++++++++++++++++++
 2 files changed, 27 insertions(+)

diff --git a/src/lib/include/fwts_firmware.h b/src/lib/include/fwts_firmware.h
index 7688d5e..bc7c293 100644
--- a/src/lib/include/fwts_firmware.h
+++ b/src/lib/include/fwts_firmware.h
@@ -19,6 +19,8 @@
 #ifndef __FWTS_FIRMWARE_H__
 #define __FWTS_FIRMWARE_H__
 
+#include <stdbool.h>
+
 enum {
 	FWTS_FIRMWARE_UNKNOWN = 0,
 	FWTS_FIRMWARE_BIOS = 1,
@@ -26,6 +28,11 @@ enum {
 	FWTS_FIRMWARE_OTHER = 100,
 };
 
+enum firmware_feature {
+	FWTS_FW_FEATURE_ACPI = 1 << 0,
+};
+
 int fwts_firmware_detect(void);
+bool fwts_firmware_has_feature(enum firmware_feature);
 
 #endif
diff --git a/src/lib/src/fwts_firmware.c b/src/lib/src/fwts_firmware.c
index fcc2e80..3d09572 100644
--- a/src/lib/src/fwts_firmware.c
+++ b/src/lib/src/fwts_firmware.c
@@ -36,3 +36,23 @@ int fwts_firmware_detect(void)
 	else
 		return FWTS_FIRMWARE_UEFI;
 }
+
+/*
+ * returns true if the running firmware has feature @feature
+ */
+bool fwts_firmware_has_feature(enum firmware_feature feature)
+{
+	int features = 0;
+
+	/* we just have static feature definitions for now */
+	switch (fwts_firmware_detect()) {
+	case FWTS_FIRMWARE_BIOS:
+	case FWTS_FIRMWARE_UEFI:
+		features = FWTS_FW_FEATURE_ACPI;
+		break;
+	default:
+		break;
+	}
+
+	return features & feature;
+}



More information about the fwts-devel mailing list