2007-06-22 11:15:22 +02:00
|
|
|
/** @file
|
2009-01-04 04:20:55 +01:00
|
|
|
This sample application bases on HelloWorld PCD setting
|
|
|
|
to print "UEFI Hello World!" to the UEFI Console.
|
|
|
|
|
2016-02-21 08:55:14 +01:00
|
|
|
Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR>
|
2010-04-24 11:49:11 +02:00
|
|
|
This program and the accompanying materials
|
2007-06-22 11:15:22 +02:00
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
2007-06-22 19:08:39 +02:00
|
|
|
#include <Uefi.h>
|
2008-09-19 07:05:40 +02:00
|
|
|
#include <Library/PcdLib.h>
|
2007-06-22 19:08:39 +02:00
|
|
|
#include <Library/UefiLib.h>
|
|
|
|
#include <Library/UefiApplicationEntryPoint.h>
|
2007-06-22 11:15:22 +02:00
|
|
|
|
2016-02-21 08:55:14 +01:00
|
|
|
//
|
|
|
|
// String token ID of help message text.
|
|
|
|
// Shell supports to find help message in the resource section of an application image if
|
|
|
|
// .MAN file is not found. This global variable is added to make build tool recognizes
|
|
|
|
// that the help string is consumed by user and then build tool will add the string into
|
|
|
|
// the resource section. Thus the application can use '-?' option to show help message in
|
|
|
|
// Shell.
|
|
|
|
//
|
|
|
|
GLOBAL_REMOVE_IF_UNREFERENCED EFI_STRING_ID mStringHelpTokenId = STRING_TOKEN (STR_HELLO_WORLD_HELP_INFORMATION);
|
2007-06-26 02:32:26 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
The user Entry Point for Application. The user code starts with this function
|
2009-01-04 04:20:55 +01:00
|
|
|
as the real entry point for the application.
|
2007-06-26 02:32:26 +02:00
|
|
|
|
|
|
|
@param[in] ImageHandle The firmware allocated handle for the EFI image.
|
|
|
|
@param[in] SystemTable A pointer to the EFI System Table.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The entry point is executed successfully.
|
|
|
|
@retval other Some error occurs when executing this entry point.
|
|
|
|
|
|
|
|
**/
|
2007-06-22 11:15:22 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
UefiMain (
|
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
|
|
|
)
|
|
|
|
{
|
2008-09-19 07:05:40 +02:00
|
|
|
UINT32 Index;
|
|
|
|
|
|
|
|
Index = 0;
|
2007-06-22 11:15:22 +02:00
|
|
|
|
2008-09-19 07:05:40 +02:00
|
|
|
//
|
|
|
|
// Three PCD type (FeatureFlag, UINT32 and String) are used as the sample.
|
|
|
|
//
|
|
|
|
if (FeaturePcdGet (PcdHelloWorldPrintEnable)) {
|
|
|
|
for (Index = 0; Index < PcdGet32 (PcdHelloWorldPrintTimes); Index ++) {
|
2009-01-04 04:20:55 +01:00
|
|
|
//
|
|
|
|
// Use UefiLib Print API to print string to UEFI console
|
|
|
|
//
|
2008-09-19 07:05:40 +02:00
|
|
|
Print ((CHAR16*)PcdGetPtr (PcdHelloWorldPrintString));
|
|
|
|
}
|
|
|
|
}
|
2007-06-22 11:15:22 +02:00
|
|
|
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|