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)
86 if (ImageContext
->PdbPointer
) {
88 #if (__ARMCC_VERSION < 500000)
89 // Print out the command for the RVD debugger to load symbols for this image
90 DEBUG ((EFI_D_ERROR
, "load /a /ni /np %a &0x%p\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
92 // Print out the command for the DS-5 to load symbols for this image
93 DEBUG ((EFI_D_ERROR
, "add-symbol-file %a 0x%p\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
96 // This may not work correctly if you generate PE/COFF directlyas then the Offset would not be required
97 DEBUG ((EFI_D_ERROR
, "add-symbol-file %a 0x%p\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
99 DEBUG ((EFI_D_ERROR
, "Loading driver at 0x%11p EntryPoint=0x%11p\n", (VOID
*)(UINTN
) ImageContext
->ImageAddress
, FUNCTION_ENTRY_POINT (ImageContext
->EntryPoint
)));
102 DEBUG ((EFI_D_ERROR
, "Loading driver at 0x%11p EntryPoint=0x%11p\n", (VOID
*)(UINTN
) ImageContext
->ImageAddress
, FUNCTION_ENTRY_POINT (ImageContext
->EntryPoint
)));
109 Performs additional actions just before a PE/COFF image is unloaded. Any resources
110 that were allocated by PeCoffLoaderRelocateImageExtraAction() must be freed.
112 If ImageContext is NULL, then ASSERT().
114 @param ImageContext Pointer to the image context structure that describes the
115 PE/COFF image that is being unloaded.
120 PeCoffLoaderUnloadImageExtraAction (
121 IN OUT PE_COFF_LOADER_IMAGE_CONTEXT
*ImageContext
124 #if !defined(MDEPKG_NDEBUG)
128 if (ImageContext
->PdbPointer
) {
130 // Print out the command for the RVD debugger to load symbols for this image
131 DEBUG ((EFI_D_ERROR
, "unload symbols_only %a\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
))));
133 // This may not work correctly if you generate PE/COFF directlyas then the Offset would not be required
134 DEBUG ((EFI_D_ERROR
, "remove-symbol-file %a 0x%08x\n", DeCygwinPathIfNeeded (ImageContext
->PdbPointer
, Temp
, sizeof (Temp
)), (UINTN
)(ImageContext
->ImageAddress
+ ImageContext
->SizeOfHeaders
)));
136 DEBUG ((EFI_D_ERROR
, "Unloading %a\n", ImageContext
->PdbPointer
));
139 DEBUG ((EFI_D_ERROR
, "Unloading driver at 0x%11p\n", (VOID
*)(UINTN
) ImageContext
->ImageAddress
));