mirror of
https://git.proxmox.com/git/fwupd
synced 2025-05-14 21:57:34 +00:00

The HSI specification is currently incomplete and in active development. Sample output for my Lenovo P50 Laptop: Host Security ID: HSI:2+UA! HSI-1 ✔ UEFI dbx: OK ✔ TPM: v2.0 ✔ SPI: Write disabled ✔ SPI: Lock enabled ✔ SPI: SMM required ✔ UEFI Secure Boot: Enabled HSI-2 ✔ TPM Reconstruction: Matched PCR0 reading HSI-3 ✘ Linux Kernel S3 Sleep: Deep sleep available HSI-4 ✘ Intel CET: Unavailable Runtime Suffix -U ✔ Firmware Updates: Newest release is 8 months old Runtime Suffix -A ✔ Firmware Attestation: OK Runtime Suffix -! ✔ fwupd plugins: OK ✔ Linux Kernel: OK ✔ Linux Kernel: Locked down ✘ Linux Swap: Not encrypted
66 lines
1.5 KiB
C
66 lines
1.5 KiB
C
/*
|
|
* Copyright (C) 2020 Richard Hughes <richard@hughsie.com>
|
|
*
|
|
* SPDX-License-Identifier: LGPL-2.1+
|
|
*/
|
|
|
|
#include "config.h"
|
|
|
|
#include <fwupd.h>
|
|
|
|
#include "fu-common.h"
|
|
|
|
#include "fu-acpi-dmar.h"
|
|
|
|
static void
|
|
fu_acpi_dmar_opt_in_func (void)
|
|
{
|
|
g_autoptr(FuAcpiDmar) dmar = NULL;
|
|
g_autoptr(GError) error = NULL;
|
|
g_autoptr(GBytes) blob = NULL;
|
|
g_autofree gchar *fn = NULL;
|
|
|
|
fn = g_build_filename (TESTDATADIR, "DMAR", NULL);
|
|
blob = fu_common_get_contents_bytes (fn, &error);
|
|
g_assert_no_error (error);
|
|
g_assert_nonnull (blob);
|
|
dmar = fu_acpi_dmar_new (blob, &error);
|
|
g_assert_no_error (error);
|
|
g_assert_nonnull (dmar);
|
|
g_assert_true (fu_acpi_dmar_get_opt_in (dmar));
|
|
}
|
|
|
|
static void
|
|
fu_acpi_dmar_opt_out_func (void)
|
|
{
|
|
g_autoptr(FuAcpiDmar) dmar = NULL;
|
|
g_autoptr(GError) error = NULL;
|
|
g_autoptr(GBytes) blob = NULL;
|
|
g_autofree gchar *fn = NULL;
|
|
|
|
fn = g_build_filename (TESTDATADIR, "DMAR-OPTOUT", NULL);
|
|
blob = fu_common_get_contents_bytes (fn, &error);
|
|
g_assert_no_error (error);
|
|
g_assert_nonnull (blob);
|
|
dmar = fu_acpi_dmar_new (blob, &error);
|
|
g_assert_no_error (error);
|
|
g_assert_nonnull (dmar);
|
|
g_assert_false (fu_acpi_dmar_get_opt_in (dmar));
|
|
}
|
|
|
|
int
|
|
main (int argc, char **argv)
|
|
{
|
|
g_test_init (&argc, &argv, NULL);
|
|
|
|
/* only critical and error are fatal */
|
|
g_log_set_fatal_mask (NULL, G_LOG_LEVEL_ERROR | G_LOG_LEVEL_CRITICAL);
|
|
g_setenv ("G_MESSAGES_DEBUG", "all", TRUE);
|
|
|
|
/* tests go here */
|
|
g_test_add_func ("/acpi-dmar/opt-in", fu_acpi_dmar_opt_in_func);
|
|
g_test_add_func ("/acpi-dmar/opt-out", fu_acpi_dmar_opt_out_func);
|
|
|
|
return g_test_run ();
|
|
}
|