From af1a266670d040d2f4083ff309d732d648afba2a Mon Sep 17 00:00:00 2001 From: Angelos Mouzakitis Date: Tue, 10 Oct 2023 14:33:42 +0000 Subject: Add submodule dependency files Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec --- roms/edk2/MdeModulePkg/Logo/Logo.bmp | Bin 0 -> 12446 bytes roms/edk2/MdeModulePkg/Logo/Logo.c | 153 +++++++++++++++++++++++++++ roms/edk2/MdeModulePkg/Logo/Logo.idf | 10 ++ roms/edk2/MdeModulePkg/Logo/Logo.inf | 31 ++++++ roms/edk2/MdeModulePkg/Logo/Logo.uni | 16 +++ roms/edk2/MdeModulePkg/Logo/LogoDxe.inf | 56 ++++++++++ roms/edk2/MdeModulePkg/Logo/LogoDxe.uni | 16 +++ roms/edk2/MdeModulePkg/Logo/LogoDxeExtra.uni | 14 +++ roms/edk2/MdeModulePkg/Logo/LogoExtra.uni | 14 +++ 9 files changed, 310 insertions(+) create mode 100644 roms/edk2/MdeModulePkg/Logo/Logo.bmp create mode 100644 roms/edk2/MdeModulePkg/Logo/Logo.c create mode 100644 roms/edk2/MdeModulePkg/Logo/Logo.idf create mode 100644 roms/edk2/MdeModulePkg/Logo/Logo.inf create mode 100644 roms/edk2/MdeModulePkg/Logo/Logo.uni create mode 100644 roms/edk2/MdeModulePkg/Logo/LogoDxe.inf create mode 100644 roms/edk2/MdeModulePkg/Logo/LogoDxe.uni create mode 100644 roms/edk2/MdeModulePkg/Logo/LogoDxeExtra.uni create mode 100644 roms/edk2/MdeModulePkg/Logo/LogoExtra.uni (limited to 'roms/edk2/MdeModulePkg/Logo') diff --git a/roms/edk2/MdeModulePkg/Logo/Logo.bmp b/roms/edk2/MdeModulePkg/Logo/Logo.bmp new file mode 100644 index 000000000..3e85229e1 Binary files /dev/null and b/roms/edk2/MdeModulePkg/Logo/Logo.bmp differ diff --git a/roms/edk2/MdeModulePkg/Logo/Logo.c b/roms/edk2/MdeModulePkg/Logo/Logo.c new file mode 100644 index 000000000..c647253ec --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/Logo.c @@ -0,0 +1,153 @@ +/** @file + Logo DXE Driver, install Edkii Platform Logo protocol. + +Copyright (c) 2016 - 2017, Intel Corporation. All rights reserved.
+SPDX-License-Identifier: BSD-2-Clause-Patent + +**/ +#include +#include +#include +#include +#include +#include +#include +#include + +typedef struct { + EFI_IMAGE_ID ImageId; + EDKII_PLATFORM_LOGO_DISPLAY_ATTRIBUTE Attribute; + INTN OffsetX; + INTN OffsetY; +} LOGO_ENTRY; + +EFI_HII_IMAGE_EX_PROTOCOL *mHiiImageEx; +EFI_HII_HANDLE mHiiHandle; +LOGO_ENTRY mLogos[] = { + { + IMAGE_TOKEN (IMG_LOGO), + EdkiiPlatformLogoDisplayAttributeCenter, + 0, + 0 + } +}; + +/** + Load a platform logo image and return its data and attributes. + + @param This The pointer to this protocol instance. + @param Instance The visible image instance is found. + @param Image Points to the image. + @param Attribute The display attributes of the image returned. + @param OffsetX The X offset of the image regarding the Attribute. + @param OffsetY The Y offset of the image regarding the Attribute. + + @retval EFI_SUCCESS The image was fetched successfully. + @retval EFI_NOT_FOUND The specified image could not be found. +**/ +EFI_STATUS +EFIAPI +GetImage ( + IN EDKII_PLATFORM_LOGO_PROTOCOL *This, + IN OUT UINT32 *Instance, + OUT EFI_IMAGE_INPUT *Image, + OUT EDKII_PLATFORM_LOGO_DISPLAY_ATTRIBUTE *Attribute, + OUT INTN *OffsetX, + OUT INTN *OffsetY + ) +{ + UINT32 Current; + if (Instance == NULL || Image == NULL || + Attribute == NULL || OffsetX == NULL || OffsetY == NULL) { + return EFI_INVALID_PARAMETER; + } + + Current = *Instance; + if (Current >= ARRAY_SIZE (mLogos)) { + return EFI_NOT_FOUND; + } + + (*Instance)++; + *Attribute = mLogos[Current].Attribute; + *OffsetX = mLogos[Current].OffsetX; + *OffsetY = mLogos[Current].OffsetY; + return mHiiImageEx->GetImageEx (mHiiImageEx, mHiiHandle, mLogos[Current].ImageId, Image); +} + +EDKII_PLATFORM_LOGO_PROTOCOL mPlatformLogo = { + GetImage +}; + +/** + Entrypoint of this module. + + This function is the entrypoint of this module. It installs the Edkii + Platform Logo protocol. + + @param ImageHandle The firmware allocated handle for the EFI image. + @param SystemTable A pointer to the EFI System Table. + + @retval EFI_SUCCESS The entry point is executed successfully. + +**/ +EFI_STATUS +EFIAPI +InitializeLogo ( + IN EFI_HANDLE ImageHandle, + IN EFI_SYSTEM_TABLE *SystemTable + ) +{ + EFI_STATUS Status; + EFI_HII_PACKAGE_LIST_HEADER *PackageList; + EFI_HII_DATABASE_PROTOCOL *HiiDatabase; + EFI_HANDLE Handle; + + Status = gBS->LocateProtocol ( + &gEfiHiiDatabaseProtocolGuid, + NULL, + (VOID **) &HiiDatabase + ); + ASSERT_EFI_ERROR (Status); + + Status = gBS->LocateProtocol ( + &gEfiHiiImageExProtocolGuid, + NULL, + (VOID **) &mHiiImageEx + ); + ASSERT_EFI_ERROR (Status); + + // + // Retrieve HII package list from ImageHandle + // + Status = gBS->OpenProtocol ( + ImageHandle, + &gEfiHiiPackageListProtocolGuid, + (VOID **) &PackageList, + ImageHandle, + NULL, + EFI_OPEN_PROTOCOL_GET_PROTOCOL + ); + if (EFI_ERROR (Status)) { + DEBUG ((DEBUG_ERROR, "HII Image Package with logo not found in PE/COFF resource section\n")); + return Status; + } + + // + // Publish HII package list to HII Database. + // + Status = HiiDatabase->NewPackageList ( + HiiDatabase, + PackageList, + NULL, + &mHiiHandle + ); + if (!EFI_ERROR (Status)) { + Handle = NULL; + Status = gBS->InstallMultipleProtocolInterfaces ( + &Handle, + &gEdkiiPlatformLogoProtocolGuid, &mPlatformLogo, + NULL + ); + } + return Status; +} diff --git a/roms/edk2/MdeModulePkg/Logo/Logo.idf b/roms/edk2/MdeModulePkg/Logo/Logo.idf new file mode 100644 index 000000000..1f7933202 --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/Logo.idf @@ -0,0 +1,10 @@ +// /** @file +// Platform Logo image definition file. +// +// Copyright (c) 2016 - 2018, Intel Corporation. All rights reserved.
+// +// SPDX-License-Identifier: BSD-2-Clause-Patent +// +// **/ + +#image IMG_LOGO Logo.bmp diff --git a/roms/edk2/MdeModulePkg/Logo/Logo.inf b/roms/edk2/MdeModulePkg/Logo/Logo.inf new file mode 100644 index 000000000..70a66cae9 --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/Logo.inf @@ -0,0 +1,31 @@ +## @file +# The default logo bitmap picture shown on setup screen, which is corresponding to gEfiDefaultBmpLogoGuid. +# +# Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.
+# Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.
+ +# +# SPDX-License-Identifier: BSD-2-Clause-Patent +# +# +## + +[Defines] + INF_VERSION = 0x00010005 + BASE_NAME = Logo + MODULE_UNI_FILE = Logo.uni + FILE_GUID = 7BB28B99-61BB-11D5-9A5D-0090273FC14D + MODULE_TYPE = USER_DEFINED + VERSION_STRING = 1.0 + +# +# The following information is for reference only and not required by the build tools. +# +# VALID_ARCHITECTURES = IA32 X64 EBC ARM AARCH64 RISCV64 +# + +[Binaries] + BIN|Logo.bmp|* + +[UserExtensions.TianoCore."ExtraFiles"] + LogoExtra.uni diff --git a/roms/edk2/MdeModulePkg/Logo/Logo.uni b/roms/edk2/MdeModulePkg/Logo/Logo.uni new file mode 100644 index 000000000..9d1bbaffa --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/Logo.uni @@ -0,0 +1,16 @@ +// /** @file +// The default logo bitmap picture shown on setup screen, which is corresponding to gEfiDefaultBmpLogoGuid. +// +// This module provides the default logo bitmap picture shown on setup screen, which corresponds to gEfiDefaultBmpLogoGuid. +// +// Copyright (c) 2006 - 2014, Intel Corporation. All rights reserved.
+// +// SPDX-License-Identifier: BSD-2-Clause-Patent +// +// **/ + + +#string STR_MODULE_ABSTRACT #language en-US "Provides the default logo bitmap picture shown on setup screen, which corresponds to gEfiDefaultBmpLogoGuid" + +#string STR_MODULE_DESCRIPTION #language en-US "This module provides the default logo bitmap picture shown on setup screen, which corresponds to gEfiDefaultBmpLogoGuid." + diff --git a/roms/edk2/MdeModulePkg/Logo/LogoDxe.inf b/roms/edk2/MdeModulePkg/Logo/LogoDxe.inf new file mode 100644 index 000000000..41215d25d --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/LogoDxe.inf @@ -0,0 +1,56 @@ +## @file +# The default logo bitmap picture shown on setup screen. +# +# Copyright (c) 2016 - 2017, Intel Corporation. All rights reserved.
+# +# SPDX-License-Identifier: BSD-2-Clause-Patent +# +# +## + +[Defines] + INF_VERSION = 0x00010005 + BASE_NAME = LogoDxe + MODULE_UNI_FILE = LogoDxe.uni + FILE_GUID = F74D20EE-37E7-48FC-97F7-9B1047749C69 + MODULE_TYPE = DXE_DRIVER + VERSION_STRING = 1.0 + + ENTRY_POINT = InitializeLogo +# +# This flag specifies whether HII resource section is generated into PE image. +# + UEFI_HII_RESOURCE_SECTION = TRUE + +# +# The following information is for reference only and not required by the build tools. +# +# VALID_ARCHITECTURES = IA32 X64 +# + +[Sources] + Logo.bmp + Logo.c + Logo.idf + +[Packages] + MdeModulePkg/MdeModulePkg.dec + MdePkg/MdePkg.dec + +[LibraryClasses] + UefiBootServicesTableLib + UefiDriverEntryPoint + DebugLib + +[Protocols] + gEfiHiiDatabaseProtocolGuid ## CONSUMES + gEfiHiiImageExProtocolGuid ## CONSUMES + gEfiHiiPackageListProtocolGuid ## PRODUCES CONSUMES + gEdkiiPlatformLogoProtocolGuid ## PRODUCES + +[Depex] + gEfiHiiDatabaseProtocolGuid AND + gEfiHiiImageExProtocolGuid + +[UserExtensions.TianoCore."ExtraFiles"] + LogoDxeExtra.uni diff --git a/roms/edk2/MdeModulePkg/Logo/LogoDxe.uni b/roms/edk2/MdeModulePkg/Logo/LogoDxe.uni new file mode 100644 index 000000000..9635701b6 --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/LogoDxe.uni @@ -0,0 +1,16 @@ +// /** @file +// The default logo bitmap picture shown on setup screen. +// +// This module provides the default logo bitmap picture shown on setup screen, through EDKII Platform Logo protocol. +// +// Copyright (c) 2016, Intel Corporation. All rights reserved.
+// +// SPDX-License-Identifier: BSD-2-Clause-Patent +// +// **/ + + +#string STR_MODULE_ABSTRACT #language en-US "Provides the default logo bitmap picture shown on setup screen." + +#string STR_MODULE_DESCRIPTION #language en-US "This module provides the default logo bitmap picture shown on setup screen, through EDKII Platform Logo protocol." + diff --git a/roms/edk2/MdeModulePkg/Logo/LogoDxeExtra.uni b/roms/edk2/MdeModulePkg/Logo/LogoDxeExtra.uni new file mode 100644 index 000000000..c6ea34b81 --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/LogoDxeExtra.uni @@ -0,0 +1,14 @@ +// /** @file +// Logo Localized Strings and Content +// +// Copyright (c) 2016, Intel Corporation. All rights reserved.
+// +// SPDX-License-Identifier: BSD-2-Clause-Patent +// +// **/ + +#string STR_PROPERTIES_MODULE_NAME +#language en-US +"Logo Image File" + + diff --git a/roms/edk2/MdeModulePkg/Logo/LogoExtra.uni b/roms/edk2/MdeModulePkg/Logo/LogoExtra.uni new file mode 100644 index 000000000..041179fb7 --- /dev/null +++ b/roms/edk2/MdeModulePkg/Logo/LogoExtra.uni @@ -0,0 +1,14 @@ +// /** @file +// Logo Localized Strings and Content +// +// Copyright (c) 2013 - 2018, Intel Corporation. All rights reserved.
+// +// SPDX-License-Identifier: BSD-2-Clause-Patent +// +// **/ + +#string STR_PROPERTIES_MODULE_NAME +#language en-US +"Logo Image File" + + -- cgit 1.2.3-korg