Use Microsoft's recommended positioning [1] for the boot logo. > We recommend that the logo is placed with its center at 38.2% from the > screen's top edge. This positioning is based on the golden ratio's > visual aesthetics and matches the Windows 10 design proportions. [1]: https://docs.microsoft.com/en-us/windows-hardware/drivers/bringup/boot-screen-components#position-the-logo-during-post
		
			
				
	
	
		
			557 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			557 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  This library is only intended to be used by PlatformBootManagerLib
 | 
						|
  to show progress bar and LOGO.
 | 
						|
 | 
						|
Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
 | 
						|
Copyright (c) 2016, Microsoft Corporation<BR>
 | 
						|
SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#include <Uefi.h>
 | 
						|
#include <Protocol/GraphicsOutput.h>
 | 
						|
#include <Protocol/SimpleTextOut.h>
 | 
						|
#include <Protocol/PlatformLogo.h>
 | 
						|
#include <Protocol/UgaDraw.h>
 | 
						|
#include <Protocol/BootLogo.h>
 | 
						|
#include <Protocol/BootLogo2.h>
 | 
						|
#include <Library/BaseLib.h>
 | 
						|
#include <Library/UefiLib.h>
 | 
						|
#include <Library/BaseMemoryLib.h>
 | 
						|
#include <Library/UefiBootServicesTableLib.h>
 | 
						|
#include <Library/PcdLib.h>
 | 
						|
#include <Library/MemoryAllocationLib.h>
 | 
						|
#include <Library/DebugLib.h>
 | 
						|
 | 
						|
/**
 | 
						|
  Show LOGO returned from Edkii Platform Logo protocol on all consoles.
 | 
						|
 | 
						|
  @retval EFI_SUCCESS     Logo was displayed.
 | 
						|
  @retval EFI_UNSUPPORTED Logo was not found or cannot be displayed.
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
BootLogoEnableLogo (
 | 
						|
  VOID
 | 
						|
  )
 | 
						|
{
 | 
						|
  EFI_STATUS                             Status;
 | 
						|
  EDKII_PLATFORM_LOGO_PROTOCOL           *PlatformLogo;
 | 
						|
  EDKII_PLATFORM_LOGO_DISPLAY_ATTRIBUTE  Attribute;
 | 
						|
  INTN                                   OffsetX;
 | 
						|
  INTN                                   OffsetY;
 | 
						|
  UINT32                                 SizeOfX;
 | 
						|
  UINT32                                 SizeOfY;
 | 
						|
  INTN                                   DestX;
 | 
						|
  INTN                                   DestY;
 | 
						|
  UINT32                                 Instance;
 | 
						|
  EFI_IMAGE_INPUT                        Image;
 | 
						|
  EFI_GRAPHICS_OUTPUT_BLT_PIXEL          *Blt;
 | 
						|
  EFI_UGA_DRAW_PROTOCOL                  *UgaDraw;
 | 
						|
  UINT32                                 ColorDepth;
 | 
						|
  UINT32                                 RefreshRate;
 | 
						|
  EFI_GRAPHICS_OUTPUT_PROTOCOL           *GraphicsOutput;
 | 
						|
  EFI_BOOT_LOGO_PROTOCOL                 *BootLogo;
 | 
						|
  EDKII_BOOT_LOGO2_PROTOCOL              *BootLogo2;
 | 
						|
  UINTN                                  NumberOfLogos;
 | 
						|
  EFI_GRAPHICS_OUTPUT_BLT_PIXEL          *LogoBlt;
 | 
						|
  UINTN                                  LogoDestX;
 | 
						|
  UINTN                                  LogoDestY;
 | 
						|
  UINTN                                  LogoHeight;
 | 
						|
  UINTN                                  LogoWidth;
 | 
						|
  UINTN                                  NewDestX;
 | 
						|
  UINTN                                  NewDestY;
 | 
						|
  UINTN                                  BufferSize;
 | 
						|
 | 
						|
  Status = gBS->LocateProtocol (&gEdkiiPlatformLogoProtocolGuid, NULL, (VOID **)&PlatformLogo);
 | 
						|
  if (EFI_ERROR (Status)) {
 | 
						|
    return EFI_UNSUPPORTED;
 | 
						|
  }
 | 
						|
 | 
						|
  UgaDraw = NULL;
 | 
						|
  //
 | 
						|
  // Try to open GOP first
 | 
						|
  //
 | 
						|
  Status = gBS->HandleProtocol (gST->ConsoleOutHandle, &gEfiGraphicsOutputProtocolGuid, (VOID **)&GraphicsOutput);
 | 
						|
  if (EFI_ERROR (Status) && FeaturePcdGet (PcdUgaConsumeSupport)) {
 | 
						|
    GraphicsOutput = NULL;
 | 
						|
    //
 | 
						|
    // Open GOP failed, try to open UGA
 | 
						|
    //
 | 
						|
    Status = gBS->HandleProtocol (gST->ConsoleOutHandle, &gEfiUgaDrawProtocolGuid, (VOID **)&UgaDraw);
 | 
						|
    if (EFI_ERROR (Status)) {
 | 
						|
      UgaDraw = NULL;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  if (EFI_ERROR (Status)) {
 | 
						|
    return EFI_UNSUPPORTED;
 | 
						|
  }
 | 
						|
 | 
						|
  //
 | 
						|
  // Try to open Boot Logo Protocol.
 | 
						|
  //
 | 
						|
  Status = gBS->LocateProtocol (&gEfiBootLogoProtocolGuid, NULL, (VOID **)&BootLogo);
 | 
						|
  if (EFI_ERROR (Status)) {
 | 
						|
    BootLogo = NULL;
 | 
						|
  }
 | 
						|
 | 
						|
  //
 | 
						|
  // Try to open Boot Logo 2 Protocol.
 | 
						|
  //
 | 
						|
  Status = gBS->LocateProtocol (&gEdkiiBootLogo2ProtocolGuid, NULL, (VOID **)&BootLogo2);
 | 
						|
  if (EFI_ERROR (Status)) {
 | 
						|
    BootLogo2 = NULL;
 | 
						|
  }
 | 
						|
 | 
						|
  //
 | 
						|
  // Erase Cursor from screen
 | 
						|
  //
 | 
						|
  gST->ConOut->EnableCursor (gST->ConOut, FALSE);
 | 
						|
 | 
						|
  if (GraphicsOutput != NULL) {
 | 
						|
    SizeOfX = GraphicsOutput->Mode->Info->HorizontalResolution;
 | 
						|
    SizeOfY = GraphicsOutput->Mode->Info->VerticalResolution;
 | 
						|
  } else {
 | 
						|
    ASSERT (UgaDraw != NULL);
 | 
						|
    Status = UgaDraw->GetMode (UgaDraw, &SizeOfX, &SizeOfY, &ColorDepth, &RefreshRate);
 | 
						|
    if (EFI_ERROR (Status)) {
 | 
						|
      return EFI_UNSUPPORTED;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  Blt           = NULL;
 | 
						|
  NumberOfLogos = 0;
 | 
						|
  LogoDestX     = 0;
 | 
						|
  LogoDestY     = 0;
 | 
						|
  LogoHeight    = 0;
 | 
						|
  LogoWidth     = 0;
 | 
						|
  NewDestX      = 0;
 | 
						|
  NewDestY      = 0;
 | 
						|
  Instance      = 0;
 | 
						|
  DestX         = 0;
 | 
						|
  DestY         = 0;
 | 
						|
  while (TRUE) {
 | 
						|
    //
 | 
						|
    // Get image from PlatformLogo protocol.
 | 
						|
    //
 | 
						|
    Status = PlatformLogo->GetImage (
 | 
						|
                             PlatformLogo,
 | 
						|
                             &Instance,
 | 
						|
                             &Image,
 | 
						|
                             &Attribute,
 | 
						|
                             &OffsetX,
 | 
						|
                             &OffsetY
 | 
						|
                             );
 | 
						|
    if (EFI_ERROR (Status)) {
 | 
						|
      break;
 | 
						|
    }
 | 
						|
 | 
						|
    if (Blt != NULL) {
 | 
						|
      FreePool (Blt);
 | 
						|
    }
 | 
						|
 | 
						|
    Blt = Image.Bitmap;
 | 
						|
 | 
						|
    //
 | 
						|
    // Calculate the display position according to Attribute.
 | 
						|
    //
 | 
						|
    switch (Attribute) {
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeLeftTop:
 | 
						|
        DestX = 0;
 | 
						|
        DestY = 0;
 | 
						|
        break;
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeCenterTop:
 | 
						|
        DestX = (SizeOfX - Image.Width) / 2;
 | 
						|
        DestY = 0;
 | 
						|
        break;
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeRightTop:
 | 
						|
        DestX = SizeOfX - Image.Width;
 | 
						|
        DestY = 0;
 | 
						|
        break;
 | 
						|
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeCenterLeft:
 | 
						|
        DestX = 0;
 | 
						|
        DestY = (SizeOfY - Image.Height) / 2;
 | 
						|
        break;
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeCenter:
 | 
						|
        DestX = (SizeOfX - Image.Width) / 2;
 | 
						|
        DestY = (SizeOfY * 382) / 1000 - Image.Height / 2;
 | 
						|
        break;
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeCenterRight:
 | 
						|
        DestX = SizeOfX - Image.Width;
 | 
						|
        DestY = (SizeOfY - Image.Height) / 2;
 | 
						|
        break;
 | 
						|
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeLeftBottom:
 | 
						|
        DestX = 0;
 | 
						|
        DestY = SizeOfY - Image.Height;
 | 
						|
        break;
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeCenterBottom:
 | 
						|
        DestX = (SizeOfX - Image.Width) / 2;
 | 
						|
        DestY = SizeOfY - Image.Height;
 | 
						|
        break;
 | 
						|
      case EdkiiPlatformLogoDisplayAttributeRightBottom:
 | 
						|
        DestX = SizeOfX - Image.Width;
 | 
						|
        DestY = SizeOfY - Image.Height;
 | 
						|
        break;
 | 
						|
 | 
						|
      default:
 | 
						|
        ASSERT (FALSE);
 | 
						|
        continue;
 | 
						|
        break;
 | 
						|
    }
 | 
						|
 | 
						|
    DestX += OffsetX;
 | 
						|
    DestY += OffsetY;
 | 
						|
 | 
						|
    if ((DestX >= 0) && (DestY >= 0)) {
 | 
						|
      if (GraphicsOutput != NULL) {
 | 
						|
        Status = GraphicsOutput->Blt (
 | 
						|
                                   GraphicsOutput,
 | 
						|
                                   Blt,
 | 
						|
                                   EfiBltBufferToVideo,
 | 
						|
                                   0,
 | 
						|
                                   0,
 | 
						|
                                   (UINTN)DestX,
 | 
						|
                                   (UINTN)DestY,
 | 
						|
                                   Image.Width,
 | 
						|
                                   Image.Height,
 | 
						|
                                   Image.Width * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)
 | 
						|
                                   );
 | 
						|
      } else {
 | 
						|
        ASSERT (UgaDraw != NULL);
 | 
						|
        Status = UgaDraw->Blt (
 | 
						|
                            UgaDraw,
 | 
						|
                            (EFI_UGA_PIXEL *)Blt,
 | 
						|
                            EfiUgaBltBufferToVideo,
 | 
						|
                            0,
 | 
						|
                            0,
 | 
						|
                            (UINTN)DestX,
 | 
						|
                            (UINTN)DestY,
 | 
						|
                            Image.Width,
 | 
						|
                            Image.Height,
 | 
						|
                            Image.Width * sizeof (EFI_UGA_PIXEL)
 | 
						|
                            );
 | 
						|
      }
 | 
						|
 | 
						|
      //
 | 
						|
      // Report displayed Logo information.
 | 
						|
      //
 | 
						|
      if (!EFI_ERROR (Status)) {
 | 
						|
        NumberOfLogos++;
 | 
						|
 | 
						|
        if (NumberOfLogos == 1) {
 | 
						|
          //
 | 
						|
          // The first Logo.
 | 
						|
          //
 | 
						|
          LogoDestX  = (UINTN)DestX;
 | 
						|
          LogoDestY  = (UINTN)DestY;
 | 
						|
          LogoWidth  = Image.Width;
 | 
						|
          LogoHeight = Image.Height;
 | 
						|
        } else {
 | 
						|
          //
 | 
						|
          // Merge new logo with old one.
 | 
						|
          //
 | 
						|
          NewDestX   = MIN ((UINTN)DestX, LogoDestX);
 | 
						|
          NewDestY   = MIN ((UINTN)DestY, LogoDestY);
 | 
						|
          LogoWidth  = MAX ((UINTN)DestX + Image.Width, LogoDestX + LogoWidth) - NewDestX;
 | 
						|
          LogoHeight = MAX ((UINTN)DestY + Image.Height, LogoDestY + LogoHeight) - NewDestY;
 | 
						|
 | 
						|
          LogoDestX = NewDestX;
 | 
						|
          LogoDestY = NewDestY;
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  if (((BootLogo == NULL) && (BootLogo2 == NULL)) || (NumberOfLogos == 0)) {
 | 
						|
    //
 | 
						|
    // No logo displayed.
 | 
						|
    //
 | 
						|
    if (Blt != NULL) {
 | 
						|
      FreePool (Blt);
 | 
						|
    }
 | 
						|
 | 
						|
    return Status;
 | 
						|
  }
 | 
						|
 | 
						|
  //
 | 
						|
  // Advertise displayed Logo information.
 | 
						|
  //
 | 
						|
  if (NumberOfLogos == 1) {
 | 
						|
    //
 | 
						|
    // Only one logo displayed, use its Blt buffer directly for BootLogo protocol.
 | 
						|
    //
 | 
						|
    LogoBlt = Blt;
 | 
						|
    Status  = EFI_SUCCESS;
 | 
						|
  } else {
 | 
						|
    //
 | 
						|
    // More than one Logo displayed, get merged BltBuffer using VideoToBuffer operation.
 | 
						|
    //
 | 
						|
    if (Blt != NULL) {
 | 
						|
      FreePool (Blt);
 | 
						|
    }
 | 
						|
 | 
						|
    //
 | 
						|
    // Ensure the LogoHeight * LogoWidth * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL) doesn't overflow
 | 
						|
    //
 | 
						|
    if (LogoHeight > MAX_UINTN / LogoWidth / sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)) {
 | 
						|
      return EFI_UNSUPPORTED;
 | 
						|
    }
 | 
						|
 | 
						|
    BufferSize = LogoWidth * LogoHeight * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL);
 | 
						|
 | 
						|
    LogoBlt = AllocatePool (BufferSize);
 | 
						|
    if (LogoBlt == NULL) {
 | 
						|
      return EFI_OUT_OF_RESOURCES;
 | 
						|
    }
 | 
						|
 | 
						|
    if (GraphicsOutput != NULL) {
 | 
						|
      Status = GraphicsOutput->Blt (
 | 
						|
                                 GraphicsOutput,
 | 
						|
                                 LogoBlt,
 | 
						|
                                 EfiBltVideoToBltBuffer,
 | 
						|
                                 LogoDestX,
 | 
						|
                                 LogoDestY,
 | 
						|
                                 0,
 | 
						|
                                 0,
 | 
						|
                                 LogoWidth,
 | 
						|
                                 LogoHeight,
 | 
						|
                                 LogoWidth * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)
 | 
						|
                                 );
 | 
						|
    } else {
 | 
						|
      Status = UgaDraw->Blt (
 | 
						|
                          UgaDraw,
 | 
						|
                          (EFI_UGA_PIXEL *)LogoBlt,
 | 
						|
                          EfiUgaVideoToBltBuffer,
 | 
						|
                          LogoDestX,
 | 
						|
                          LogoDestY,
 | 
						|
                          0,
 | 
						|
                          0,
 | 
						|
                          LogoWidth,
 | 
						|
                          LogoHeight,
 | 
						|
                          LogoWidth * sizeof (EFI_UGA_PIXEL)
 | 
						|
                          );
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  if (!EFI_ERROR (Status)) {
 | 
						|
    //
 | 
						|
    // Attempt to register logo with Boot Logo 2 Protocol first
 | 
						|
    //
 | 
						|
    if (BootLogo2 != NULL) {
 | 
						|
      Status = BootLogo2->SetBootLogo (BootLogo2, LogoBlt, LogoDestX, LogoDestY, LogoWidth, LogoHeight);
 | 
						|
    }
 | 
						|
 | 
						|
    //
 | 
						|
    // If Boot Logo 2 Protocol is not available or registration with Boot Logo 2
 | 
						|
    // Protocol failed, then attempt to register logo with Boot Logo Protocol
 | 
						|
    //
 | 
						|
    if (EFI_ERROR (Status) && (BootLogo != NULL)) {
 | 
						|
      Status = BootLogo->SetBootLogo (BootLogo, LogoBlt, LogoDestX, LogoDestY, LogoWidth, LogoHeight);
 | 
						|
    }
 | 
						|
 | 
						|
    //
 | 
						|
    // Status of this function is EFI_SUCCESS even if registration with Boot
 | 
						|
    // Logo 2 Protocol or Boot Logo Protocol fails.
 | 
						|
    //
 | 
						|
    Status = EFI_SUCCESS;
 | 
						|
  }
 | 
						|
 | 
						|
  FreePool (LogoBlt);
 | 
						|
 | 
						|
  return Status;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
  Use SystemTable Conout to turn on video based Simple Text Out consoles. The
 | 
						|
  Simple Text Out screens will now be synced up with all non video output devices
 | 
						|
 | 
						|
  @retval EFI_SUCCESS     UGA devices are back in text mode and synced up.
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
BootLogoDisableLogo (
 | 
						|
  VOID
 | 
						|
  )
 | 
						|
{
 | 
						|
  //
 | 
						|
  // Enable Cursor on Screen
 | 
						|
  //
 | 
						|
  gST->ConOut->EnableCursor (gST->ConOut, TRUE);
 | 
						|
  return EFI_SUCCESS;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Update progress bar with title above it. It only works in Graphics mode.
 | 
						|
 | 
						|
  @param TitleForeground Foreground color for Title.
 | 
						|
  @param TitleBackground Background color for Title.
 | 
						|
  @param Title           Title above progress bar.
 | 
						|
  @param ProgressColor   Progress bar color.
 | 
						|
  @param Progress        Progress (0-100)
 | 
						|
  @param PreviousValue   The previous value of the progress.
 | 
						|
 | 
						|
  @retval  EFI_STATUS       Success update the progress bar
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
BootLogoUpdateProgress (
 | 
						|
  IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL  TitleForeground,
 | 
						|
  IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL  TitleBackground,
 | 
						|
  IN CHAR16                         *Title,
 | 
						|
  IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL  ProgressColor,
 | 
						|
  IN UINTN                          Progress,
 | 
						|
  IN UINTN                          PreviousValue
 | 
						|
  )
 | 
						|
{
 | 
						|
  EFI_STATUS                     Status;
 | 
						|
  EFI_GRAPHICS_OUTPUT_PROTOCOL   *GraphicsOutput;
 | 
						|
  EFI_UGA_DRAW_PROTOCOL          *UgaDraw;
 | 
						|
  UINT32                         SizeOfX;
 | 
						|
  UINT32                         SizeOfY;
 | 
						|
  UINT32                         ColorDepth;
 | 
						|
  UINT32                         RefreshRate;
 | 
						|
  EFI_GRAPHICS_OUTPUT_BLT_PIXEL  Color;
 | 
						|
  UINTN                          BlockHeight;
 | 
						|
  UINTN                          BlockWidth;
 | 
						|
  UINTN                          BlockNum;
 | 
						|
  UINTN                          PosX;
 | 
						|
  UINTN                          PosY;
 | 
						|
  UINTN                          Index;
 | 
						|
 | 
						|
  if (Progress > 100) {
 | 
						|
    return EFI_INVALID_PARAMETER;
 | 
						|
  }
 | 
						|
 | 
						|
  UgaDraw = NULL;
 | 
						|
  Status  = gBS->HandleProtocol (gST->ConsoleOutHandle, &gEfiGraphicsOutputProtocolGuid, (VOID **)&GraphicsOutput);
 | 
						|
  if (EFI_ERROR (Status) && FeaturePcdGet (PcdUgaConsumeSupport)) {
 | 
						|
    GraphicsOutput = NULL;
 | 
						|
 | 
						|
    Status = gBS->HandleProtocol (gST->ConsoleOutHandle, &gEfiUgaDrawProtocolGuid, (VOID **)&UgaDraw);
 | 
						|
    if (EFI_ERROR (Status)) {
 | 
						|
      UgaDraw = NULL;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  if (EFI_ERROR (Status)) {
 | 
						|
    return EFI_UNSUPPORTED;
 | 
						|
  }
 | 
						|
 | 
						|
  SizeOfX = 0;
 | 
						|
  SizeOfY = 0;
 | 
						|
  if (GraphicsOutput != NULL) {
 | 
						|
    SizeOfX = GraphicsOutput->Mode->Info->HorizontalResolution;
 | 
						|
    SizeOfY = GraphicsOutput->Mode->Info->VerticalResolution;
 | 
						|
  } else if (UgaDraw != NULL) {
 | 
						|
    Status = UgaDraw->GetMode (
 | 
						|
                        UgaDraw,
 | 
						|
                        &SizeOfX,
 | 
						|
                        &SizeOfY,
 | 
						|
                        &ColorDepth,
 | 
						|
                        &RefreshRate
 | 
						|
                        );
 | 
						|
    if (EFI_ERROR (Status)) {
 | 
						|
      return EFI_UNSUPPORTED;
 | 
						|
    }
 | 
						|
  } else {
 | 
						|
    return EFI_UNSUPPORTED;
 | 
						|
  }
 | 
						|
 | 
						|
  BlockWidth  = SizeOfX / 100;
 | 
						|
  BlockHeight = SizeOfY / 50;
 | 
						|
 | 
						|
  BlockNum = Progress;
 | 
						|
 | 
						|
  PosX = 0;
 | 
						|
  PosY = SizeOfY * 48 / 50;
 | 
						|
 | 
						|
  if (BlockNum == 0) {
 | 
						|
    //
 | 
						|
    // Clear progress area
 | 
						|
    //
 | 
						|
    SetMem (&Color, sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL), 0x0);
 | 
						|
 | 
						|
    if (GraphicsOutput != NULL) {
 | 
						|
      Status = GraphicsOutput->Blt (
 | 
						|
                                 GraphicsOutput,
 | 
						|
                                 &Color,
 | 
						|
                                 EfiBltVideoFill,
 | 
						|
                                 0,
 | 
						|
                                 0,
 | 
						|
                                 0,
 | 
						|
                                 PosY - EFI_GLYPH_HEIGHT - 1,
 | 
						|
                                 SizeOfX,
 | 
						|
                                 SizeOfY - (PosY - EFI_GLYPH_HEIGHT - 1),
 | 
						|
                                 SizeOfX * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)
 | 
						|
                                 );
 | 
						|
    } else if (FeaturePcdGet (PcdUgaConsumeSupport)) {
 | 
						|
      Status = UgaDraw->Blt (
 | 
						|
                          UgaDraw,
 | 
						|
                          (EFI_UGA_PIXEL *)&Color,
 | 
						|
                          EfiUgaVideoFill,
 | 
						|
                          0,
 | 
						|
                          0,
 | 
						|
                          0,
 | 
						|
                          PosY - EFI_GLYPH_HEIGHT - 1,
 | 
						|
                          SizeOfX,
 | 
						|
                          SizeOfY - (PosY - EFI_GLYPH_HEIGHT - 1),
 | 
						|
                          SizeOfX * sizeof (EFI_UGA_PIXEL)
 | 
						|
                          );
 | 
						|
    } else {
 | 
						|
      return EFI_UNSUPPORTED;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  //
 | 
						|
  // Show progress by drawing blocks
 | 
						|
  //
 | 
						|
  for (Index = PreviousValue; Index < BlockNum; Index++) {
 | 
						|
    PosX = Index * BlockWidth;
 | 
						|
    if (GraphicsOutput != NULL) {
 | 
						|
      Status = GraphicsOutput->Blt (
 | 
						|
                                 GraphicsOutput,
 | 
						|
                                 &ProgressColor,
 | 
						|
                                 EfiBltVideoFill,
 | 
						|
                                 0,
 | 
						|
                                 0,
 | 
						|
                                 PosX,
 | 
						|
                                 PosY,
 | 
						|
                                 BlockWidth - 1,
 | 
						|
                                 BlockHeight,
 | 
						|
                                 (BlockWidth) * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)
 | 
						|
                                 );
 | 
						|
    } else if (FeaturePcdGet (PcdUgaConsumeSupport)) {
 | 
						|
      Status = UgaDraw->Blt (
 | 
						|
                          UgaDraw,
 | 
						|
                          (EFI_UGA_PIXEL *)&ProgressColor,
 | 
						|
                          EfiUgaVideoFill,
 | 
						|
                          0,
 | 
						|
                          0,
 | 
						|
                          PosX,
 | 
						|
                          PosY,
 | 
						|
                          BlockWidth - 1,
 | 
						|
                          BlockHeight,
 | 
						|
                          (BlockWidth) * sizeof (EFI_UGA_PIXEL)
 | 
						|
                          );
 | 
						|
    } else {
 | 
						|
      return EFI_UNSUPPORTED;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  PrintXY (
 | 
						|
    (SizeOfX - StrLen (Title) * EFI_GLYPH_WIDTH) / 2,
 | 
						|
    PosY - EFI_GLYPH_HEIGHT - 1,
 | 
						|
    &TitleForeground,
 | 
						|
    &TitleBackground,
 | 
						|
    Title
 | 
						|
    );
 | 
						|
 | 
						|
  return EFI_SUCCESS;
 | 
						|
}
 |