--- /dev/null
+/** @file\r
+ Support routines for memory profile for DxeCore.\r
+\r
+ Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
+ This program and the accompanying materials \r
+ are licensed and made available under the terms and conditions of the BSD License \r
+ which accompanies this distribution. The full text of the license may be found at \r
+ http://opensource.org/licenses/bsd-license.php. \r
+\r
+ THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, \r
+ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. \r
+\r
+**/\r
+\r
+\r
+#include <PiDxe.h>\r
+\r
+#include <Guid/MemoryProfile.h>\r
+\r
+#include "DxeCoreMemoryProfileServices.h"\r
+\r
+/**\r
+ Record memory profile of multilevel caller.\r
+\r
+ @param[in] CallerAddress Address of caller.\r
+ @param[in] Action Memory profile action.\r
+ @param[in] MemoryType Memory type.\r
+ EfiMaxMemoryType means the MemoryType is unknown.\r
+ @param[in] Buffer Buffer address.\r
+ @param[in] Size Buffer size.\r
+ @param[in] ActionString String for memory profile action.\r
+ Only needed for user defined allocate action.\r
+\r
+ @return EFI_SUCCESS Memory profile is updated.\r
+ @return EFI_UNSUPPORTED Memory profile is unsupported,\r
+ or memory profile for the image is not required,\r
+ or memory profile for the memory type is not required.\r
+ @return EFI_ACCESS_DENIED It is during memory profile data getting.\r
+ @return EFI_ABORTED Memory profile recording is not enabled.\r
+ @return EFI_OUT_OF_RESOURCES No enough resource to update memory profile for allocate action.\r
+ @return EFI_NOT_FOUND No matched allocate info found for free action.\r
+\r
+**/\r
+EFI_STATUS\r
+EFIAPI\r
+MemoryProfileLibRecord (\r
+ IN PHYSICAL_ADDRESS CallerAddress,\r
+ IN MEMORY_PROFILE_ACTION Action,\r
+ IN EFI_MEMORY_TYPE MemoryType,\r
+ IN VOID *Buffer,\r
+ IN UINTN Size,\r
+ IN CHAR8 *ActionString OPTIONAL\r
+ )\r
+{\r
+ return CoreUpdateProfile (CallerAddress, Action, MemoryType, Size, Buffer, ActionString);\r
+}\r
+\r
/** @file\r
Support routines for memory allocation routines based \r
- on boot services for Dxe phase drivers.\r
+ on DxeCore Memory Allocation services for DxeCore,\r
+ with memory profile support.\r
\r
- Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.<BR>\r
+ Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR>\r
This program and the accompanying materials \r
are licensed and made available under the terms and conditions of the BSD License \r
which accompanies this distribution. The full text of the license may be found at \r
#include <Library/DebugLib.h>\r
#include "DxeCoreMemoryAllocationServices.h"\r
\r
+#include <Library/MemoryProfileLib.h>\r
+\r
/**\r
Allocates one or more 4KB pages of a certain memory type.\r
\r
IN UINTN Pages\r
)\r
{\r
- return InternalAllocatePages (EfiBootServicesData, Pages);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocatePages (EfiBootServicesData, Pages);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_PAGES,\r
+ EfiBootServicesData,\r
+ Buffer,\r
+ EFI_PAGES_TO_SIZE (Pages),\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN Pages\r
)\r
{\r
- return InternalAllocatePages (EfiRuntimeServicesData, Pages);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocatePages (EfiRuntimeServicesData, Pages);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RUNTIME_PAGES,\r
+ EfiRuntimeServicesData,\r
+ Buffer,\r
+ EFI_PAGES_TO_SIZE (Pages),\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN Pages\r
)\r
{\r
- return InternalAllocatePages (EfiReservedMemoryType, Pages);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocatePages (EfiReservedMemoryType, Pages);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RESERVED_PAGES,\r
+ EfiReservedMemoryType,\r
+ Buffer,\r
+ EFI_PAGES_TO_SIZE (Pages),\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN Alignment\r
)\r
{\r
- return InternalAllocateAlignedPages (EfiBootServicesData, Pages, Alignment);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocateAlignedPages (EfiBootServicesData, Pages, Alignment);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_ALIGNED_PAGES,\r
+ EfiBootServicesData,\r
+ Buffer,\r
+ EFI_PAGES_TO_SIZE (Pages),\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN Alignment\r
)\r
{\r
- return InternalAllocateAlignedPages (EfiRuntimeServicesData, Pages, Alignment);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocateAlignedPages (EfiRuntimeServicesData, Pages, Alignment);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_ALIGNED_RUNTIME_PAGES,\r
+ EfiRuntimeServicesData,\r
+ Buffer,\r
+ EFI_PAGES_TO_SIZE (Pages),\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN Alignment\r
)\r
{\r
- return InternalAllocateAlignedPages (EfiReservedMemoryType, Pages, Alignment);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocateAlignedPages (EfiReservedMemoryType, Pages, Alignment);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_ALIGNED_RESERVED_PAGES,\r
+ EfiReservedMemoryType,\r
+ Buffer,\r
+ EFI_PAGES_TO_SIZE (Pages),\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN AllocationSize\r
)\r
{\r
- return InternalAllocatePool (EfiBootServicesData, AllocationSize);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocatePool (EfiBootServicesData, AllocationSize);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_POOL,\r
+ EfiBootServicesData,\r
+ Buffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN AllocationSize\r
)\r
{\r
- return InternalAllocatePool (EfiRuntimeServicesData, AllocationSize);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocatePool (EfiRuntimeServicesData, AllocationSize);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RUNTIME_POOL,\r
+ EfiRuntimeServicesData,\r
+ Buffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN AllocationSize\r
)\r
{\r
- return InternalAllocatePool (EfiReservedMemoryType, AllocationSize);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocatePool (EfiReservedMemoryType, AllocationSize);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RESERVED_POOL,\r
+ EfiReservedMemoryType,\r
+ Buffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN AllocationSize\r
)\r
{\r
- return InternalAllocateZeroPool (EfiBootServicesData, AllocationSize);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocateZeroPool (EfiBootServicesData, AllocationSize);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_ZERO_POOL,\r
+ EfiBootServicesData,\r
+ Buffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN AllocationSize\r
)\r
{\r
- return InternalAllocateZeroPool (EfiRuntimeServicesData, AllocationSize);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocateZeroPool (EfiRuntimeServicesData, AllocationSize);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RUNTIME_ZERO_POOL,\r
+ EfiRuntimeServicesData,\r
+ Buffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN UINTN AllocationSize\r
)\r
{\r
- return InternalAllocateZeroPool (EfiReservedMemoryType, AllocationSize);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalAllocateZeroPool (EfiReservedMemoryType, AllocationSize);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RESERVED_ZERO_POOL,\r
+ EfiReservedMemoryType,\r
+ Buffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN CONST VOID *Buffer\r
)\r
{\r
- return InternalAllocateCopyPool (EfiBootServicesData, AllocationSize, Buffer);\r
+ VOID *NewBuffer;\r
+\r
+ NewBuffer = InternalAllocateCopyPool (EfiBootServicesData, AllocationSize, Buffer);\r
+ if (NewBuffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_COPY_POOL,\r
+ EfiBootServicesData,\r
+ NewBuffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return NewBuffer;\r
}\r
\r
/**\r
IN CONST VOID *Buffer\r
)\r
{\r
- return InternalAllocateCopyPool (EfiRuntimeServicesData, AllocationSize, Buffer);\r
+ VOID *NewBuffer;\r
+\r
+ NewBuffer = InternalAllocateCopyPool (EfiRuntimeServicesData, AllocationSize, Buffer);\r
+ if (NewBuffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RUNTIME_COPY_POOL,\r
+ EfiRuntimeServicesData,\r
+ NewBuffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return NewBuffer;\r
}\r
\r
/**\r
IN CONST VOID *Buffer\r
)\r
{\r
- return InternalAllocateCopyPool (EfiReservedMemoryType, AllocationSize, Buffer);\r
+ VOID *NewBuffer;\r
+\r
+ NewBuffer = InternalAllocateCopyPool (EfiReservedMemoryType, AllocationSize, Buffer);\r
+ if (NewBuffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_ALLOCATE_RESERVED_COPY_POOL,\r
+ EfiRuntimeServicesData,\r
+ NewBuffer,\r
+ AllocationSize,\r
+ NULL\r
+ );\r
+ }\r
+ return NewBuffer;\r
}\r
\r
/**\r
IN VOID *OldBuffer OPTIONAL\r
)\r
{\r
- return InternalReallocatePool (EfiBootServicesData, OldSize, NewSize, OldBuffer);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalReallocatePool (EfiBootServicesData, OldSize, NewSize, OldBuffer);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_REALLOCATE_POOL,\r
+ EfiBootServicesData,\r
+ Buffer,\r
+ NewSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN VOID *OldBuffer OPTIONAL\r
)\r
{\r
- return InternalReallocatePool (EfiRuntimeServicesData, OldSize, NewSize, OldBuffer);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalReallocatePool (EfiRuntimeServicesData, OldSize, NewSize, OldBuffer);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_REALLOCATE_RUNTIME_POOL,\r
+ EfiRuntimeServicesData,\r
+ Buffer,\r
+ NewSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r
IN VOID *OldBuffer OPTIONAL\r
)\r
{\r
- return InternalReallocatePool (EfiReservedMemoryType, OldSize, NewSize, OldBuffer);\r
+ VOID *Buffer;\r
+\r
+ Buffer = InternalReallocatePool (EfiReservedMemoryType, OldSize, NewSize, OldBuffer);\r
+ if (Buffer != NULL) {\r
+ MemoryProfileLibRecord (\r
+ (PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS(0),\r
+ MEMORY_PROFILE_ACTION_LIB_REALLOCATE_RESERVED_POOL,\r
+ EfiReservedMemoryType,\r
+ Buffer,\r
+ NewSize,\r
+ NULL\r
+ );\r
+ }\r
+ return Buffer;\r
}\r
\r
/**\r