From: Heinrich Schuchardt Date: Mon, 17 Dec 2018 23:06:05 +0000 (+0100) Subject: efi_loader: struct efi_configuration_table X-Git-Tag: v2019.04-rc2~13^2~48 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=2859f446b081db62336c32a832af026d37ab00b4;p=oweals%2Fu-boot.git efi_loader: struct efi_configuration_table Commit 393fccdf6c73 ("efi_loader: efi_guid_t must be 64-bit aligned") has changed the alignment of efi_guid_t. This changed the size of struct efi_configuration_table on 32-bit systems form 20 to 24 bytes. As an array of this type is pointed to by the system table this breaks compatibility with existing versions of GRUB and Linux. Let's get back the original size by using the attribute __packed. Fixes: 393fccdf6c73 ("efi_loader: efi_guid_t must be 64-bit aligned") Signed-off-by: Heinrich Schuchardt Signed-off-by: Alexander Graf --- diff --git a/include/efi_api.h b/include/efi_api.h index aef77b6319..0e5c6e92d0 100644 --- a/include/efi_api.h +++ b/include/efi_api.h @@ -299,7 +299,7 @@ struct efi_runtime_services { struct efi_configuration_table { efi_guid_t guid; void *table; -}; +} __packed; #define EFI_SYSTEM_TABLE_SIGNATURE ((u64)0x5453595320494249ULL)