mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-20 12:14:27 +02:00
ArmPkg/DefaultExceptionHandlerLib: walk call stack unconditionally
Currently, we only attempt to walk the call stack and print a backtrace if the program counter refers to a location covered by a PE/COFF image. However, regardless of the value of PC, the frame pointer may still have a meaningful value, and so we can still produce the remainder of the backtrace. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
This commit is contained in:
parent
b8fc72bd7d
commit
173bf5c847
@ -181,6 +181,9 @@ DefaultExceptionHandler (
|
||||
DEBUG ((EFI_D_ERROR, "PC 0x%012lx (0x%012lx+0x%08x) [ 0] %a\n",
|
||||
SystemContext.SystemContextAArch64->ELR, ImageBase,
|
||||
SystemContext.SystemContextAArch64->ELR - ImageBase, BaseName (Pdb)));
|
||||
} else {
|
||||
DEBUG ((EFI_D_ERROR, "PC 0x%012lx\n", SystemContext.SystemContextAArch64->ELR));
|
||||
}
|
||||
|
||||
if ((UINT64 *)SystemContext.SystemContextAArch64->FP != 0) {
|
||||
Idx = 0;
|
||||
@ -200,10 +203,14 @@ DefaultExceptionHandler (
|
||||
}
|
||||
DEBUG ((EFI_D_ERROR, "PC 0x%012lx (0x%012lx+0x%08x) [% 2d] %a\n",
|
||||
Fp[1], ImageBase, Fp[1] - ImageBase, Idx, BaseName (Pdb)));
|
||||
} else {
|
||||
DEBUG ((EFI_D_ERROR, "PC 0x%012lx\n", Fp[1]));
|
||||
}
|
||||
}
|
||||
PrevPdb = Pdb = GetImageName (SystemContext.SystemContextAArch64->ELR, &ImageBase, &PeCoffSizeOfHeader);
|
||||
if (Pdb != NULL) {
|
||||
DEBUG ((EFI_D_ERROR, "\n[ 0] %a\n", Pdb));
|
||||
}
|
||||
|
||||
Idx = 0;
|
||||
for (Fp = RootFp; Fp[0] != 0; Fp = (UINT64 *)Fp[0]) {
|
||||
@ -214,7 +221,6 @@ DefaultExceptionHandler (
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
DEBUG_CODE_END ();
|
||||
|
||||
DEBUG ((EFI_D_ERROR, "\n X0 0x%016lx X1 0x%016lx X2 0x%016lx X3 0x%016lx\n", SystemContext.SystemContextAArch64->X0, SystemContext.SystemContextAArch64->X1, SystemContext.SystemContextAArch64->X2, SystemContext.SystemContextAArch64->X3));
|
||||
|
Loading…
x
Reference in New Issue
Block a user