2 Support routines for memory profile for DxeCore.
4 Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>
5 This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php.
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
18 #include <Guid/MemoryProfile.h>
20 #include "DxeCoreMemoryProfileServices.h"
23 Record memory profile of multilevel caller.
25 @param[in] CallerAddress Address of caller.
26 @param[in] Action Memory profile action.
27 @param[in] MemoryType Memory type.
28 EfiMaxMemoryType means the MemoryType is unknown.
29 @param[in] Buffer Buffer address.
30 @param[in] Size Buffer size.
31 @param[in] ActionString String for memory profile action.
32 Only needed for user defined allocate action.
34 @return EFI_SUCCESS Memory profile is updated.
35 @return EFI_UNSUPPORTED Memory profile is unsupported,
36 or memory profile for the image is not required,
37 or memory profile for the memory type is not required.
38 @return EFI_ACCESS_DENIED It is during memory profile data getting.
39 @return EFI_ABORTED Memory profile recording is not enabled.
40 @return EFI_OUT_OF_RESOURCES No enough resource to update memory profile for allocate action.
41 @return EFI_NOT_FOUND No matched allocate info found for free action.
46 MemoryProfileLibRecord (
47 IN PHYSICAL_ADDRESS CallerAddress
,
48 IN MEMORY_PROFILE_ACTION Action
,
49 IN EFI_MEMORY_TYPE MemoryType
,
52 IN CHAR8
*ActionString OPTIONAL
55 return CoreUpdateProfile (CallerAddress
, Action
, MemoryType
, Size
, Buffer
, ActionString
);