3 Copyright (c) 2006 - 2009, Intel Corporation. All rights reserved.<BR>
4 Portions copyright (c) 2008 - 2010, Apple Inc. All rights reserved.<BR>
5 Portions copyright (c) 2011 - 2012, ARM Ltd. All rights reserved.<BR>
7 This program and the accompanying materials
8 are licensed and made available under the terms and conditions of the BSD License
9 which accompanies this distribution. The full text of the license may be found at
10 http://opensource.org/licenses/bsd-license.php
12 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
13 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
18 #include <Library/PeCoffLib.h>
20 #include <Library/BaseLib.h>
21 #include <Library/DebugLib.h>
22 #include <Library/BaseMemoryLib.h>
23 #include <Library/PeCoffExtraActionLib.h>
24 #include <Library/PrintLib.h>
28 If the build is done on cygwin the paths are cygpaths.
29 /cygdrive/c/tmp.txt vs c:\tmp.txt so we need to convert
30 them to work with RVD commands
32 @param Name Path to convert if needed
36 DeCygwinPathIfNeeded (
46 Ptr
= AsciiStrStr (Name
, "/cygdrive/");
51 for (Index
= 9, Index2
= 0; (Index
< (Size
+ 9)) && (Ptr
[Index
] != '\0'); Index
++, Index2
++) {
52 Temp
[Index2
] = Ptr
[Index
];
53 if (Temp
[Index2
] == '/') {
58 Temp
[Index2
- 1] = Ptr
[Index
];
68 Performs additional actions after a PE/COFF image has been loaded and relocated.
70 If ImageContext is NULL, then ASSERT().
72 @param ImageContext Pointer to the image context structure that describes the
73 PE/COFF image that has already been loaded and relocated.
78 PeCoffLoaderRelocateImageExtraAction (
79 IN OUT PE_COFF_LOADER_IMAGE_CONTEXT
*ImageContext
82 #if !defined(MDEPKG_NDEBUG)
87 #if (__ARMCC_VERSION < 500000)
88 // Print out the command for the RVD debugger to load symbols for this image
89 DEBUG ((EFI_D_ERROR
, "load /a /ni /np %a &0x%08x\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
91 // Print out the command for the DS-5 to load symbols for this image
92 DEBUG ((EFI_D_ERROR
, "add-symbol-file %a 0x%08x\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
95 // This may not work correctly if you generate PE/COFF directlyas then the Offset would not be required
96 DEBUG ((EFI_D_ERROR
, "add-symbol-file %a 0x%08x\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
98 DEBUG ((EFI_D_ERROR
, "Loading driver at 0x%11p EntryPoint=0x%11p\n", (VOID
*)(UINTN
) ImageContext
->ImageAddress
, FUNCTION_ENTRY_POINT (ImageContext
->EntryPoint
)));
105 Performs additional actions just before a PE/COFF image is unloaded. Any resources
106 that were allocated by PeCoffLoaderRelocateImageExtraAction() must be freed.
108 If ImageContext is NULL, then ASSERT().
110 @param ImageContext Pointer to the image context structure that describes the
111 PE/COFF image that is being unloaded.
116 PeCoffLoaderUnloadImageExtraAction (
117 IN OUT PE_COFF_LOADER_IMAGE_CONTEXT
*ImageContext
120 #if !defined(MDEPKG_NDEBUG)
126 // Print out the command for the RVD debugger to load symbols for this image
127 DEBUG ((EFI_D_ERROR
, "unload symbols_only %a\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
))));
130 // This may not work correctly if you generate PE/COFF directlyas then the Offset would not be required
131 DEBUG ((EFI_D_ERROR
, "remove-symbol-file %a 0x%08x\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
133 DEBUG ((EFI_D_ERROR
, "Unloading %a\n", ImageContext
->PdbPointer
));