#[path = "acpi/acpi.rs"]
#[cfg(target_arch = "x86_64")]
pub mod acpi;
#[path = "dt/dt.rs"]
pub mod dt;
#[path = "ovmf/ovmf.rs"]
pub mod ovmf;
#[path = "uefi/uefi.rs"]
pub mod uefi;
use snafu::Snafu;
use crate::errors::{DebugTrace, trace_error};
use self::ovmf::x86_64::sev::SEV_SIGNATURE;
use self::ovmf::x86_64::tdx::{TDVF_SIGNATURE, TDVF_VERSION};
#[trace_error]
#[derive(Snafu, DebugTrace)]
#[snafu(module, context(suffix(false)))]
pub enum Error {
#[snafu(display("Firmware missing {name}"))]
MissingMetadata { name: &'static str },
#[snafu(display("Firmware missing TDVF signature {TDVF_SIGNATURE:08x}, got {got:08x}"))]
MissingTdvfSignature { got: u32 },
#[snafu(display("Firmware missing AMD-SEV signature {SEV_SIGNATURE:08x}, got {got:08x}"))]
MissingAmdSevSignature { got: u32 },
#[snafu(display("Firmware missing TDVF version {TDVF_VERSION}, got {got}"))]
MissingTdvfVersion { got: u32 },
#[snafu(display("Invalid firmware data layout"))]
InvalidLayout,
#[snafu(display("Uncovered TDVF section"))]
UncoveredTdvfSection,
#[snafu(display("Failed to write HOB"))]
WriteHob { error: std::io::Error },
}
type Result<T, E = Error> = std::result::Result<T, E>;