4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/** @file
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This library implements the Extended SAL Library Class for use in boot services and runtime.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This program and the accompanying materials
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync are licensed and made available under the terms and conditions of the BSD License
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync which accompanies this distribution. The full text of the license may be found at
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync http://opensource.org/licenses/bsd-license.php.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <PiDxe.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Protocol/ExtendedSalBootService.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Protocol/ExtendedSalServiceClasses.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Guid/EventGroup.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Library/ExtendedSalLib.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Library/UefiBootServicesTableLib.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Library/UefiRuntimeServicesTableLib.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Library/UefiRuntimeLib.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync#include <Library/DebugLib.h>
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Stores the virtual plabel of ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This assembly function stores the virtual plabel of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync where GetEsalEntryPoint() can easily retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param EntryPoint Virtual address of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Gp Virtual GP of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return r8 = EFI_SAL_SUCCESS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSetEsalVirtualEntryPoint (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 EntryPoint,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Gp
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Stores the physical plabel of ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This assembly function stores the physical plabel of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync where GetEsalEntryPoint() can easily retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param EntryPoint Physical address of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Gp Physical GP of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return r8 = EFI_SAL_SUCCESS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSetEsalPhysicalEntryPoint (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 EntryPoint,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Gp
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Retrieves plabel of ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function retrives plabel of ESAL entrypoint stored by
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SetEsalPhysicalEntryPoint().
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return r8 = EFI_SAL_SUCCESS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync r9 = Physical Plabel
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync r10 = Virtual Plabel
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync r11 = PSR
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncGetEsalEntryPoint (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VOID
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEXTENDED_SAL_BOOT_SERVICE_PROTOCOL *mEsalBootService = NULL;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_PLABEL mPlabel;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_EVENT mEfiVirtualNotifyEvent;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Notification function of EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE to set virtual plabel of
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This is a notification function registered on EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE event.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync It converts physical plabel of ESAL entrypoint to virtual plabel and stores it where
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync GetEsalEntryPoint() can easily retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Event Event whose notification function is being invoked.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Context Pointer to the notification function's context
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncVOID
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncExtendedSalVirtualNotifyEvent (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_EVENT Event,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN VOID *Context
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync UINT64 PhysicalEntryPoint;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PhysicalEntryPoint = mPlabel.EntryPoint;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync gRT->ConvertPointer (0x0, (VOID **) &mPlabel.EntryPoint);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync mPlabel.GP += mPlabel.EntryPoint - PhysicalEntryPoint;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SetEsalVirtualEntryPoint (mPlabel.EntryPoint, mPlabel.GP);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Gets Extended SAL Boot Service Protocol, and initializes physical plabel of
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function first locates Extended SAL Boot Service Protocol and caches it in global variable.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Then it initializes the physical plable of ESAL entrypoint, and stores
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync it where GetEsalEntryPoint() can easily retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS Plable of ESAL entrypoint successfully stored.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_STATUS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncDxeSalLibInitialize (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VOID
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_PLABEL *Plabel;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_STATUS Status;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // The protocol contains a function pointer, which is an indirect procedure call.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // An indirect procedure call goes through a plabel, and pointer to a function is
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // a pointer to a plabel. To implement indirect procedure calls that can work in
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // both physical and virtual mode, two plabels are required (one physical and one
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // virtual). So lets grap the physical PLABEL for the EsalEntryPoint and store it
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // away. We cache it in a module global, so we can register the vitrual version.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Status = gBS->LocateProtocol (&gEfiExtendedSalBootServiceProtocolGuid, NULL, (VOID **) &mEsalBootService);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ASSERT_EFI_ERROR (Status);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Plabel = (EFI_PLABEL *) (UINTN) mEsalBootService->ExtendedSalProc;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync mPlabel.EntryPoint = Plabel->EntryPoint;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync mPlabel.GP = Plabel->GP;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Stores the physical plabel of ESAL entrypoint where GetEsalEntryPoint() can easily retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SetEsalPhysicalEntryPoint (mPlabel.EntryPoint, mPlabel.GP);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EFI_SUCCESS;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Constructor function to initializes physical plabel of ESAL entrypoint and register an event
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync for initialization of virtual plabel of ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This is the library constructor function to call a function to initialize physical plabel of ESAL entrypoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync and to register notification function for
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE, which sets virtual plabel of ESAL entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ImageHandle The firmware allocated handle for the EFI image.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param SystemTable A pointer to the EFI System Table.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS Notification function successfully registered.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_STATUS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncDxeRuntimeExtendedSalLibConstruct (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_HANDLE ImageHandle,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_SYSTEM_TABLE *SystemTable
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_STATUS Status;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Register notify function for EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ASSERT (gBS != NULL);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync DxeSalLibInitialize ();
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Status = gBS->CreateEventEx (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EVT_NOTIFY_SIGNAL,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync TPL_NOTIFY,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ExtendedSalVirtualNotifyEvent,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync NULL,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync &gEfiEventVirtualAddressChangeGuid,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync &mEfiVirtualNotifyEvent
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ASSERT_EFI_ERROR (Status);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EFI_SUCCESS;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Destructor function to close the event created by the library constructor
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This is the library destructor function to close the event with type of
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EVT_SIGNAL_VIRTUAL_ADDRESS_CHANGE, which is created by the library constructor.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ImageHandle The firmware allocated handle for the EFI image.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param SystemTable A pointer to the EFI System Table.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS Event successfully closed.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_STATUS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncDxeRuntimeExtendedSalLibDeconstruct (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_HANDLE ImageHandle,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_SYSTEM_TABLE *SystemTable
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_STATUS Status;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Close SetVirtualAddressMap () notify function
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ASSERT (gBS != NULL);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Status = gBS->CloseEvent (mEfiVirtualNotifyEvent);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ASSERT_EFI_ERROR (Status);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EFI_SUCCESS;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Registers function of ESAL class and it's associated global.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function registers function of ESAL class, together with its associated global.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync It is worker function for RegisterEsalClass().
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync It is only for boot time.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param FunctionId ID of function to register
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ClassGuidLo GUID of ESAL class, lower 64-bits
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ClassGuidHi GUID of ESAL class, upper 64-bits
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Function Function to register with ClassGuid/FunctionId pair
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ModuleGlobal Module global for the function.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return Status returned by RegisterExtendedSalProc() of Extended SAL Boot Service Protocol
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_STATUS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncRegisterEsalFunction (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 FunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 ClassGuidLo,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 ClassGuidHi,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN SAL_INTERNAL_EXTENDED_SAL_PROC Function,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN VOID *ModuleGlobal
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return mEsalBootService->RegisterExtendedSalProc (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync mEsalBootService,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ClassGuidLo,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ClassGuidHi,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync FunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Function,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ModuleGlobal
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Registers ESAL Class and it's associated global.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function registers one or more Extended SAL services in a given
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync class along with the associated global context.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is only available prior to ExitBootServices().
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ClassGuidLo GUID of function class, lower 64-bits
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ClassGuidHi GUID of function class, upper 64-bits
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ModuleGlobal Module global for the class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ... List of Function/FunctionId pairs, ended by NULL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS The Extended SAL services were registered.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_UNSUPPORTED This function was called after ExitBootServices().
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_OUT_OF_RESOURCES There are not enough resources available to register one or more of the specified services.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval Other ClassGuid could not be installed onto a new handle.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFI_STATUS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncRegisterEsalClass (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN CONST UINT64 ClassGuidLo,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN CONST UINT64 ClassGuidHi,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN VOID *ModuleGlobal, OPTIONAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ...
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VA_LIST Args;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_STATUS Status;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SAL_INTERNAL_EXTENDED_SAL_PROC Function;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync UINT64 FunctionId;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_HANDLE NewHandle;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_GUID ClassGuid;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VA_START (Args, ModuleGlobal);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Register all functions of the class to register.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Status = EFI_SUCCESS;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync while (!EFI_ERROR (Status)) {
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Function = (SAL_INTERNAL_EXTENDED_SAL_PROC) VA_ARG (Args, SAL_INTERNAL_EXTENDED_SAL_PROC);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // NULL serves as the end mark of function list
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync if (Function == NULL) {
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync break;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync }
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync FunctionId = VA_ARG (Args, UINT64);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Status = RegisterEsalFunction (FunctionId, ClassGuidLo, ClassGuidHi, Function, ModuleGlobal);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync }
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VA_END (Args);
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync if (EFI_ERROR (Status)) {
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return Status;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync }
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync NewHandle = NULL;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync *((UINT64 *)(&ClassGuid) + 0) = ClassGuidLo;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync *((UINT64 *)(&ClassGuid) + 1) = ClassGuidHi;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return gBS->InstallProtocolInterface (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync &NewHandle,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync &ClassGuid,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_NATIVE_INTERFACE,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync NULL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Calls an Extended SAL Class service that was previously registered with RegisterEsalClass().
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function gets the entrypoint of Extended SAL, and calls an Extended SAL Class service
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync that was previously registered with RegisterEsalClass() through this entrypoint.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ClassGuidLo GUID of function, lower 64-bits
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ClassGuidHi GUID of function, upper 64-bits
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param FunctionId Function in ClassGuid to call
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg2 Argument 2 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg3 Argument 3 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg4 Argument 4 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg5 Argument 5 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg6 Argument 6 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg7 Argument 7 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Arg8 Argument 8 ClassGuid/FunctionId defined
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS ESAL procedure successfully called.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_ERROR The address of ExtendedSalProc() can not be correctly
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync initialized.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval Other Status returned from ExtendedSalProc() service of
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EXTENDED_SAL_BOOT_SERVICE_PROTOCOL.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 ClassGuidLo,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 ClassGuidHi,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 FunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg2,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg3,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg4,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg5,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg6,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg7,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Arg8
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SAL_RETURN_REGS ReturnReg;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EXTENDED_SAL_PROC EsalProc;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Get the entrypoint of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ReturnReg = GetEsalEntryPoint ();
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync if (*(UINT64 *)ReturnReg.r9 == 0 && *(UINT64 *)(ReturnReg.r9 + 8) == 0) {
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // The ESAL Entry Point could not be initialized
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ReturnReg.Status = EFI_SAL_ERROR;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return ReturnReg;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync }
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Test PSR.it which is BIT36
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync if ((ReturnReg.r11 & BIT36) != 0) {
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Virtual mode plabel to entry point
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalProc = (EXTENDED_SAL_PROC) ReturnReg.r10;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync } else {
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync // Physical mode plabel to entry point
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync //
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalProc = (EXTENDED_SAL_PROC) ReturnReg.r9;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync }
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalProc (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ClassGuidLo,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ClassGuidHi,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync FunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg2,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg3,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg4,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg5,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg6,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg7,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Arg8
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalStallFunctionId service of Extended SAL Stall Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalStallFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Stall Services Class. See EsalStallFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Microseconds The number of microseconds to delay.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS Call completed without error.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_INVALID_ARGUMENT Invalid argument.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_VIRTUAL_ADDRESS_ERROR Virtual address not registered
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalStall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINTN Microseconds
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_STALL_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_STALL_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync StallFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Microseconds,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalSetNewPalEntryFunctionId service of Extended SAL PAL Services Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalSetNewPalEntryFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PAL Services Services Class. See EsalSetNewPalEntryFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param PhysicalAddress If TRUE, then PalEntryPoint is a physical address.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync If FALSE, then PalEntryPoint is a virtual address.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param PalEntryPoint The PAL Entry Point being set.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The PAL Entry Point was set.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_VIRTUAL_ADDRESS_ERROR This function was called in virtual mode before
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync virtual mappings for the specified Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Procedure are available.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalSetNewPalEntry (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN PhysicalAddress,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 PalEntryPoint
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_PAL_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_PAL_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SetNewPalEntryFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PhysicalAddress,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PalEntryPoint,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetNewPalEntryFunctionId service of Extended SAL PAL Services Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetNewPalEntryFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PAL Services Services Class. See EsalGetNewPalEntryFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param PhysicalAddress If TRUE, then PalEntryPoint is a physical address.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync If FALSE, then PalEntryPoint is a virtual address.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The PAL Entry Point was retrieved and returned in
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SAL_RETURN_REGS.r9.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_VIRTUAL_ADDRESS_ERROR This function was called in virtual mode before
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync virtual mappings for the specified Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Procedure are available.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return r9 PAL entry point retrieved.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetNewPalEntry (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN PhysicalAddress
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_PAL_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_PAL_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync GetNewPalEntryFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PhysicalAddress,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetStateBufferFunctionId service of Extended SAL MCA Log Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetStateBufferFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MCA Log Services Class. See EsalGetStateBufferFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param McaType See type parameter of SAL Procedure SAL_GET_STATE_INFO.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param McaBuffer A pointer to the base address of the returned buffer.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Copied from SAL_RETURN_REGS.r9.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param BufferSize A pointer to the size, in bytes, of the returned buffer.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Copied from SAL_RETURN_REGS.r10.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The memory buffer to store error records was returned in r9 and r10.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_OUT_OF_RESOURCES A memory buffer for string error records in not available
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return r9 Base address of the returned buffer
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @return r10 Size of the returned buffer in bytes
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetStateBuffer (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 McaType,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync OUT UINT8 **McaBuffer,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync OUT UINTN *BufferSize
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SAL_RETURN_REGS Regs;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Regs = EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_LOG_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_LOG_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalGetStateBufferFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync McaType,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync *McaBuffer = (UINT8 *) Regs.r9;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync *BufferSize = Regs.r10;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return Regs;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalSaveStateBufferFunctionId service of Extended SAL MCA Log Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalSaveStateBufferFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MCA Log Services Class. See EsalSaveStateBufferFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param McaType See type parameter of SAL Procedure SAL_GET_STATE_INFO.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS The memory buffer containing the error record was written to nonvolatile storage.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalSaveStateBuffer (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 McaType
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_LOG_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_LOG_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalSaveStateBufferFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync McaType,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetVectorsFunctionId service of Extended SAL Base Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetVectorsFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Base Services Class. See EsalGetVectorsFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param VectorType The vector type to retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0 - MCA, 1 - BSP INIT, 2 - BOOT_RENDEZ, 3 - AP INIT.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS Call completed without error.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_INVALID_ARGUMENT Invalid argument.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The requested vector has not been registered
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync with the SAL Procedure SAL_SET_VECTORS.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetVectors (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 VectorType
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalGetVectorsFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VectorType,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalMcGetParamsFunctionId service of Extended SAL Base Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalMcGetParamsFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Base Services Class. See EsalMcGetParamsFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param ParamInfoType The parameter type to retrieve.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 1 - rendezvous interrupt
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 2 - wake up
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 3 - Corrected Platform Error Vector.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS Call completed without error.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_INVALID_ARGUMENT Invalid argument.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The requested vector has not been registered
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync with the SAL Procedure SAL_MC_SET_PARAMS.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalMcGetParams (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 ParamInfoType
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalMcGetParamsFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ParamInfoType,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalMcGetParamsFunctionId service of Extended SAL Base Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalMcGetParamsFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Base Services Class. See EsalMcGetParamsFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS Call completed without error.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The requested vector has not been registered
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync with the SAL Procedure SAL_MC_SET_PARAMS.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalMcGetMcParams (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VOID
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalMcGetMcParamsFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetMcCheckinFlagsFunctionId service of Extended SAL Base Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetMcCheckinFlagsFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Base Services Class. See EsalGetMcCheckinFlagsFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuIndex The index of the CPU of set of enabled CPUs to check.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The checkin status of the requested CPU was returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetMcCheckinFlags (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuIndex
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_BASE_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EsalGetMcCheckinFlagsFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuIndex,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalAddCpuDataFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalAddCpuDataFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalAddCpuDataFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU being added.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Enabled The enable flag for the CPU being added.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync TRUE means the CPU is enabled.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync FALSE means the CPU is disabled.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param PalCompatibility The PAL Compatibility value for the CPU being added.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The CPU was added to the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NOT_ENOUGH_SCRATCH There are not enough resource available to add the CPU.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalAddCpuData (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN Enabled,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 PalCompatibility
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync AddCpuDataFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Enabled,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PalCompatibility,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalRemoveCpuDataFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalRemoveCpuDataFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalRemoveCpuDataFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU being removed.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The CPU was removed from the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The specified CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalRemoveCpuData (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync RemoveCpuDataFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalModifyCpuDataFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalModifyCpuDataFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalModifyCpuDataFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU being modified.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Enabled The enable flag for the CPU being modified.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync TRUE means the CPU is enabled.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync FALSE means the CPU is disabled.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param PalCompatibility The PAL Compatibility value for the CPU being modified.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The CPU database was updated.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The specified CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalModifyCpuData (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN Enabled,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 PalCompatibility
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync ModifyCpuDataFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Enabled,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync PalCompatibility,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetCpuDataByIdFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetCpuDataByIdFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalGetCpuDataByIdFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU being looked up.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param IndexByEnabledCpu If TRUE, then the index of set of enabled CPUs of database is returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync If FALSE, then the index of set of all CPUs of database is returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The information on the specified CPU was returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The specified CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetCpuDataById (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN IndexByEnabledCpu
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync GetCpuDataByIDFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IndexByEnabledCpu,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetCpuDataByIndexFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetCpuDataByIndexFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalGetCpuDataByIndexFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param Index The Global ID for the CPU being modified.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param IndexByEnabledCpu If TRUE, then the index of set of enabled CPUs of database is returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync If FALSE, then the index of set of all CPUs of database is returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The information on the specified CPU was returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The specified CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetCpuDataByIndex (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 Index,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN IndexByEnabledCpu
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync GetCpuDataByIndexFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Index,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IndexByEnabledCpu,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalWhoAmIFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalWhoAmIFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalWhoAmIFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param IndexByEnabledCpu If TRUE, then the index of set of enabled CPUs of database is returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync If FALSE, then the index of set of all CPUs of database is returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The Global ID for the calling CPU was returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The calling CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalWhoAmI (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN BOOLEAN IndexByEnabledCpu
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CurrentProcInfoFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IndexByEnabledCpu,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalNumProcessors service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalNumProcessors service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalNumProcessors of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The information on the number of CPUs in the platform
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync was returned.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalNumProcessors (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync VOID
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync NumProcessorsFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalSetMinStateFnctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalSetMinStateFnctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalSetMinStateFnctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU whose MINSTATE pointer is being set.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param MinStatePointer The physical address of the MINSTATE buffer for the CPU
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync specified by CpuGlobalId.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The MINSTATE pointer was set for the specified CPU.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The specified CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalSetMinState (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_PHYSICAL_ADDRESS MinStatePointer
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SetMinStateFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MinStatePointer,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalGetMinStateFunctionId service of Extended SAL MP Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalGetMinStateFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MP Services Class. See EsalGetMinStateFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU whose MINSTATE pointer is being retrieved.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_SUCCESS The MINSTATE pointer for the specified CPU was retrieved.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION The specified CPU is not in the database.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalGetMinState (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MP_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync GetMinStateFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalMcsGetStateInfoFunctionId service of Extended SAL MCA Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalMcsGetStateInfoFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MCA Services Class. See EsalMcsGetStateInfoFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU whose MCA state buffer is being retrieved.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param StateBufferPointer A pointer to the returned MCA state buffer.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param RequiredStateBufferSize A pointer to the size, in bytes, of the returned MCA state buffer.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS MINSTATE successfully got and size calculated.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION Fail to get MINSTATE.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalMcaGetStateInfo (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync OUT EFI_PHYSICAL_ADDRESS *StateBufferPointer,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync OUT UINT64 *RequiredStateBufferSize
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync SAL_RETURN_REGS Regs;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Regs = EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync McaGetStateInfoFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync *StateBufferPointer = (EFI_PHYSICAL_ADDRESS) Regs.r9;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync *RequiredStateBufferSize = (UINT64) Regs.r10;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return Regs;
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync/**
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync Wrapper for the EsalMcaRegisterCpuFunctionId service of Extended SAL MCA Services Class.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync This function is a wrapper for the EsalMcaRegisterCpuFunctionId service of Extended SAL
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync MCA Services Class. See EsalMcaRegisterCpuFunctionId of Extended SAL Specification.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param CpuGlobalId The Global ID for the CPU whose MCA state buffer is being set.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @param StateBufferPointer A pointer to the MCA state buffer.
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SAL_NO_INFORMATION Cannot get the processor info with the CpuId
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync @retval EFI_SUCCESS Save the processor's state info successfully
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync**/
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncSAL_RETURN_REGS
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEFIAPI
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsyncEsalMcaRegisterCpu (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN UINT64 CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync IN EFI_PHYSICAL_ADDRESS StateBufferPointer
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync )
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync{
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync return EsalCall (
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_SERVICES_PROTOCOL_GUID_LO,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync EFI_EXTENDED_SAL_MCA_SERVICES_PROTOCOL_GUID_HI,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync McaRegisterCpuFunctionId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync CpuGlobalId,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync StateBufferPointer,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0,
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync 0
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync );
4fd606d1f5abe38e1f42c38de1d2e895166bd0f4vboxsync}