mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-29 16:44:10 +02:00
MdeModulePkg DxeCore: Enhance memory profile for memory leak detection
1. Implement include GetRecordingState/SetRecordingState/Record for memory profile protocol. 2. Consume PcdMemoryProfilePropertyMask to support disable recording at the start. 3. Consume PcdMemoryProfileDriverPath to control which drivers need memory profile data. Cc: Jiewen Yao <jiewen.yao@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Star Zeng <star.zeng@intel.com> Reviewed-by: Jiewen Yao <jiewen.yao@intel.com>
This commit is contained in:
parent
94092aa603
commit
1d60fe9642
@ -2780,11 +2780,13 @@ MemoryProfileInstallProtocol (
|
|||||||
@param DriverEntry Image info.
|
@param DriverEntry Image info.
|
||||||
@param FileType Image file type.
|
@param FileType Image file type.
|
||||||
|
|
||||||
@retval TRUE Register success.
|
@return EFI_SUCCESS Register successfully.
|
||||||
@retval FALSE Register fail.
|
@return EFI_UNSUPPORTED Memory profile unsupported,
|
||||||
|
or memory profile for the image is not required.
|
||||||
|
@return EFI_OUT_OF_RESOURCES No enough resource for this register.
|
||||||
|
|
||||||
**/
|
**/
|
||||||
BOOLEAN
|
EFI_STATUS
|
||||||
RegisterMemoryProfileImage (
|
RegisterMemoryProfileImage (
|
||||||
IN LOADED_IMAGE_PRIVATE_DATA *DriverEntry,
|
IN LOADED_IMAGE_PRIVATE_DATA *DriverEntry,
|
||||||
IN EFI_FV_FILETYPE FileType
|
IN EFI_FV_FILETYPE FileType
|
||||||
@ -2795,11 +2797,13 @@ RegisterMemoryProfileImage (
|
|||||||
|
|
||||||
@param DriverEntry Image info.
|
@param DriverEntry Image info.
|
||||||
|
|
||||||
@retval TRUE Unregister success.
|
@return EFI_SUCCESS Unregister successfully.
|
||||||
@retval FALSE Unregister fail.
|
@return EFI_UNSUPPORTED Memory profile unsupported,
|
||||||
|
or memory profile for the image is not required.
|
||||||
|
@return EFI_NOT_FOUND The image is not found.
|
||||||
|
|
||||||
**/
|
**/
|
||||||
BOOLEAN
|
EFI_STATUS
|
||||||
UnregisterMemoryProfileImage (
|
UnregisterMemoryProfileImage (
|
||||||
IN LOADED_IMAGE_PRIVATE_DATA *DriverEntry
|
IN LOADED_IMAGE_PRIVATE_DATA *DriverEntry
|
||||||
);
|
);
|
||||||
@ -2810,20 +2814,31 @@ UnregisterMemoryProfileImage (
|
|||||||
@param CallerAddress Address of caller who call Allocate or Free.
|
@param CallerAddress Address of caller who call Allocate or Free.
|
||||||
@param Action This Allocate or Free action.
|
@param Action This Allocate or Free action.
|
||||||
@param MemoryType Memory type.
|
@param MemoryType Memory type.
|
||||||
|
EfiMaxMemoryType means the MemoryType is unknown.
|
||||||
@param Size Buffer size.
|
@param Size Buffer size.
|
||||||
@param Buffer Buffer address.
|
@param Buffer Buffer address.
|
||||||
|
@param ActionString String for memory profile action.
|
||||||
|
Only needed for user defined allocate action.
|
||||||
|
|
||||||
@retval TRUE Profile udpate success.
|
@return EFI_SUCCESS Memory profile is updated.
|
||||||
@retval FALSE Profile update fail.
|
@return EFI_UNSUPPORTED Memory profile is unsupported,
|
||||||
|
or memory profile for the image is not required,
|
||||||
|
or memory profile for the memory type is not required.
|
||||||
|
@return EFI_ACCESS_DENIED It is during memory profile data getting.
|
||||||
|
@return EFI_ABORTED Memory profile recording is not enabled.
|
||||||
|
@return EFI_OUT_OF_RESOURCES No enough resource to update memory profile for allocate action.
|
||||||
|
@return EFI_NOT_FOUND No matched allocate info found for free action.
|
||||||
|
|
||||||
**/
|
**/
|
||||||
BOOLEAN
|
EFI_STATUS
|
||||||
|
EFIAPI
|
||||||
CoreUpdateProfile (
|
CoreUpdateProfile (
|
||||||
IN EFI_PHYSICAL_ADDRESS CallerAddress,
|
IN EFI_PHYSICAL_ADDRESS CallerAddress,
|
||||||
IN MEMORY_PROFILE_ACTION Action,
|
IN MEMORY_PROFILE_ACTION Action,
|
||||||
IN EFI_MEMORY_TYPE MemoryType,
|
IN EFI_MEMORY_TYPE MemoryType,
|
||||||
IN UINTN Size, // Valid for AllocatePages/FreePages/AllocatePool
|
IN UINTN Size, // Valid for AllocatePages/FreePages/AllocatePool
|
||||||
IN VOID *Buffer
|
IN VOID *Buffer,
|
||||||
|
IN CHAR8 *ActionString OPTIONAL
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -187,6 +187,7 @@
|
|||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdMaxEfiSystemTablePointerAddress ## CONSUMES
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMaxEfiSystemTablePointerAddress ## CONSUMES
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdMemoryProfileMemoryType ## CONSUMES
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMemoryProfileMemoryType ## CONSUMES
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdMemoryProfilePropertyMask ## CONSUMES
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMemoryProfilePropertyMask ## CONSUMES
|
||||||
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMemoryProfileDriverPath ## CONSUMES
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdPropertiesTableEnable ## CONSUMES
|
gEfiMdeModulePkgTokenSpaceGuid.PcdPropertiesTableEnable ## CONSUMES
|
||||||
|
|
||||||
# [Hob]
|
# [Hob]
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1335,7 +1335,14 @@ CoreAllocatePages (
|
|||||||
|
|
||||||
Status = CoreInternalAllocatePages (Type, MemoryType, NumberOfPages, Memory);
|
Status = CoreInternalAllocatePages (Type, MemoryType, NumberOfPages, Memory);
|
||||||
if (!EFI_ERROR (Status)) {
|
if (!EFI_ERROR (Status)) {
|
||||||
CoreUpdateProfile ((EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0), MemoryProfileActionAllocatePages, MemoryType, EFI_PAGES_TO_SIZE (NumberOfPages), (VOID *) (UINTN) *Memory);
|
CoreUpdateProfile (
|
||||||
|
(EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0),
|
||||||
|
MemoryProfileActionAllocatePages,
|
||||||
|
MemoryType,
|
||||||
|
EFI_PAGES_TO_SIZE (NumberOfPages),
|
||||||
|
(VOID *) (UINTN) *Memory,
|
||||||
|
NULL
|
||||||
|
);
|
||||||
InstallMemoryAttributesTableOnMemoryAllocation (MemoryType);
|
InstallMemoryAttributesTableOnMemoryAllocation (MemoryType);
|
||||||
}
|
}
|
||||||
return Status;
|
return Status;
|
||||||
@ -1444,7 +1451,14 @@ CoreFreePages (
|
|||||||
|
|
||||||
Status = CoreInternalFreePages (Memory, NumberOfPages, &MemoryType);
|
Status = CoreInternalFreePages (Memory, NumberOfPages, &MemoryType);
|
||||||
if (!EFI_ERROR (Status)) {
|
if (!EFI_ERROR (Status)) {
|
||||||
CoreUpdateProfile ((EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0), MemoryProfileActionFreePages, MemoryType, EFI_PAGES_TO_SIZE (NumberOfPages), (VOID *) (UINTN) Memory);
|
CoreUpdateProfile (
|
||||||
|
(EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0),
|
||||||
|
MemoryProfileActionFreePages,
|
||||||
|
MemoryType,
|
||||||
|
EFI_PAGES_TO_SIZE (NumberOfPages),
|
||||||
|
(VOID *) (UINTN) Memory,
|
||||||
|
NULL
|
||||||
|
);
|
||||||
InstallMemoryAttributesTableOnMemoryAllocation (MemoryType);
|
InstallMemoryAttributesTableOnMemoryAllocation (MemoryType);
|
||||||
}
|
}
|
||||||
return Status;
|
return Status;
|
||||||
|
@ -276,7 +276,14 @@ CoreAllocatePool (
|
|||||||
|
|
||||||
Status = CoreInternalAllocatePool (PoolType, Size, Buffer);
|
Status = CoreInternalAllocatePool (PoolType, Size, Buffer);
|
||||||
if (!EFI_ERROR (Status)) {
|
if (!EFI_ERROR (Status)) {
|
||||||
CoreUpdateProfile ((EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0), MemoryProfileActionAllocatePool, PoolType, Size, *Buffer);
|
CoreUpdateProfile (
|
||||||
|
(EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0),
|
||||||
|
MemoryProfileActionAllocatePool,
|
||||||
|
PoolType,
|
||||||
|
Size,
|
||||||
|
*Buffer,
|
||||||
|
NULL
|
||||||
|
);
|
||||||
InstallMemoryAttributesTableOnMemoryAllocation (PoolType);
|
InstallMemoryAttributesTableOnMemoryAllocation (PoolType);
|
||||||
}
|
}
|
||||||
return Status;
|
return Status;
|
||||||
@ -505,7 +512,14 @@ CoreFreePool (
|
|||||||
|
|
||||||
Status = CoreInternalFreePool (Buffer, &PoolType);
|
Status = CoreInternalFreePool (Buffer, &PoolType);
|
||||||
if (!EFI_ERROR (Status)) {
|
if (!EFI_ERROR (Status)) {
|
||||||
CoreUpdateProfile ((EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0), MemoryProfileActionFreePool, PoolType, 0, Buffer);
|
CoreUpdateProfile (
|
||||||
|
(EFI_PHYSICAL_ADDRESS) (UINTN) RETURN_ADDRESS (0),
|
||||||
|
MemoryProfileActionFreePool,
|
||||||
|
PoolType,
|
||||||
|
0,
|
||||||
|
Buffer,
|
||||||
|
NULL
|
||||||
|
);
|
||||||
InstallMemoryAttributesTableOnMemoryAllocation (PoolType);
|
InstallMemoryAttributesTableOnMemoryAllocation (PoolType);
|
||||||
}
|
}
|
||||||
return Status;
|
return Status;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user