/**@file Copyright (c) 2006 - 2009, Intel Corporation. All rights reserved.
Portions copyright (c) 2008 - 2010, Apple Inc. All rights reserved.
Portions copyright (c) 2011 - 2012, ARM Ltd. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #include #include #include #include #include #include #include /** If the build is done on cygwin the paths are cygpaths. /cygdrive/c/tmp.txt vs c:\tmp.txt so we need to convert them to work with RVD commands @param Name Path to convert if needed **/ CONST CHAR8 * DeCygwinPathIfNeeded ( IN CONST CHAR8 *Name, IN CHAR8 *Temp, IN UINTN Size ) { CHAR8 *Ptr; UINTN Index; UINTN Index2; Ptr = AsciiStrStr (Name, "/cygdrive/"); if (Ptr == NULL) { return Name; } for (Index = 9, Index2 = 0; (Index < (Size + 9)) && (Ptr[Index] != '\0'); Index++, Index2++) { Temp[Index2] = Ptr[Index]; if (Temp[Index2] == '/') { Temp[Index2] = '\\'; } if (Index2 == 1) { Temp[Index2 - 1] = Ptr[Index]; Temp[Index2] = ':'; } } return Temp; } /** Performs additional actions after a PE/COFF image has been loaded and relocated. If ImageContext is NULL, then ASSERT(). @param ImageContext Pointer to the image context structure that describes the PE/COFF image that has already been loaded and relocated. **/ VOID EFIAPI UefiImageLoaderRelocateImageExtraAction ( IN CONST UEFI_IMAGE_LOADER_IMAGE_CONTEXT *ImageContext ) { RETURN_STATUS Status; CONST CHAR8 *PdbPath; UINT32 PdbPathSize; #if defined (__CC_ARM) || defined (__GNUC__) CHAR8 Temp[512]; #endif Status = UefiImageGetSymbolsPath (ImageContext, &PdbPath, &PdbPathSize); if (!RETURN_ERROR (Status)) { #ifdef __CC_ARM #if (__ARMCC_VERSION < 500000) // Print out the command for the RVD debugger to load symbols for this image DEBUG ((DEBUG_LOAD | DEBUG_INFO, "load /a /ni /np %a &0x%p\n", DeCygwinPathIfNeeded (PdbPath, Temp, sizeof (Temp)), UefiImageLoaderGetImageAddress (ImageContext))); #else // Print out the command for the DS-5 to load symbols for this image DEBUG ((DEBUG_LOAD | DEBUG_INFO, "add-symbol-file %a -o 0x%p\n", DeCygwinPathIfNeeded (PdbPath, Temp, sizeof (Temp)), UefiImageLoaderGetImageAddress (ImageContext))); #endif #elif __GNUC__ // This may not work correctly if you generate PE/COFF directly as then the Offset would not be required DEBUG ((DEBUG_LOAD | DEBUG_INFO, "add-symbol-file %a -o 0x%p\n", DeCygwinPathIfNeeded (PdbPath, Temp, sizeof (Temp)), UefiImageLoaderGetImageAddress (ImageContext))); #else DEBUG ((DEBUG_LOAD | DEBUG_INFO, "Loading driver at 0x%11p EntryPoint=0x%11p\n", (VOID *)(UINTN)UefiImageLoaderGetImageAddress (ImageContext), FUNCTION_ENTRY_POINT (UefiImageLoaderGetImageEntryPoint (ImageContext)))); #endif } else { DEBUG ((DEBUG_LOAD | DEBUG_INFO, "Loading driver at 0x%11p EntryPoint=0x%11p\n", (VOID *)(UINTN)UefiImageLoaderGetImageAddress (ImageContext), FUNCTION_ENTRY_POINT (UefiImageLoaderGetImageEntryPoint (ImageContext)))); } } /** Performs additional actions just before a PE/COFF image is unloaded. Any resources that were allocated by UefiImageLoaderRelocateImageExtraAction() must be freed. If ImageContext is NULL, then ASSERT(). @param ImageContext Pointer to the image context structure that describes the PE/COFF image that is being unloaded. **/ VOID EFIAPI UefiImageLoaderUnloadImageExtraAction ( IN OUT UEFI_IMAGE_LOADER_IMAGE_CONTEXT *ImageContext ) { RETURN_STATUS Status; CONST CHAR8 *PdbPath; UINT32 PdbPathSize; #if defined (__CC_ARM) || defined (__GNUC__) CHAR8 Temp[512]; #endif Status = UefiImageGetSymbolsPath (ImageContext, &PdbPath, &PdbPathSize); if (!RETURN_ERROR (Status)) { #ifdef __CC_ARM // Print out the command for the RVD debugger to load symbols for this image DEBUG ((DEBUG_LOAD | DEBUG_INFO, "unload symbols_only %a\n", DeCygwinPathIfNeeded (PdbPath, Temp, sizeof (Temp)))); #elif __GNUC__ // This may not work correctly if you generate PE/COFF directly as then the Offset would not be required DEBUG ((DEBUG_LOAD | DEBUG_INFO, "remove-symbol-file %a 0x%08x\n", DeCygwinPathIfNeeded (PdbPath, Temp, sizeof (Temp)), (UINTN)UefiImageLoaderGetImageAddress (ImageContext))); #else DEBUG ((DEBUG_LOAD | DEBUG_INFO, "Unloading %a\n", PdbPath)); #endif } else { DEBUG ((DEBUG_LOAD | DEBUG_INFO, "Unloading driver at 0x%11p\n", (VOID *)(UINTN)UefiImageLoaderGetImageAddress (ImageContext))); } }