mirror of
https://git.proxmox.com/git/fwupd
synced 2026-03-24 13:02:39 +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 ();
|
|
}
|