use crate::{HeaderTagFlag, HeaderTagType}; use core::fmt; use core::fmt::{Debug, Formatter}; use core::mem::size_of; /// This tag is taken into account only on EFI amd64 platforms when Multiboot2 image header /// contains EFI boot services tag. Then entry point specified in ELF header and the entry address /// tag of Multiboot2 header are ignored. #[derive(Copy, Clone)] #[repr(C, packed(8))] pub struct EntryEfi64HeaderTag { typ: HeaderTagType, flags: HeaderTagFlag, size: u32, entry_addr: u32, } impl EntryEfi64HeaderTag { pub const fn new(flags: HeaderTagFlag, entry_addr: u32) -> Self { EntryEfi64HeaderTag { typ: HeaderTagType::EntryAddressEFI64, flags, size: size_of::() as u32, entry_addr, } } pub const fn typ(&self) -> HeaderTagType { self.typ } pub const fn flags(&self) -> HeaderTagFlag { self.flags } pub const fn size(&self) -> u32 { self.size } pub const fn entry_addr(&self) -> u32 { self.entry_addr } } impl Debug for EntryEfi64HeaderTag { fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result { f.debug_struct("EntryEfi64HeaderTag") .field("type", &{ self.typ }) .field("flags", &{ self.flags }) .field("size", &{ self.size }) .field("entry_addr", &(self.entry_addr as *const u32)) .finish() } } #[cfg(feature = "builder")] impl crate::StructAsBytes for EntryEfi64HeaderTag {}